Collection of Concrete Vector Reduction/Transformation Operator Implementations  Version of the Day
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Groups Pages
RTOpPack_TOpEleWiseProd.hpp
1 // @HEADER
2 // *****************************************************************************
3 // RTOp: Interfaces and Support Software for Vector Reduction Transformation
4 // Operations
5 //
6 // Copyright 2006 NTESS and the RTOp contributors.
7 // SPDX-License-Identifier: BSD-3-Clause
8 // *****************************************************************************
9 // @HEADER
10 
11 #ifndef RTOPPACK_TOP_ELE_WISE_PROD_HPP
12 #define RTOPPACK_TOP_ELE_WISE_PROD_HPP
13 
14 #include "RTOpPack_RTOpTHelpers.hpp"
15 
16 
17 namespace RTOpPack {
18 
19 
21 template<class Scalar>
23 {
24 public:
25  TOpEleWiseProdEleWiseTransformation( const Scalar &alpha )
26  : alpha_(alpha)
27  {}
28  void operator()( const Scalar &v0, const Scalar &v1, Scalar &z0 ) const
29  {
30  z0 += alpha_ * v0 * v1;
31  }
32 private:
33  Scalar alpha_;
34 };
35 
36 
40 template<class Scalar>
42  : public TOp_2_1_Base<Scalar, TOpEleWiseProdEleWiseTransformation<Scalar> >
43 {
44 public:
47  TOpEleWiseProd( const Scalar &alpha )
49  {
50  this->setOpNameBase("TOpEleWiseProd");
51  }
52 };
53 
54 
55 } // namespace RTOpPack
56 
57 
58 #endif // RTOPPACK_TOP_ELE_WISE_PROD_HPP
Element-wise transformation operator for TOpEleWiseProd.
Element-wise product transformation operator: z0[i] += alpha*v0[i]*v1[i], i=0...n-1.
TOpEleWiseProd(const Scalar &alpha)
void setOpNameBase(const std::string &op_name_base)