libpnicore
div_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  template<typename ATYPE> class array_view;
33 
41  template<
42  typename OP1T,
43  typename OP2T
44  >
45  class div_op
46  {
47  private:
52  public:
53  //--------------------public types---------------------------------
55  typedef typename OP1T::value_type value_type;
59  typedef void storage_type;
75 
76  //===================constructors==================================
83  div_op(const OP1T &o1,const OP2T &o2):
84  _op1(o1),
85  _op2(o2)
86  {}
87 
88  //====================public methods===============================
97  value_type operator[](size_t i) const
98  {
99  return this->_op1[i]/this->_op2[i];
100  }
101 
102  //-----------------------------------------------------------------
112  value_type at(size_t i) const
113  {
114  if(i>=size())
115  throw index_error(EXCEPTION_RECORD,"index exceeds size");
116 
117  return (*this)[i];
118  }
119 
120  //-----------------------------------------------------------------
128  size_t size() const
129  {
130  return _op1.size() > _op2.size() ? _op1.size() : _op2.size();
131  }
132 
133  //=====================iterators===================================
135  const_iterator begin() const
136  {
137  return const_iterator(this,0);
138  }
139 
140  //-----------------------------------------------------------------
142  const_iterator end() const
143  {
144  return const_iterator(this,this->size());
145  }
146  };
147 
148 //end of namespace
149 }
150 }
container_iterator< const array_type > const_reverse_iterator
const reverse iterator type
Definition: div_op.hpp:67
value_type operator[](size_t i) const
return result at i
Definition: div_op.hpp:97
const_iterator begin() const
get const iterator to first element
Definition: div_op.hpp:135
array_view< array_type > view_type
view type
Definition: div_op.hpp:69
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
iterator type
Definition: container_iterator.hpp:59
const_iterator end() const
get const iterator to last+1 element
Definition: div_op.hpp:142
OP1::map_type map_type
index map type
Definition: op_traits.hpp:86
value_type at(size_t i) const
return value at i
Definition: div_op.hpp:112
index error
Definition: exceptions.hpp:437
Definition: add_op.hpp:29
container_iterator< const array_type > const_iterator
const iterator type
Definition: div_op.hpp:63
array_trait< OP1T, OP2T >::inplace_arithmetic inplace_arithmetic
inplace arithmetic type
Definition: div_op.hpp:74
container_iterator< array_type > iterator
non-const iterator - just for interface
Definition: div_op.hpp:61
Division expression template.
Definition: div_op.hpp:45
op_trait< OP1T >::ref_type _op1
reference to the left operand
Definition: div_op.hpp:49
container_iterator< array_type > reverse_iterator
reverse iterator type
Definition: div_op.hpp:65
array_trait< OP1T, OP2T >::map_type map_type
index map type
Definition: div_op.hpp:71
div_op< OP1T, OP2T > array_type
type of the expression template
Definition: div_op.hpp:57
size_t size() const
get size
Definition: div_op.hpp:128
OP1T::value_type value_type
result type of the operation
Definition: div_op.hpp:55
div_op(const OP1T &o1, const OP2T &o2)
constructor
Definition: div_op.hpp:83
void storage_type
storage type
Definition: div_op.hpp:59
op_trait< OP2T >::ref_type _op2
reference to the right operand
Definition: div_op.hpp:51
operator reference trait
Definition: op_traits.hpp:43
provides a view on a part of an array
Definition: add_op.hpp:32