Taskflow 3.2.0 is the 3rd release in the 3.x line! This release includes several new changes such as CPU-GPU tasking, algorithm collection, enhanced web-based profiler, documentation, and unit tests.
Download
Taskflow 3.2.0 can be downloaded from here.
System Requirements
To use Taskflow v3.2.0, you need a compiler that supports C++17:
- GNU C++ Compiler at least v8.4 with -std=c++17
- Clang C++ Compiler at least v6.0 with -std=c++17
- Microsoft Visual Studio at least v19.27 with /std:c++17
- AppleClang Xode Version at least v12.0 with -std=c++17
- Nvidia CUDA Toolkit and Compiler (nvcc) at least v11.1 with -std=c++17
- Intel C++ Compiler at least v19.0.1 with -std=c++17
- Intel DPC++ Clang Compiler at least v13.0.0 with -std=c++17 and SYCL20
Taskflow works on Linux, Windows, and Mac OS X.
Working Items
- enhancing support for SYCL with Intel DPC++
- enhancing parallel CPU and GPU algorithms
- designing pipeline interface and its scheduling algorithms
New Features
Taskflow Core
- added tf::SmallVector optimization for optimizing the dependency storage in a graph
- added move constructor and move assignment operator for tf::Taskflow
- added moved run in tf::Executor for automatically managing taskflow's lifetimes
cudaFlow
New algorithms in tf::cudaFlow and tf::cudaFlowCapturer:
syclFlow
CUDA Standard Parallel Algorithms
Utilities
- added CUDA meta programming
- added SYCL meta programming
Taskflow Profiler (TFProf)
Bug Fixes
Breaking Changes
There are no breaking changes in this release.
Deprecated and Removed Items
- removed tf::cudaFlow::kernel_on method
- removed explicit partitions in parallel iterations and reductions
- removed tf::cudaFlowCapturerBase
- removed tf::cublasFlowCapturer
- renamed update and rebind methods in tf::cudaFlow and tf::cudaFlowCapturer to overloads
Documentation
Miscellaneous Items
We have published tf::cudaFlow in the following conference:
- Dian-Lun Lin and Tsung-Wei Huang, "Efficient GPU Computation using Task Graph Parallelism," European Conference on Parallel and Distributed Computing (EuroPar), 2021