Code Monkey home page Code Monkey logo

aiida-fireworks-scheduler's Introduction

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

[email protected]

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.