#include <eve/module/core.hpp>
#include <iostream>
int main()
{
eve::wide wf0{0.0, 1.0, 2.0, 3.0, -1.0, -2.0, -3.0, -4.0};
eve::wide wf1{0.0, -4.0, 1.0, -1.0, 2.0, -2.0, 3.0, -3.0};
eve::wide wu0{0u, 1u, 2u, 3u, 4u, 5u, 6u, 7u};
eve::wide wu1{7u, 6u, 5u, 4u, 3u, 2u, 1u, 0u};
std::cout << "<- wf0 = " << wf0 << "\n";
std::cout << "<- wf1 = " << wf1 << "\n";
std::cout << "<- wi0 = " << wi0 << "\n";
std::cout << "<- wi1 = " << wi1 << "\n";
std::cout << "<- wu0 = " << wu0 << "\n";
std::cout << "<- wu1 = " << wu1 << "\n";
std::cout <<
"-> dot(wf0, wf1) = " <<
eve::dot(wf0, wf1) <<
"\n";
std::cout <<
"-> dot(wu0, wu1) = " <<
eve::dot(wu0, wu1) <<
"\n";
std::cout <<
"-> dot(wi0, wi1) = " <<
eve::dot(wi0, wi1) <<
"\n";
std::cout <<
"-> dot(wf0, wf1, wf0, wf1) = "<<
eve::dot(wf0, wf1, wf0, wf1) <<
"\n";
std::cout <<
"-> dot[kahan](wf0, wf1, wf0, wf1) = "<<
eve::dot[eve::kahan](wf0, wf1, wf0, wf1) <<
"\n";
std::cout <<
"-> dot[widen](wf0, wf1, wf0, wf1) = "<<
eve::dot[eve::widen](wf0, wf1, wf0, wf1) <<
"\n";
auto vwf0= kumi::tuple{wf0, 2*wf0, 3*wf0};
auto vwf1= kumi::tuple{wf1, 2*wf1, 3*wf1};
std::cout <<
"-> dot(vwf0, vwf1) = " <<
eve::dot(vwf0, vwf1) <<
"\n";
std::cout <<
"-> dot[widen](vwf0, vwf1) = " <<
eve::dot[eve::widen](vwf0, vwf1) <<
"\n";
std::cout <<
"-> dot[kahan](vwf0, vwf1) = " <<
eve::dot[eve::kahan](vwf0, vwf1) <<
"\n";
}
Wrapper for SIMD registers.
Definition wide.hpp:94