| 1 | #ifndef BZ_ARRAYMISC_CC
 | 
|---|
| 2 | #define BZ_ARRAYMISC_CC
 | 
|---|
| 3 | 
 | 
|---|
| 4 | #ifndef BZ_ARRAY_H
 | 
|---|
| 5 |  #error <blitz/array/misc.cc> must be included via <blitz/array.h>
 | 
|---|
| 6 | #endif
 | 
|---|
| 7 | 
 | 
|---|
| 8 | BZ_NAMESPACE(blitz)
 | 
|---|
| 9 | 
 | 
|---|
| 10 | #define BZ_ARRAY_DECLARE_UOP(fn, fnobj)                                \
 | 
|---|
| 11 | template<class T_numtype, int N_rank>                                  \
 | 
|---|
| 12 | inline                                                                 \
 | 
|---|
| 13 | _bz_ArrayExpr<_bz_ArrayExprUnaryOp<ArrayIterator<T_numtype,N_rank>,    \
 | 
|---|
| 14 |     fnobj<T_numtype> > >                                               \
 | 
|---|
| 15 | fn(const Array<T_numtype,N_rank>& array)                               \
 | 
|---|
| 16 | {                                                                      \
 | 
|---|
| 17 |     return _bz_ArrayExprUnaryOp<ArrayIterator<T_numtype,N_rank>,       \
 | 
|---|
| 18 |         fnobj<T_numtype> >(array.begin());                             \
 | 
|---|
| 19 | }                                                                      \
 | 
|---|
| 20 |                                                                        \
 | 
|---|
| 21 | template<class T_expr>                                                 \
 | 
|---|
| 22 | inline                                                                 \
 | 
|---|
| 23 | _bz_ArrayExpr<_bz_ArrayExprUnaryOp<_bz_ArrayExpr<T_expr>,              \
 | 
|---|
| 24 |     fnobj<_bz_typename T_expr::T_numtype> > >                          \
 | 
|---|
| 25 | fn(_bz_ArrayExpr<T_expr> expr)                                         \
 | 
|---|
| 26 | {                                                                      \
 | 
|---|
| 27 |     return _bz_ArrayExprUnaryOp<_bz_ArrayExpr<T_expr>,                 \
 | 
|---|
| 28 |         fnobj<_bz_typename T_expr::T_numtype> >(expr);                 \
 | 
|---|
| 29 | }                                                                      \
 | 
|---|
| 30 |                                                                        \
 | 
|---|
| 31 | template<int N_index>                                                  \
 | 
|---|
| 32 | inline                                                                 \
 | 
|---|
| 33 | _bz_ArrayExpr<_bz_ArrayExprUnaryOp<IndexPlaceholder<N_index>,          \
 | 
|---|
| 34 |     fnobj<int> > >                                                     \
 | 
|---|
| 35 | fn(IndexPlaceholder<N_index> index)                                    \
 | 
|---|
| 36 | {                                                                      \
 | 
|---|
| 37 |     return _bz_ArrayExprUnaryOp<IndexPlaceholder<N_index>,             \
 | 
|---|
| 38 |         fnobj<int> >(index);                                           \
 | 
|---|
| 39 | }
 | 
|---|
| 40 | 
 | 
|---|
| 41 | BZ_ARRAY_DECLARE_UOP(operator!, LogicalNot)
 | 
|---|
| 42 | BZ_ARRAY_DECLARE_UOP(operator~, BitwiseNot)
 | 
|---|
| 43 | BZ_ARRAY_DECLARE_UOP(operator-, Negate)
 | 
|---|
| 44 | 
 | 
|---|
| 45 | /*
 | 
|---|
| 46 |  * cast() functions, for explicit type casting
 | 
|---|
| 47 |  */
 | 
|---|
| 48 | 
 | 
|---|
| 49 | template<class T_numtype, int N_rank, class T_cast>
 | 
|---|
| 50 | inline                                                                 
 | 
|---|
| 51 | _bz_ArrayExpr<_bz_ArrayExprUnaryOp<ArrayIterator<T_numtype,N_rank>,   
 | 
|---|
| 52 |     Cast<T_numtype, T_cast> > >
 | 
|---|
| 53 | cast(const Array<T_numtype,N_rank>& array, T_cast)
 | 
|---|
| 54 | {                                                                      
 | 
|---|
| 55 |     return _bz_ArrayExprUnaryOp<ArrayIterator<T_numtype,N_rank>,      
 | 
|---|
| 56 |         Cast<T_numtype,T_cast> >(array.begin());                            
 | 
|---|
| 57 | }                                                                      
 | 
|---|
| 58 |                                                                        
 | 
|---|
| 59 | template<class T_expr, class T_cast>
 | 
|---|
| 60 | inline                                                                 
 | 
|---|
| 61 | _bz_ArrayExpr<_bz_ArrayExprUnaryOp<_bz_ArrayExpr<T_expr>,              
 | 
|---|
| 62 |     Cast<_bz_typename T_expr::T_numtype,T_cast> > >                          
 | 
|---|
| 63 | cast(_bz_ArrayExpr<T_expr> expr, T_cast)
 | 
|---|
| 64 | {                                                                      
 | 
|---|
| 65 |     return _bz_ArrayExprUnaryOp<_bz_ArrayExpr<T_expr>,                 
 | 
|---|
| 66 |         Cast<_bz_typename T_expr::T_numtype,T_cast> >(expr);                 
 | 
|---|
| 67 | }                                                                      
 | 
|---|
| 68 |                                                                        
 | 
|---|
| 69 | template<int N_index, class T_cast>
 | 
|---|
| 70 | inline                                                                 
 | 
|---|
| 71 | _bz_ArrayExpr<_bz_ArrayExprUnaryOp<IndexPlaceholder<N_index>,          
 | 
|---|
| 72 |     Cast<int,T_cast> > >                                                     
 | 
|---|
| 73 | cast(IndexPlaceholder<N_index> index, T_cast)
 | 
|---|
| 74 | {                                                                      
 | 
|---|
| 75 |     return _bz_ArrayExprUnaryOp<IndexPlaceholder<N_index>,             
 | 
|---|
| 76 |         Cast<int,T_cast> >(index);                                           
 | 
|---|
| 77 | }
 | 
|---|
| 78 | 
 | 
|---|
| 79 | BZ_NAMESPACE_END
 | 
|---|
| 80 | 
 | 
|---|
| 81 | #endif // BZ_ARRAYMISC_CC
 | 
|---|
| 82 | 
 | 
|---|