⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 vecdot.cc

📁 A C++ class library for scientific computing
💻 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 + -