7 static const int endLoop = (I < N-1) ? 1 : 0;
9 template<class V, class S, class EqOp>
10 static inline void eqOpS(V& vs, const S& s, EqOp eo)
13 VectorSpaceOps<endLoop*N, endLoop*(I+1)>::eqOpS(vs, s, eo);
16 template<class S, class V, class EqOp>
17 static inline void SeqOp(S& s, const V& vs, EqOp eo)
20 VectorSpaceOps<endLoop*N, endLoop*(I+1)>::SeqOp(s, vs, eo);
23 template<class V1, class V2, class EqOp>
24 static inline void eqOp(V1& vs1, const V2& vs2, EqOp eo)
26 eo(vs1.v_[I], vs2.v_[I]);
27 VectorSpaceOps<endLoop*N, endLoop*(I+1)>::eqOp(vs1, vs2, eo);
31 template<class V, class V1, class S, class Op>
32 static inline void opVS(V& vs, const V1& vs1, const S& s, Op o)
34 vs.v_[I] = o(vs1.v_[I], s);
35 VectorSpaceOps<endLoop*N, endLoop*(I+1)>::opVS(vs, vs1, s, o);
38 template<class V, class S, class V1, class Op>
39 static inline void opSV(V& vs, const S& s, const V1& vs1, Op o)
41 vs.v_[I] = o(s, vs1.v_[I]);
42 VectorSpaceOps<endLoop*N, endLoop*(I+1)>::opSV(vs, s, vs1, o);
45 template<class V, class V1, class Op>
46 static inline void op(V& vs, const V1& vs1, const V1& vs2, Op o)
48 vs.v_[I] = o(vs1.v_[I], vs2.v_[I]);
49 VectorSpaceOps<endLoop*N, endLoop*(I+1)>::op(vs, vs1, vs2, o);
52 template<class V, class V1, class V2, class Op>
53 static inline void opVV(V& vs, const V1& vs1, const V2& vs2, Op o)
55 vs.v_[I] = o(vs1.v_[I], vs2.v_[I]);
56 VectorSpaceOps<endLoop*N, endLoop*(I+1)>::opVV(vs, vs1, vs2, o);
59 template<class S, class V1, class V2, class EqOp, class Op>
60 static inline void SopEqOpVV(S& s, const V1& vs1, const V2& vs2, EqOp eo, Op o)
62 eo(s, o(vs1.v_[I], vs2.v_[I]));
63 VectorSpaceOps<endLoop*N, endLoop*(I+1)>::SopEqOpVV(s, vs1, vs2, eo, o);
69 class VectorSpaceOps<0, 0>
73 template<class V, class S, class EqOp>
74 static inline void eqOpS(V&, const S&, EqOp)
77 template<class S, class V, class EqOp>
78 static inline void SeqOp(S&, const V&, EqOp)
81 template<class V1, class V2, class EqOp>
82 static inline void eqOp(V1&, const V2&, EqOp)
86 template<class V, class V1, class S, class Op>
87 static inline void opVS(V& vs, const V1&, const S&, Op)
90 template<class V, class S, class V1, class Op>
91 static inline void opSV(V& vs, const S&, const V1&, Op)
94 template<class V, class V1, class Op>
95 static inline void op(V& vs, const V1&, const V1&, Op)
98 template<class V, class V1, class V2, class Op>
99 static inline void opVV(V& vs, const V1& vs1, const V2& vs2, Op o)
102 template<class S, class V1, class V2, class EqOp, class Op>
103 static inline void SopEqOpVV(S& s, const V1& vs1, const V2& vs2, EqOp eo, Op o)