x
Yes
No
Do you want to visit DriveHQ English website?
首页
产品服务
价格
免费试用
下载客户端
关于我们
云文件服务
|
云备份服务
|
FTP服务
|
企业邮箱服务
|
网站托管
|
客户端软件
云文件服务
云备份服务
FTP服务
企业级邮箱服务
网站托管
客户端软件
storage_order.hpp - Hosted on DriveHQ Cloud IT Platform
返回上层目录
上传
下载
共享
发布
新建文件夹
新建文件
复制
剪切
删除
粘贴
评论
升级服务
路径: \\game3dprogramming\materials\GameFactory\GameFactoryDemo\references\boost_1_35_0\boost\multi_array\storage_order.hpp
旋转
特效
属性
历史版本
// Copyright 2002 The Trustees of Indiana University. // Use, modification and distribution is subject to the Boost Software // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) // Boost.MultiArray Library // Authors: Ronald Garcia // Jeremy Siek // Andrew Lumsdaine // See http://www.boost.org/libs/multi_array for documentation. #ifndef BOOST_STORAGE_ORDER_RG071801_HPP #define BOOST_STORAGE_ORDER_RG071801_HPP #include "boost/multi_array/types.hpp" #include "boost/array.hpp" #include "boost/multi_array/algorithm.hpp" #include
#include
#include
#include
#include
namespace boost { // RG - This is to make things work with VC++. So sad, so sad. class c_storage_order; class fortran_storage_order; template
class general_storage_order { public: typedef detail::multi_array::size_type size_type; template
general_storage_order(OrderingIter ordering, AscendingIter ascending) { boost::detail::multi_array::copy_n(ordering,NumDims,ordering_.begin()); boost::detail::multi_array::copy_n(ascending,NumDims,ascending_.begin()); } // RG - ideally these would not be necessary, but some compilers // don't like template conversion operators. I suspect that not // too many folk will feel the need to use customized // storage_order objects, I sacrifice that feature for compiler support. general_storage_order(const c_storage_order&) { for (size_type i=0; i != NumDims; ++i) { ordering_[i] = NumDims - 1 - i; } ascending_.assign(true); } general_storage_order(const fortran_storage_order&) { for (size_type i=0; i != NumDims; ++i) { ordering_[i] = i; } ascending_.assign(true); } size_type ordering(size_type dim) const { return ordering_[dim]; } bool ascending(size_type dim) const { return ascending_[dim]; } bool all_dims_ascending() const { return std::accumulate(ascending_.begin(),ascending_.end(),true, std::logical_and
()); } bool operator==(general_storage_order const& rhs) const { return (ordering_ == rhs.ordering_) && (ascending_ == rhs.ascending_); } protected: boost::array
ordering_; boost::array
ascending_; }; class c_storage_order { typedef detail::multi_array::size_type size_type; public: // This is the idiom for creating your own custom storage orders. // Not supported by all compilers though! #ifndef __MWERKS__ // Metrowerks screams "ambiguity!" template
operator general_storage_order
() const { boost::array
ordering; boost::array
ascending; for (size_type i=0; i != NumDims; ++i) { ordering[i] = NumDims - 1 - i; ascending[i] = true; } return general_storage_order
(ordering.begin(), ascending.begin()); } #endif }; class fortran_storage_order { typedef detail::multi_array::size_type size_type; public: // This is the idiom for creating your own custom storage orders. // Not supported by all compilers though! #ifndef __MWERKS__ // Metrowerks screams "ambiguity!" template
operator general_storage_order
() const { boost::array
ordering; boost::array
ascending; for (size_type i=0; i != NumDims; ++i) { ordering[i] = i; ascending[i] = true; } return general_storage_order
(ordering.begin(), ascending.begin()); } #endif }; } // namespace boost #endif // BOOST_ARRAY_STORAGE_RG071801_HPP
storage_order.hpp
网页地址
文件地址
上一页
12/15
下一页
下载
( 4 KB )
Comments
Total ratings:
0
Average rating:
无评论
of 10
Would you like to comment?
Join now
, or
Logon
if you are already a member.