Pure Python. Easily parallelize Python code.
Parsl provides an intuitive, pythonic way of parallelizing codes by annotating "apps": Python functions or external applications that run concurrently. Natural parallel programming!
data:image/s3,"s3://crabby-images/a088a/a088ad1d6bdbe8d2a2058bc7a8634e74939c38b9" alt=""
Implicit dataflow. Apps execute concurrently while respecting data dependencies.
Parsl creates a dynamic graph of tasks and their data dependencies. Tasks are only executed when their dependencies are met.
data:image/s3,"s3://crabby-images/58f16/58f167ff4263c4bc29b2455f17f1a8b29e3f0770" alt=""
Scalable Jupyter notebooks. Easily manage execution across distributed resources.
Parsl works seamlessly with Jupyter notebooks allowing apps within a notebook to be executed in parallel and on remote resources.
data:image/s3,"s3://crabby-images/c6670/c6670a6e2f501451a86cce7bfe9aed676bb05dd4" alt=""
Write once, run anywhere. From laptops to supercomputers.
Parsl scripts are independent of the execution environment. A single script can be executed on one or more execution resources without modifying the script.
data:image/s3,"s3://crabby-images/7fe2b/7fe2b14d7bfa895f79d95815ddc8c8a94cf59153" alt=""