aboutsummaryrefslogtreecommitdiff
path: root/README.md
blob: 3949fad6f81b3025846bf4183041ba2775f6c249 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
Reproduction pipeline for paper XXXXXXX
=======================================

This is the reproduction pipeline for the paper titled "**XXXXXX**", by
XXXXXXXX et al. (**IN PREPARATION**).

To reproduce our results, the only dependency is **Wget**, and a minimal
Unix-based building environment including a C compiler (already available
on your system if you have ever built and installed a software from
source). Note that **Git is not mandatory**: if you don't have Git to run
the first command below, go to the URL given in the command on your
browser, and download them manually (there is a button to download a
compressed tarball of the project).

```shell
$ git clone XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
$ ./configure
$ .local/bin/make -j8
```

For a general introduction to reproducible science as implemented in this
pipeline, please see the [principles of reproducible
science](http://akhlaghi.org/reproducible-science.html), and a
[reproducible paper
template](https://gitlab.com/makhlaghi/reproducible-paper) that is based on
it.





Running the pipeline
--------------------

This pipeline was designed to have as few dependencies as possible.

1. Necessary dependencies:

   1.1: Minimal software building tools like C compiler, Make, and other
        tools found on any Unix-like operating system (GNU/Linux, BSD, Mac
        OS, and others). All necessary dependencies will be built from
        source (for use only within this pipeline) by the `./configure'
        script (next step).

   1.2: (OPTIONAL) Tarball of dependencies. If they are already present (in
        a directory given at configuration time), they will be
        used. Otherwise, *GNU Wget* will be used to download any necessary
        tarball. The necessary tarballs are also collected in the link
        below for easy download. [[TO PIPELINE DESIGNERS: it is STRONGLY
        RECOMMENDED to keep a backup of all the necessary software tarballs
        you need for the project (possibly in another Git repository). If
        you do have such a link, add it here. If not, remove the
        placeholder and the previous sentence. Also, don't forget to remove
        this note.]]

            https://XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

2. Configure the environment (top-level directories in particular) and
   build all the necessary software for use in the next step. It is
   recommended to set directories outside the current directory. Please
   read the description of each necessary input clearly and set the best
   value. Note that the configure script also downloads, builds and locally
   installs (only for this pipeline, no root privileges necessary) many
   programs (pipeline dependencies). So it may take a while to complete.

     ```shell
     $ ./configure
     ```

3. Run the following command (local build of the Make software) to
   reproduce all the analysis and build the final `paper.pdf` on *8*
   threads. If your CPU has a different number of threads, change the
   number (you can see the number of threads available to your operating
   system by running `./.local/bin/nproc`)

     ```shell
     $ .local/bin/make -j8
     ```