Skip to content

Latest commit

 

History

History
32 lines (19 loc) · 1.9 KB

contributing.md

File metadata and controls

32 lines (19 loc) · 1.9 KB

Contribution Guidelines

Thanks for your interest in contributing to this repository!

This repository contains a framework to define, train, run, and evaluate machine learning models for LArTPC data. Goals are to

  1. Provide the basic framework needed for I/O, batching, and parallelization for models
  2. Make it easy to try out new models
  3. Make it easy to customize different parts of a LArTPC reconstruction pipeline

Basics

  1. Code should definitely run with Python 3. Please include imports to make your code Python 2 compatible.
  2. Please use the appropriate directories

Tests

Obviously, you should test your code. Ideally, we would have a unit testing framework that would make it easy for you to prove to others that you at least didn't break something.

Use the command CUDA_VISBLE_DEVICES='' pytest -rxXs to run all the tests that are currently available (still work in progress).

Documentation

If you are contributing code, please remember that other people use this repository as well, and that they may want (or need) to understand how to use what you have done. You may also need to understand what you do today 6 months from now. This means that documentation is important. There are three steps to making sure that others (and future you) can easily use and understand your code.

  1. Write a docstring for every function you write, no matter how simple.
  2. Comment your code. If you're writing more than a few lines in a function, a docstring will not suffice. Let any reader know what you're doing, especially when you get to a loop or if statement.
  3. If appropriate, update a README with your contribution.

Docstring Template

We use the numpy style for docstrings. Several example docstrings can be viewed here.