libpnicore
mult_op.hpp
1 //
2 // (c) Copyright 2011 DESY, Eugen Wintersberger <eugen.wintersberger@desy.de>
3 //
4 // This file is part of libpnicore.
5 //
6 // libpnicore is free software: you can redistribute it and/or modify
7 // it under the terms of the GNU General Public License as published by
8 // the Free Software Foundation, either version 2 of the License, or
9 // (at your option) any later version.
10 //
11 // libpnicore is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
15 //
16 // You should have received a copy of the GNU General Public License
17 // along with libpnicore. If not, see <http://www.gnu.org/licenses/>.
18 //
19 // ============================================================================
20 //
21 // Created on: Jul 25,2012
22 // Author: Eugen Wintersberger <eugen.wintersberger@desy.de>
23 //
24 #pragma once
25 
26 #include "op_traits.hpp"
27 #include "../../utilities/container_iterator.hpp"
28 
29 namespace pni{
30 namespace core{
31 
32 
33  template<typename ATYPE> class array_view;
34 
42  template<
43  typename OP1T,
44  typename OP2T
45  >
46  class mult_op
47  {
48  private:
53  public:
54  //--------------------public types---------------------------------
56  typedef typename OP1T::value_type value_type;
60  typedef void storage_type;
71 
77 
78  //===================constructors==================================
86  mult_op(const OP1T &o1,const OP2T &o2):
87  _op1(o1),
88  _op2(o2)
89  {}
90 
91  //====================public methods===============================
99  value_type operator[](size_t i) const
100  {
101  return this->_op1[i]*this->_op2[i];
102  }
103 
104  //-----------------------------------------------------------------
114  value_type at(size_t i) const
115  {
116  if(i>=size())
117  throw index_error(EXCEPTION_RECORD,"index exceeds size!");
118 
119  return (*this)[i];
120  }
121 
122  //-----------------------------------------------------------------
129  size_t size() const
130  {
131  return _op1.size() > _op2.size() ? _op1.size() : _op2.size();
132  }
133 
134 
135  //=====================iterators===================================
139  const_iterator begin() const
140  {
141  return const_iterator(this,0);
142  }
143 
144  //-----------------------------------------------------------------
148  const_iterator end() const
149  {
150  return const_iterator(this,this->size());
151  }
152  };
153 //end of namespace
154 }
155 }
array_view< array_type > view_type
view type
Definition: mult_op.hpp:70
const_iterator begin() const
get iterator on first element
Definition: mult_op.hpp:139
OP1T::value_type value_type
value type of the multiplication
Definition: mult_op.hpp:56
container_iterator< const array_type > const_iterator
const iterator type
Definition: mult_op.hpp:64
OP1::inplace_arithmetic inplace_arithmetic
inplace arithmetic type
Definition: op_traits.hpp:88
#define EXCEPTION_RECORD
macro creating an instance of ExceptionRecord
Definition: exceptions.hpp:48
container_iterator< array_type > reverse_iterator
reverse iterator type
Definition: mult_op.hpp:66
mult_op(const OP1T &o1, const OP2T &o2)
constructor
Definition: mult_op.hpp:86
size_t size() const
return size of the operator
Definition: mult_op.hpp:129
value_type operator[](size_t i) const
get value at index i
Definition: mult_op.hpp:99
void storage_type
storage type
Definition: mult_op.hpp:60
array_trait< OP1T, OP2T >::inplace_arithmetic inplace_arithmetic
inplace arithmetic type
Definition: mult_op.hpp:76
iterator type
Definition: container_iterator.hpp:59
OP1::map_type map_type
index map type
Definition: op_traits.hpp:86
const_iterator end() const
get iterator on last+1 element
Definition: mult_op.hpp:148
value_type at(size_t i) const
get value at index i
Definition: mult_op.hpp:114
index error
Definition: exceptions.hpp:437
array_trait< OP1T, OP2T >::map_type map_type
index map type
Definition: mult_op.hpp:73
Definition: add_op.hpp:29
op_trait< OP1T >::ref_type _op1
left operand
Definition: mult_op.hpp:50
container_iterator< const array_type > const_reverse_iterator
const reverse iterator type
Definition: mult_op.hpp:68
container_iterator< array_type > iterator
non-const iterator type - this is only to satsify the interaface
Definition: mult_op.hpp:62
op_trait< OP2T >::ref_type _op2
right operand
Definition: mult_op.hpp:52
Multiplication expression template.
Definition: mult_op.hpp:46
operator reference trait
Definition: op_traits.hpp:43
mult_op< OP1T, OP2T > array_type
type of the operation class
Definition: mult_op.hpp:58
provides a view on a part of an array
Definition: add_op.hpp:32