mirror of
https://github.com/paboyle/Grid.git
synced 2024-11-10 15:55:37 +00:00
Force inlining on ICPC because inline apparently is not enoguh
This commit is contained in:
parent
cbfa4097b4
commit
af6e8f7829
@ -14,14 +14,14 @@ namespace Grid {
|
|||||||
// Vector +/- Vector
|
// Vector +/- Vector
|
||||||
// Matrix +/- Matrix
|
// Matrix +/- Matrix
|
||||||
// Matrix /- scalar
|
// Matrix /- scalar
|
||||||
template<class vtype,class ltype,class rtype> inline void sub(iScalar<vtype> * __restrict__ ret,
|
template<class vtype,class ltype,class rtype> strong_inline void sub(iScalar<vtype> * __restrict__ ret,
|
||||||
const iScalar<ltype> * __restrict__ lhs,
|
const iScalar<ltype> * __restrict__ lhs,
|
||||||
const iScalar<rtype> * __restrict__ rhs)
|
const iScalar<rtype> * __restrict__ rhs)
|
||||||
{
|
{
|
||||||
sub(&ret->_internal,&lhs->_internal,&rhs->_internal);
|
sub(&ret->_internal,&lhs->_internal,&rhs->_internal);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class vtype,class ltype,class rtype,int N> inline void sub(iVector<vtype,N> * __restrict__ ret,
|
template<class vtype,class ltype,class rtype,int N> strong_inline void sub(iVector<vtype,N> * __restrict__ ret,
|
||||||
const iVector<ltype,N> * __restrict__ lhs,
|
const iVector<ltype,N> * __restrict__ lhs,
|
||||||
const iVector<rtype,N> * __restrict__ rhs)
|
const iVector<rtype,N> * __restrict__ rhs)
|
||||||
{
|
{
|
||||||
@ -30,7 +30,7 @@ template<class vtype,class ltype,class rtype,int N> inline void sub(iVector<vtyp
|
|||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
template<class vtype,class ltype,class rtype, int N> inline void sub(iMatrix<vtype,N> * __restrict__ ret,
|
template<class vtype,class ltype,class rtype, int N> strong_inline void sub(iMatrix<vtype,N> * __restrict__ ret,
|
||||||
const iMatrix<ltype,N> * __restrict__ lhs,
|
const iMatrix<ltype,N> * __restrict__ lhs,
|
||||||
const iMatrix<rtype,N> * __restrict__ rhs){
|
const iMatrix<rtype,N> * __restrict__ rhs){
|
||||||
for(int c2=0;c2<N;c2++){
|
for(int c2=0;c2<N;c2++){
|
||||||
@ -39,7 +39,7 @@ template<class vtype,class ltype,class rtype, int N> inline void sub(iMatrix<vty
|
|||||||
}}
|
}}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
template<class vtype,class ltype,class rtype, int N> inline void sub(iMatrix<vtype,N> * __restrict__ ret,
|
template<class vtype,class ltype,class rtype, int N> strong_inline void sub(iMatrix<vtype,N> * __restrict__ ret,
|
||||||
const iScalar<ltype> * __restrict__ lhs,
|
const iScalar<ltype> * __restrict__ lhs,
|
||||||
const iMatrix<rtype,N> * __restrict__ rhs){
|
const iMatrix<rtype,N> * __restrict__ rhs){
|
||||||
for(int c2=0;c2<N;c2++){
|
for(int c2=0;c2<N;c2++){
|
||||||
@ -55,7 +55,7 @@ template<class vtype,class ltype,class rtype, int N> inline void sub(iMatrix<vty
|
|||||||
}}
|
}}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
template<class vtype,class ltype,class rtype, int N> inline void sub(iMatrix<vtype,N> * __restrict__ ret,
|
template<class vtype,class ltype,class rtype, int N> strong_inline void sub(iMatrix<vtype,N> * __restrict__ ret,
|
||||||
const iMatrix<ltype,N> * __restrict__ lhs,
|
const iMatrix<ltype,N> * __restrict__ lhs,
|
||||||
const iScalar<rtype> * __restrict__ rhs){
|
const iScalar<rtype> * __restrict__ rhs){
|
||||||
for(int c2=0;c2<N;c2++){
|
for(int c2=0;c2<N;c2++){
|
||||||
@ -69,7 +69,7 @@ template<class vtype,class ltype,class rtype, int N> inline void sub(iMatrix<vty
|
|||||||
}
|
}
|
||||||
|
|
||||||
// - operator for scalar, vector, matrix
|
// - operator for scalar, vector, matrix
|
||||||
template<class ltype,class rtype> inline auto
|
template<class ltype,class rtype> strong_inline auto
|
||||||
operator - (const iScalar<ltype>& lhs, const iScalar<rtype>& rhs) -> iScalar<decltype(lhs._internal - rhs._internal)>
|
operator - (const iScalar<ltype>& lhs, const iScalar<rtype>& rhs) -> iScalar<decltype(lhs._internal - rhs._internal)>
|
||||||
{
|
{
|
||||||
typedef iScalar<decltype(lhs._internal-rhs._internal)> ret_t;
|
typedef iScalar<decltype(lhs._internal-rhs._internal)> ret_t;
|
||||||
@ -78,7 +78,7 @@ operator - (const iScalar<ltype>& lhs, const iScalar<rtype>& rhs) -> iScalar<dec
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
template<class ltype,class rtype,int N>
|
template<class ltype,class rtype,int N>
|
||||||
inline auto operator - (const iVector<ltype,N>& lhs,const iVector<rtype,N>& rhs) ->iVector<decltype(lhs._internal[0]-rhs._internal[0]),N>
|
strong_inline auto operator - (const iVector<ltype,N>& lhs,const iVector<rtype,N>& rhs) ->iVector<decltype(lhs._internal[0]-rhs._internal[0]),N>
|
||||||
{
|
{
|
||||||
typedef iVector<decltype(lhs._internal[0]-rhs._internal[0]),N> ret_t;
|
typedef iVector<decltype(lhs._internal[0]-rhs._internal[0]),N> ret_t;
|
||||||
ret_t ret;
|
ret_t ret;
|
||||||
@ -86,7 +86,7 @@ inline auto operator - (const iVector<ltype,N>& lhs,const iVector<rtype,N>& rhs)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
template<class ltype,class rtype,int N>
|
template<class ltype,class rtype,int N>
|
||||||
inline auto operator - (const iMatrix<ltype,N>& lhs,const iMatrix<rtype,N>& rhs) ->iMatrix<decltype(lhs._internal[0][0]-rhs._internal[0][0]),N>
|
strong_inline auto operator - (const iMatrix<ltype,N>& lhs,const iMatrix<rtype,N>& rhs) ->iMatrix<decltype(lhs._internal[0][0]-rhs._internal[0][0]),N>
|
||||||
{
|
{
|
||||||
typedef iMatrix<decltype(lhs._internal[0][0]-rhs._internal[0][0]),N> ret_t;
|
typedef iMatrix<decltype(lhs._internal[0][0]-rhs._internal[0][0]),N> ret_t;
|
||||||
ret_t ret;
|
ret_t ret;
|
||||||
@ -94,7 +94,7 @@ inline auto operator - (const iMatrix<ltype,N>& lhs,const iMatrix<rtype,N>& rhs)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
template<class ltype,class rtype,int N>
|
template<class ltype,class rtype,int N>
|
||||||
inline auto operator - (const iScalar<ltype>& lhs,const iMatrix<rtype,N>& rhs)->iMatrix<decltype(lhs._internal-rhs._internal[0][0]),N>
|
strong_inline auto operator - (const iScalar<ltype>& lhs,const iMatrix<rtype,N>& rhs)->iMatrix<decltype(lhs._internal-rhs._internal[0][0]),N>
|
||||||
{
|
{
|
||||||
typedef iMatrix<decltype(lhs._internal-rhs._internal[0][0]),N> ret_t;
|
typedef iMatrix<decltype(lhs._internal-rhs._internal[0][0]),N> ret_t;
|
||||||
ret_t ret;
|
ret_t ret;
|
||||||
@ -102,7 +102,7 @@ inline auto operator - (const iScalar<ltype>& lhs,const iMatrix<rtype,N>& rhs)->
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
template<class ltype,class rtype,int N>
|
template<class ltype,class rtype,int N>
|
||||||
inline auto operator - (const iMatrix<ltype,N>& lhs,const iScalar<rtype>& rhs)->iMatrix<decltype(lhs._internal[0][0]-rhs._internal),N>
|
strong_inline auto operator - (const iMatrix<ltype,N>& lhs,const iScalar<rtype>& rhs)->iMatrix<decltype(lhs._internal[0][0]-rhs._internal),N>
|
||||||
{
|
{
|
||||||
typedef iMatrix<decltype(lhs._internal[0][0]-rhs._internal),N> ret_t;
|
typedef iMatrix<decltype(lhs._internal[0][0]-rhs._internal),N> ret_t;
|
||||||
ret_t ret;
|
ret_t ret;
|
||||||
|
Loading…
Reference in New Issue
Block a user