◆ shift_right()

Value boost::simd::shift_right ( Value const &  x,
IntegerValue const &  n 
)

This function object returns the first operand shifted right by the second one.

Infix notation can be used with operator '>>'

Header <boost/simd/function/shift_right.hpp>
See also
shift_left, shr, rshl, rshr, rol, ror
Precondition
the second parameter must be of integer type, scalar or of the same number of elements as the first parameter
Note:
  • on many architectures a scalar second parameter results in a much faster call
Example:
#include <boost/simd/bitwise.hpp>
#include <boost/simd/pack.hpp>
#include <iostream>
namespace bs = boost::simd;
using iT = std::int32_t;
using pack_it = bs::pack<iT, 4>;
int main() {
pack_it pi = {1, 2, -1, 3};
pack_it qi = {1, 2, 4, 3};
std::cout << "---- simd" << '\n'
<< "<- pi = " << pi << '\n'
<< "<- qi = " << qi << '\n'
<< "-> bs::shift_right(pi, qi) = " << bs::shift_right(pi, qi)
<< '\n';
iT xi = 2, yi = 3;
std::cout << "---- scalar" << '\n'
<< "<- xi = " << xi << '\n'
<< "<- yi = " << yi << '\n'
<< "-> bs::shift_right(xi, yi) = " << bs::shift_right(xi, yi)
<< '\n';
return 0;
}
Possible output:
---- simd
<- pi = (1, 2, -1, 3)
<- qi = (1, 2, 4, 3)
-> bs::shift_right(pi, qi) = (0, 0, -1, 0)
---- scalar
<- xi = 2
<- yi = 3
-> bs::shift_right(xi, yi) = 0