Skip to content

Automatized python pipelines to run reproducible experiments.

License

Notifications You must be signed in to change notification settings

TheoGuyard/ExpRun

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ExpRun

Python 3.9+ PyPI version codecov Test Status License

Automatized python pipelines to run reproducible experiments.

Installation

exprun is available on pypi. The latest version of the package can be installed as

pip install exprun

Quick start

With exprun, an experiment is run using an instance of the Runner class, based on a yaml configuration file, with a specified results directory, save directory, and number of repeats. The user is only required to fill the four methods in inherited from the Experiment class.

Here is a simple example of experiment that computes the sum of two random numbers drawn uniformly over a specified range. The configuration file is as follows.

# file: config.yml

min: 1
max: 10

The experiment can then be created is as follows.

# file: myexperiment.py

from exprun import Experiment, Runner

class MyExperiment(Experiment):
    def setup(self) -> None:
        # Set up the experiment from the information in the configuration file.
        ...

    def run(self) -> dict:
        # Perform one run of the experiment and return the results as a dict.
        ...

    def cleanup(self) -> None:
         # Clean up the experimental data.
        ...

    def plot(self, results: list) -> dict:
         # Process the results obtained and returns the plot data that must be saved.
        ...

config_path = './config.yml'
result_dir = './results/'
save_dir = './saves/'

runner = Runner()
runner.run(MyExperiment, config_path, result_dir, repeats=10)
runner.plot(MyExperiment, config_path, result_dir, save_dir)

Launching python myexperiment.py runs 10 times MyExperiment, each result is saved at result_dir and the plot data is saved as a pickle file. Then, the results found in the result_dir that match the current configuration are recovered, plotted, and saved at save_dir as a pickle file. And as simple as that, you have a reproducible experiment that can be run multiple times with different configurations. More advanced examples can be found in the examples directory.

Contribute

exprun is still in its early stages of development. Feel free to contribute by reporting any bugs on the issue page or by opening a pull request. Any feedback or contribution is welcome.

License

exprun is distributed under the MIT license.

About

Automatized python pipelines to run reproducible experiments.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages