Skip to main content

REProducible Experimental environment.

Project description

fret

PyPI Travis (.org) Coveralls github

Framework for Reproducible ExperimenTs

Installation

From pip:

pip install fret

From source: clone the repository and then run: python setup.py install.

Tutorial

Basic Usage

Create a file named app.py with content:

import fret

@fret.command
def run(ws):
    model = ws.build()
    print(model)

@fret.configurable
class Model:
    def __init__(self, x=3, y=4):
        ...

Then under the same directory, you can run:

$ fret config Model
[ws/_default] configured "main" as "Model" with: x=3, y=4
$ fret run
Model(x=3, y=4)
$ fret config Model -x 5 -y 10
[ws/_default] configured "main" as "Model" with: x=5, y=10
$ fret run
Model(x=5, y=10)

Using Workspace

You can specify different configuration in different workspace:

$ fret -w ws/model1 config Model
[ws/model1] configured "main" as "Model" with: x=3, y=4
$ fret -w ws/model2 config Model -x 5 -y 10
[ws/model2] configured "main" as "Model" with: x=5, y=10
$ fret -w ws/model1 run
Model(x=3, y=4)
$ fret -w ws/model2 run
Model(x=5, y=10)

You can ommit -w <path> if you are currently under a workspace:

$ cd ws/model2
$ fret run
Model(x=5, y=10)

An Advanced Workflow

In app.py:

import time
import fret

@fret.configurable
@fret.stateful(['value'])
class Model:
    def __init__(self):
        self.value = 0

@fret.command
def resumable(ws):
    model = ws.build()
    with ws.run('exp-1') as run:
        run.register(model)
        cnt = run.acc()
        for e in fret.nonbreak(run.range(5)):
            # with `nonbreak`, the program always finish this loop before exit
            model.value += e
            time.sleep(0.2)
            cnt += 1
            print('current epoch: %d, sum: %d, cnt: %d' %
                  (e, model.value, cnt))

Then you can stop and restart this program anytime, with consistent results:

$ fret resumable
current epoch: 0, sum: 0, cnt: 1
current epoch: 1, sum: 1, cnt: 2
^CW SIGINT received. Delaying KeyboardInterrupt.
current epoch: 2, sum: 3, cnt: 3
Traceback (most recent call last):
    ...
KeyboardInterrupt
W cancelled by user
$ fret resumable
current epoch: 3, sum: 6, cnt: 4
current epoch: 4, sum: 10, cnt: 5

Submodule

@fret.configurable
class A:
    def __init__(self, foo='bar'):
        ...

@fret.configurable(submodules=['a'])
class B:
    def __init__(self, a, bar=3):
        ...
$ fret config a A -foo test
[ws/_default] configured "a" as "A" with: foo='test'
$ fret config B
[ws/_default] configured "main" as "B" with: a='a', bar=3
$ fret run
B(A(foo='test'), bar=4)

Inheritance

@fret.configurable
class A:
    def __init__(self, foo='bar', sth=3):
        ...

@fret.configurable
class B(A):
    def __init__(self, bar=3, **others):
        super().__init__(**others)
        ...
$ fret config B -foo baz -bar 0
[ws/_default] configured "main" as "B" with: bar=0, foo='baz', sth=3
$ fret run
B(bar=0, foo='baz', sth=3)

Internals

>>> config = fret.Configuration({'foo': 'bar'})
>>> config
foo='bar'

TODO

  • fret.Configuration: high-level class for configuration
  • fret.Workspace: module build/save/load (by tag or by path), persistency
  • ws.run() context manager, run.value(), run.acc(), run.range(), run.register()
  • @fret.configurable: parameter checking
  • fret.App, global app object
  • CLI: entry point logic, testing, tagged workspace
  • Java/GNU style command line args, shorthands, better logic for boolean default value
  • Global configuration file: fret.toml
  • Documents and examples
  • fret new command with interactive CLI
  • Other fret commands like show log, check module, etc.

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

fret-0.2.0b2.tar.gz (13.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fret-0.2.0b2-py2-none-any.whl (14.7 kB view details)

Uploaded Python 2

File details

Details for the file fret-0.2.0b2.tar.gz.

File metadata

  • Download URL: fret-0.2.0b2.tar.gz
  • Upload date:
  • Size: 13.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.19.1 setuptools/39.1.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.5

File hashes

Hashes for fret-0.2.0b2.tar.gz
Algorithm Hash digest
SHA256 4fa6c17d525103d6b86d4091bd8a8e3b6462487ce1b735d3362114c8e9f023e3
MD5 7250299837da015bc9e87805687b177d
BLAKE2b-256 60cbaf2a82eb4977677f14c1fa73a73e6aee0ee237497e7c336b8a92410897bd

See more details on using hashes here.

File details

Details for the file fret-0.2.0b2-py2-none-any.whl.

File metadata

  • Download URL: fret-0.2.0b2-py2-none-any.whl
  • Upload date:
  • Size: 14.7 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.19.1 setuptools/39.1.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.5

File hashes

Hashes for fret-0.2.0b2-py2-none-any.whl
Algorithm Hash digest
SHA256 f0f9ac5826666b8ba7bcea813ae5b7ed798c1e7b2648611adc6132a0082a5d03
MD5 c9dc721719bf873096b5a0b1a89ede4b
BLAKE2b-256 056dd2697d34efec8b6748fc10d24756f409b353b8b17520e57b8c0a28cccb90

See more details on using hashes here.

Supported by

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