Skip to main content

AiiDA plugin to allow using `fireworks` as the execution engine for `CalcJob`.

Project description

Build Status Coverage Status Docs status PyPI version

aiida-fireworks-scheduler

AiiDA plugin for using fireworks as the execution engine for CalcJobProcess.

The main advantage of using the FwScheduler, as provided in this plugin, compared to the standard AiiDA scheduler plugins is that it allows more flexible job placement. For example, your may be forced to submit very large jobs to the cluster (or simply such jobs goes through the queue faster!), or that the cluster has a strict limit on the number of jobs that can be in the queue. Using FwScheduler, a single allocation of the resources from the scheduler (SGE, PBSpro, SLURM etc.) can be used to run multiple AiiDA CalcJobs in serial or in parallel, depending on the user configuration. In addition, AiiDA jobs can be run along side other workflows in fireworks.

Repository contents

Features

  • FWScheduler scheduler plugin to submit jobs to LaunchPad managed by fireworks.

  • arlaunch command for launching jobs on the cluster machine.

  • verdi data fireworks-scheduler command line tool for duplicating existing Computer/Cold for switching to FwScheduler.

Installation

On the local machine where AiiDA is installed:

pip install aiida-fireworks-scheduler[local]

On the remote machine where jobs to be launched:

pip install aiida-fireworks-scheduler

Usage

Simply create a new computer using verdi computer setup and select the fw scheduler. Configure your fireworks configuration following the guide here.

Note that you must configure the LAUNCHPAD_LOC setting in the file as defined by the FW_CONFIG_FILE environment variable to point to your my_launchpad.yaml file on BOTH the local and remote machines. On the local machine, it will be picked up by the daemon.

In addition, on the remote machine, setup your my_fworker.yaml with special directives for identifying the computer and username. These files can be generated using:

verdi data fireworks-scheduler generate-worker -Y COMPUTER -mpinp NUM_MPI_PROCESSORS

Note that each *worker" can only launch jobs of a particular size (number of MPI processors). But you can always combine multiple workers in one or more cluster jobs.

At runtime, jobs needs to be launched with the arlaunch command on the remote machine.

Adding walltime selectors for standard fireworks jobs

Standard fireworks jobs can also be selected based on the requested walltime using arlaunch. If a job has spec._walltime_seconds key, it will only be selected to run if there is sufficient time left. However, unlike AiiDA jobs, this walltime limit is not enforced, and the launch can proceed even if the requested seconds have elapsed.

Development

git clone https://github.com/zhubonan/aiida-fireworks-scheduler .
cd aiida-fireworks-scheduler
pip install -e .[pre-commit,testing]  # install extra dependencies
pre-commit install  # install pre-commit hooks
pytest -v  # discover and run all tests

See the developer guide for more information.

License

MIT

Contact

zhubonan@outlook.com

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aiida-fireworks-scheduler-1.0.0.tar.gz (18.6 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page