Metadata-Version: 2.1
Name: boba
Version: 0.1.3
Summary: Author and execute multiverse analysis
Home-page: https://github.com/uwdata/multiverse-spec
Author: Yang Liu
Author-email: yliu0@uw.edu
License: BSD license
Keywords: multiverse analysis
Platform: UNKNOWN
Classifier: Development Status :: 2 - Pre-Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Requires-Dist: Click (>=6.0)
Requires-Dist: dataclasses (>=0.6)

====
boba
====

Author and execute multiverse analysis with ease.

Boba is a simple domain specific language for specifying multiverse analysis.
It comes with a command line tool to parse your specification and generate
universe scripts, allows you to execute all scripts with a single command, and
wrangles outputs into a single table.

- works with both python and R
- handles simple parameter substitution as well as complex code flow dependency

.. image:: https://badge.fury.io/py/boba.svg
  :target: https://badge.fury.io/py/boba
.. image:: https://travis-ci.org/uwdata/multiverse-spec.svg?branch=master
  :target: https://travis-ci.org/uwdata/multiverse-spec
.. image:: https://img.shields.io/badge/License-BSD%203--Clause-blue.svg
  :target: https://opensource.org/licenses/BSD-3-Clause)
.. image:: https://img.shields.io/pypi/pyversions/boba

Installation
============

You might download and install the latest version of this software from the
Python package index (PyPI)::

  pip install --upgrade boba

Usage
=====

To author your multiverse, please refer to the specification rules_.
Here is a `simple example`_ to get you started!


To parse your specification and generate actual scripts, invoke boba and pass
in the path to your template script and your JSON spec::

  boba compile --script template.py -- json spec.json

To execute the multiverse, namely running all the generated scripts, use::

  boba run --all

For more command line options, see `CLI`_.

.. _rules: https://github.com/uwdata/multiverse-spec/blob/master/tutorial/rules.md
.. _simple example: https://github.com/uwdata/multiverse-spec/blob/master/tutorial/simple.md
.. _more complex example: https://github.com/uwdata/multiverse-spec/blob/master/tutorial/fertility.md
.. _CLI: https://github.com/uwdata/multiverse-spec/blob/master/tutorial/cli.rst

Examples
========

- A `simple example`_ to walk you through the basics
- A `more complex example`_ using `Steegen's multiverse analysis`_ and `Durante's fertility dataset`_.
- Another multiverse example_, based on the `specification curve paper`_ by Simonsohn et al.

.. _reading speed dataset: https://github.com/QishengLi/CHI2019_Reader_View
.. _analysis: https://github.com/uwdata/multiverse-spec/tree/master/example/reading
.. _example: https://github.com/uwdata/multiverse-spec/tree/master/example/hurricane
.. _specification curve paper: https://papers.ssrn.com/sol3/papers.cfm?abstract_id=2694998
.. _Steegen's multiverse analysis: https://journals.sagepub.com/doi/pdf/10.1177/1745691616658637
.. _Durante's fertility dataset: https://osf.io/zj68b/


=======
History
=======

0.1.3 (2019-11-30)
==================

* Revise authoring syntax to support decision blocks and constraints
* Revise CLI, with separate commands to compile and to run
* Improve execution
* Add the hurricane example

0.1.2 (2019-09-19)
==================

* Fix bugs

0.1.1 (2019-09-19)
==================

* Support R
* Improve CLI options
* Support a built-in variable {{_n}}, which represents the universe number
* Support "before_execute" and "after_execute" hooks in the JSON spec
* Update examples

0.1.0 (2019-08-26)
==================

* First release on PyPI.


