// This program demonstrates how to perform parallel inclusive scan. #include #include int main(int argc, char* argv[]) { if(argc != 3) { std::cerr << "usage: ./inclusive_scan num_workers num_elements\n"; std::exit(EXIT_FAILURE); } size_t W = std::atoi(argv[1]); size_t N = std::atoi(argv[2]); tf::Executor executor(W); tf::Taskflow taskflow; std::vector elements(N), scan_seq(N), scan_par(N); for(size_t i=0; i(i); } // sequential inclusive scan { std::cout << "sequential inclusive scan ... "; auto beg = std::chrono::steady_clock::now(); std::inclusive_scan( elements.begin(), elements.end(), scan_seq.begin(), std::multiplies{} ); auto end = std::chrono::steady_clock::now(); std::cout << std::chrono::duration_cast(end-beg).count() << "ns\n"; } // create a parallel inclusive scan task { std::cout << "parallel inclusive scan ... "; auto beg = std::chrono::steady_clock::now(); taskflow.inclusive_scan( elements.begin(), elements.end(), scan_par.begin(), std::multiplies{} ); executor.run(taskflow).wait(); auto end = std::chrono::steady_clock::now(); std::cout << std::chrono::duration_cast(end-beg).count() << "ns\n"; } // verify the result for(size_t i=0; i