MyNixOS website logo
Description

Research Project Directory Generator.

Create a project directory structure, along with typical files for that project. This allows projects to be quickly and easily created, as well as for them to be standardized. Designed specifically with scientists in mind (mainly bio-medical researchers, but likely applies to other fields).

Project creation with prodigenr: A component of reproducible and open scientific projects

CRAN StatusBadge R-CMD-check lifecycle CRAN RStudio mirrordownloads

This R package is part of a series of (planned) packages that are aimed at creating a toolkit for doing reproducible and open science. Many researchers (especially in biomedicine, medicine, or health, which is my area of research) have little to no knowledge on what open science is or what reproducibility is, let alone how to do it. Our goal is create an (opinionated) toolkit to automate and simplify the process of doing open and reproducible science.

This package has a simple aim of being a project directory generator (prodigenr), with a simple focus on:

  1. Creating a standardized project folder structure with a few template files needed for beginning a data analysis project
  2. Following a “one project, one (main) output” principle, such as a report/manuscript in the case of scientific output or a book or website for things like courses or workshops
  3. Adhering to established best practices that make it easier for the project to be reproducible and open

This standardized approach to how a scientific project is structured helps ensure that the final code and documents are fairly modular, self-contained, easy to share and make public, and be as reproducible as possible. The structure also makes use of the existing and established applications and workflows (RStudio, devtools, and usethis).

Installation

You can install the released version of prodigenr from CRAN with:

install.packages("prodigenr")

And the development version from GitHub with:

# install.packages("remotes")
remotes::install_github("rostools/prodigenr")

Usage

There are two ways of creating a new project: using the R console or using the RStudio “New Project” menu option.

Through the console, use the setup_project() command. So, for instance, if you want a manuscript project, type out:

library(prodigenr)
setup_project("~/Desktop/DiseaseDiet")

This then creates a directory tree, with template files for starting your analysis! Open the newly created project via the .Rproj file. For the RStudio approach, go to “File -> New Project”, then “New directory” and find the prodigenr project in the list:

Creating a prodigenr project inRStudio

Once in the project, you can add a manuscript R Markdown file using:

create_manuscript() 

The main secondary function is the template_list command, which lists the available template files (submit a PR if you want another template included!):

template_list
#> [1] "report" "slides"

For a more detailed tutorial, see the introduction vignette:

vignette('prodigenr', 'prodigenr')

Related packages or projects

There are several existing packages for creating projects, each of which has it’s own pros and cons. Check out the last section of the vignette("prodigenr") for more details. Try them out and see which you like!

prodigenr tries to use ideas from R packages/devtools while still being as simple as possible and to be more specific to academic researchers primarily in biomedical/non-computer science fields. However, it can always improve! I welcome any suggestions, just submit a GitHub issue.

Interested in contributing?

See the contributing documentation for information on how to contribute. Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

Special thanks to @zsemnani for creating the logo!

Metadata

Version

0.6.2

License

Unknown

Platforms (77)

    Darwin
    FreeBSD
    Genode
    GHCJS
    Linux
    MMIXware
    NetBSD
    none
    OpenBSD
    Redox
    Solaris
    WASI
    Windows
Show all
  • aarch64-darwin
  • aarch64-freebsd
  • aarch64-genode
  • aarch64-linux
  • aarch64-netbsd
  • aarch64-none
  • aarch64-windows
  • aarch64_be-none
  • arm-none
  • armv5tel-linux
  • armv6l-linux
  • armv6l-netbsd
  • armv6l-none
  • armv7a-darwin
  • armv7a-linux
  • armv7a-netbsd
  • armv7l-linux
  • armv7l-netbsd
  • avr-none
  • i686-cygwin
  • i686-darwin
  • i686-freebsd
  • i686-genode
  • i686-linux
  • i686-netbsd
  • i686-none
  • i686-openbsd
  • i686-windows
  • javascript-ghcjs
  • loongarch64-linux
  • m68k-linux
  • m68k-netbsd
  • m68k-none
  • microblaze-linux
  • microblaze-none
  • microblazeel-linux
  • microblazeel-none
  • mips-linux
  • mips-none
  • mips64-linux
  • mips64-none
  • mips64el-linux
  • mipsel-linux
  • mipsel-netbsd
  • mmix-mmixware
  • msp430-none
  • or1k-none
  • powerpc-netbsd
  • powerpc-none
  • powerpc64-linux
  • powerpc64le-linux
  • powerpcle-none
  • riscv32-linux
  • riscv32-netbsd
  • riscv32-none
  • riscv64-linux
  • riscv64-netbsd
  • riscv64-none
  • rx-none
  • s390-linux
  • s390-none
  • s390x-linux
  • s390x-none
  • vc4-none
  • wasm32-wasi
  • wasm64-wasi
  • x86_64-cygwin
  • x86_64-darwin
  • x86_64-freebsd
  • x86_64-genode
  • x86_64-linux
  • x86_64-netbsd
  • x86_64-none
  • x86_64-openbsd
  • x86_64-redox
  • x86_64-solaris
  • x86_64-windows