| Defined in header
<numeric> | ||
|---|---|---|
template< class InputIt1, class InputIt2, class T >
T inner_product( InputIt1 first1, InputIt1 last1,
InputIt2 first2, T value );
| (1) | |
template< class ExecutionPolicy, class InputIt1, class InputIt2, class T >
T inner_product( ExecutionPolicy&& policy, InputIt1 first1, InputIt1 last1,
InputIt2 first2, T value );
| (2) | (since C++17) |
template<class InputIt1, class InputIt2, class T,
class BinaryOperation1, class BinaryOperation2>
T inner_product( InputIt1 first1, InputIt1 last1,
InputIt2 first2, T value,
BinaryOperation1 op1,
BinaryOperation2 op2 );
| (3) | |
template< class ExecutionPolicy,class InputIt1, class InputIt2, class T,
class BinaryOperation1, class BinaryOperation2>
T inner_product( ExecutionPolicy&& policy, InputIt1 first1, InputIt1 last1,
InputIt2 first2, T value,
BinaryOperation1 op1,
BinaryOperation2 op2 );
| (4) | (since C++17) |
Computes inner product (i.e. sum of products) of the range [first1, last1) and another range beginning at first2.
operator* and sums are calculated using operator+.op2 and sums are calculated using op1.policy. These overloads do not participate in overload resolution unless std::is_execution_policy_v<std::decay_t<ExecutionPolicy>> is true |
| (until C++11) |
|
| (since C++11) |
| first1, last1 | - | the first range of elements |
| first2 | - | the beginning of the second range of elements |
| value | - | initial value of the sum of the products |
| policy | - | the execution policy to use. See execution policy for details. |
| op1 | - | binary operation function object that will be applied. This "sum" function takes a value returned by op2 and the current value of the accumulator and produces a new value to be stored in the accumulator. The signature of the function should be equivalent to the following:
The signature does not need to have |
| op2 | - | binary operation function object that will be applied. This "product" function takes one value from each range and produces a new value. The signature of the function should be equivalent to the following:
The signature does not need to have |
| Type requirements | ||
-
InputIt1, InputIt2 must meet the requirements of InputIterator. |
||
-
T must meet the requirements of CopyAssignable and CopyConstructible. |
||
The inner product of two ranges.
The overloads with a template parameter named ExecutionPolicy report errors as follows:
std::terminate is called. std::bad_alloc is thrown. | First version |
|---|
template<class InputIt1, class InputIt2, class T>
T inner_product(InputIt1 first1, InputIt1 last1,
InputIt2 first2, T value)
{
while (first1 != last1) {
value = value + *first1 * *first2;
++first1;
++first2;
}
return value;
} |
| Second version |
template<class InputIt1, class InputIt2,
class T,
class BinaryOperation1, class BinaryOperation2>
T inner_product(InputIt1 first1, InputIt1 last1,
InputIt2 first2, T value,
BinaryOperation1 op1
BinaryOperation2 op2)
{
while (first1 != last1) {
value = op1(value, op2(*first1, *first2));
++first1;
++first2;
}
return value;
} |
#include <numeric>
#include <iostream>
#include <vector>
#include <functional>
int main()
{
std::vector<int> a{0, 1, 2, 3, 4};
std::vector<int> b{5, 4, 2, 3, 1};
int r1 = std::inner_product(a.begin(), a.end(), b.begin(), 0);
std::cout << "Inner product of a and b: " << r1 << '\n';
int r2 = std::inner_product(a.begin(), a.end(), b.begin(), 0,
std::plus<int>(), std::equal_to<int>());
std::cout << "Number of pairwise matches between a and b: " << r2 << '\n';
}Output:
Inner product of a and b: 21 Number of pairwise matches between a and b: 2
| sums up a range of elements (function template) |
|
| computes the partial sum of a range of elements (function template) |
|
| (parallelism TS)
| parallelized version of std::inner_product (function template) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
http://en.cppreference.com/w/cpp/algorithm/inner_product