Skip to Content
C++ High Performance
book

C++ High Performance

by Viktor Sehr, Björn Andrist
January 2018
Intermediate to advanced
374 pages
9h 53m
English
Packt Publishing
Content preview from C++ High Performance

Implementation

Implementation-wise, it's quite a small bit of code. The incoming range is recursively split into two chunks; the first chunk is recursively invoked as a new task, and the second chunk is processed on the same task:

template <typename SrcIt, typename DstIt, typename Func> 
auto par_transform(SrcIt first,SrcIt last,DstIt dst,Func f,size_t chunk_sz) { 
  const auto n = static_cast<size_t>(std::distance(first, last));  if (n <= chunk_sz) { 
    std::transform(first, last, dst, f); 
    return; 
  } 
  const auto src_middle = std::next(first, n/2); 
  // Branch of first part to another task 
  auto future = std::async([=, &func]{ 
    par_transform(first, src_middle, dst, f, chunk_sz); 
  }); 
  // Recursively handle the second part const auto dst_middle = std::next(dst, ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Start your free trial

You might also like

C++ High Performance - Second Edition

C++ High Performance - Second Edition

Björn Andrist, Viktor Sehr
Advanced C++

Advanced C++

Gazihan Alankus, Olena Lizina, Rakesh Mane, Vivek Nagarajan, Brian Price
C++ In a Nutshell

C++ In a Nutshell

Ray Lischner
C++ Cookbook

C++ Cookbook

D. Ryan Stephens, Christopher Diggins, Jonathan Turkanis, Jeff Cogswell

Publisher Resources

ISBN: 9781787120952Supplemental Content