📄 vecdot.cc
字号:
/* * $Id: vecdot.cc,v 1.3 2003/12/11 03:44:22 julianc Exp $ * * Copyright (C) 1997 Todd Veldhuizen <tveldhui@oonumerics.org> * All rights reserved. Please see <blitz/blitz.h> for terms and * conditions of use. * */#ifndef BZ_VECDOT_CC#define BZ_VECDOT_CC#ifndef BZ_VECGLOBS_H #error <blitz/vecdot.cc> must be included via <blitz/vecglobs.h>#endifBZ_NAMESPACE(blitz)template<typename P1, typename P2>inlineBZ_SUMTYPE(BZ_PROMOTE(_bz_typename P1::T_numtype, _bz_typename P2::T_numtype))_bz_dot(P1 vector1, P2 vector2){ BZPRECONDITION(vector1._bz_suggestLength() == vector2._bz_suggestLength()); typedef BZ_SUMTYPE(BZ_PROMOTE(_bz_typename P1::T_numtype, _bz_typename P2::T_numtype)) T_sumtype; T_sumtype sum = 0; int length = vector1._bz_suggestLength(); if (vector1._bz_hasFastAccess() && vector2._bz_hasFastAccess()) { for (int i=0; i < length; ++i) sum += vector1._bz_fastAccess(i) * vector2._bz_fastAccess(i); } else { for (int i=0; i < length; ++i) sum += vector1[i] * vector2[i]; } return sum;}// dot()template<typename P_numtype1, typename P_numtype2>inlineBZ_SUMTYPE(BZ_PROMOTE(P_numtype1,P_numtype2))dot(const Vector<P_numtype1>& a, const Vector<P_numtype2>& b){ return _bz_dot(a, b);}// dot(expr,expr)template<typename P_expr1, typename P_expr2>inlineBZ_SUMTYPE(BZ_PROMOTE(_bz_typename P_expr1::T_numtype, _bz_typename P_expr2::T_numtype))dot(_bz_VecExpr<P_expr1> expr1, _bz_VecExpr<P_expr2> expr2){ return _bz_dot(expr1, expr2);}// dot(expr,vec)template<typename P_expr1, typename P_numtype2>inlineBZ_SUMTYPE(BZ_PROMOTE(_bz_typename P_expr1::T_numtype, P_numtype2))dot(_bz_VecExpr<P_expr1> expr1, const Vector<P_numtype2>& vector2){ return _bz_dot(vector2, expr1);}// dot(vec,expr)template<typename P_numtype1, typename P_expr2>inlineBZ_SUMTYPE(BZ_PROMOTE(P_numtype1, _bz_typename P_expr2::T_numtype))dot(const Vector<P_numtype1>& vector1, _bz_VecExpr<P_expr2> expr2){ return _bz_dot(vector1, expr2);}// dot(vec,vecpick)template<typename P_numtype1, typename P_numtype2>inlineBZ_SUMTYPE(BZ_PROMOTE(P_numtype1, P_numtype2))dot(const Vector<P_numtype1>& vector1, const VectorPick<P_numtype2>& vector2){ return _bz_dot(vector1, vector2);}// dot(vecpick,vec)template<typename P_numtype1, typename P_numtype2>inlineBZ_SUMTYPE(BZ_PROMOTE(P_numtype1, P_numtype2))dot(const VectorPick<P_numtype1>& vector1, const Vector<P_numtype2>& vector2){ return _bz_dot(vector1, vector2);}// dot(vecpick,vecpick)template<typename P_numtype1, typename P_numtype2>inlineBZ_SUMTYPE(BZ_PROMOTE(P_numtype1, P_numtype2))dot(const VectorPick<P_numtype1>& vector1, const VectorPick<P_numtype2>& vector2){ return _bz_dot(vector1, vector2);}// dot(expr, vecpick)template<typename P_expr1, typename P_numtype2>inlineBZ_SUMTYPE(BZ_PROMOTE(_bz_typename P_expr1::T_numtype, P_numtype2))dot(_bz_VecExpr<P_expr1> expr1, const VectorPick<P_numtype2>& vector2){ return _bz_dot(expr1, vector2);}// dot(vecpick, expr)template<typename P_numtype1, typename P_expr2>inlineBZ_SUMTYPE(BZ_PROMOTE(P_numtype1, _bz_typename P_expr2::T_numtype))dot(const VectorPick<P_numtype1>& vector1, _bz_VecExpr<P_expr2> expr2){ return _bz_dot(vector1, expr2);}BZ_NAMESPACE_END#endif // BZ_VECDOT_CC
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -