All Projects → expfactory → expfactory

expfactory / expfactory

Licence: BSD-3-Clause license
software to generate a reproducible container with a battery of experiments

Programming Languages

python
139335 projects - #7 most used programming language
HTML
75241 projects
TeX
3793 projects
shell
77523 projects
CSS
56736 projects
javascript
184084 projects - #8 most used programming language

Projects that are alternatives of or similar to expfactory

Singularity
Singularity: Application containers for Linux
Stars: ✭ 2,290 (+7796.55%)
Mutual labels:  reproducible, container, singularity
Neuropsydia.py
A Python Module for Creating Experiments, Tasks and Questionnaires.
Stars: ✭ 51 (+75.86%)
Mutual labels:  psychology, experiments
programmingforpsych
A textbook for programming techniques for experiment creation and data-analysis
Stars: ✭ 18 (-37.93%)
Mutual labels:  psychology, experiments
scif
scientific filesystem: a filesystem organization for scientific software and metadata
Stars: ✭ 30 (+3.45%)
Mutual labels:  container, singularity
github-ci
An example GitHub Action (CI) to build a Singularity container
Stars: ✭ 46 (+58.62%)
Mutual labels:  container, singularity
dicom-containers
singularity and Docker containers to easily get started with common dicom tools
Stars: ✭ 18 (-37.93%)
Mutual labels:  container, singularity
docker-tor
TOR Server Docker image
Stars: ✭ 32 (+10.34%)
Mutual labels:  container
chubbyphp-container
A minimal Dependency Injection Container (DIC) which implements PSR-11.
Stars: ✭ 14 (-51.72%)
Mutual labels:  container
container-security-book
container-security.dev/
Stars: ✭ 123 (+324.14%)
Mutual labels:  container
ubuntu-vnc-xfce-chromium
Retired. Headless Ubuntu/Xfce container with VNC/noVNC and Chromium (Generation 1)
Stars: ✭ 20 (-31.03%)
Mutual labels:  container
ibm-spectrum-scale-csi
The IBM Spectrum Scale Container Storage Interface (CSI) project enables container orchestrators, such as Kubernetes and OpenShift, to manage the life-cycle of persistent storage.
Stars: ✭ 41 (+41.38%)
Mutual labels:  container
iMOKA
interactive Multi Objective K-mer Analysis
Stars: ✭ 19 (-34.48%)
Mutual labels:  singularity
docker-ttrss
Tiny Tiny RSS feed reader as a Docker image.
Stars: ✭ 55 (+89.66%)
Mutual labels:  container
heroku-deploy
A simple action to build, push and deploy your dockerized app to your Heroku Application
Stars: ✭ 40 (+37.93%)
Mutual labels:  container
ex-nihilo
Show battery status on macOS
Stars: ✭ 13 (-55.17%)
Mutual labels:  battery
government-frontend
Serves government pages on GOV.UK
Stars: ✭ 42 (+44.83%)
Mutual labels:  container
CNeptune
CNeptune improve productivity & efficiency by urbanize .net module with meta-code to lay foundation for frameworks
Stars: ✭ 30 (+3.45%)
Mutual labels:  container
softwarecontainer
Framework to manage and contain applications in an automotive setting
Stars: ✭ 19 (-34.48%)
Mutual labels:  container
sregistry
server for storage and management of singularity images
Stars: ✭ 96 (+231.03%)
Mutual labels:  singularity
SeleniumDemo
Selenium automation test framework
Stars: ✭ 84 (+189.66%)
Mutual labels:  container

The Experiment Factory

DOI DOI Gitter chat

expfactory/static/img/expfactoryticketyellow.png

See our documentation for getting started. If you are new to containers, read our background or paper first. If you want a more guided entry, see the detailed start

The Experiment Factory is software to create a reproducible container that you can easily customize to deploy a set of web-based experiments.

Citation

If the Experiment Factory is useful to you, please cite the paper to support the software and open source development.

Sochat, (2018). The Experiment Factory: Reproducible Experiment Containers. Journal of Open Source Software, 3(22), 521, https://doi.org/10.21105/joss.00521

Contributing

We have many ways to contribute, and will briefly provide resources here to get you started.

How to Contribute

If you are a developer interested in working on the Experiment Factory software you should read out contributing guidelines for details. For contributing containers and experiments, see our user documentation. If you have any questions, please don't hesitate to ask a question. You'll need to lint your code using black:

$ pip install black
$ black expfactory --exclude template.py

Code of Conduct

It's important to treat one another with respect, and maintain a fun and respectful environment for the open source community. Toward this aim, we ask that you review our code of conduct

Background

It's predecessor at Expfactory.org was never able to open up to the public, and this went against the original goal of the software. Further, the badly needed functionality to serve a local battery was poorly met with expfactory-python as time progressed and dependencies changes.

This version is agnostic to the underlying driver of the experiments, and provides reproducible, instantly deployable "container" experiments. What does that mean?

  • You obtain (or build) one container, a battery of experiments.
  • You (optionally) customize it
    • custom variables (e.g., a study identifier) and configurations go into the build recipe
    • you can choose to use your own database (default output is flat files)
    • other options are available at runtime
  • The container can be easily shared.
  • You run the container, optionally specifying a subset and ordering, and collect your results

If you build on Docker Hub anyone else can then pull and use your exact container to collect their own results. It is exact down to the file hash. Note that bases for expfactory were initially provided on Docker Hub and have moved to Quay.io. Dockerfiles in the repository that use the expfactory-builder are also updated. If you need a previous version, please see the tags on the original Docker Hub.

Experiment Library

The experiments themselves are now maintained under expfactory-experiments, official submissions to be found by expfactory can be added to the library (under development) to be tested that they meet minimum requirements.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].