Foggalong / RobustOCS

Robust optimal contirbution selection problems for genetics with Python
https://pypi.org/project/robustocs
MIT License
2 stars 0 forks source link
breeding genomic-selection genomics python python-module selective-breeding

RobustOCS

PyPi Check Build

Tools for solving robust optimal contribution selection problems in Python. All code and examples in RobustOCS are fully and freely available for all use under the MIT License.

Installation

The latest release can be installed from the PyPI repository using

pip install robustocs

Alternatively, it use the latest (potentially unstable) version from GitHub, use

git clone https://github.com/Foggalong/RobustOCS.git
pip install RobustOCS/

Either way, the package depends on Python 3.10+, using NumPy for linear algebra and SciPy for sparse matrix objects. As a solver it can either use Gurobi (commercial) via gurobipy or HiGHS (free software) via highspy.

Quick-start

Suppose we have a breeding cohort whose relationships are modelled some matrix $\Sigma$, and whose expected breeding values have mean $\bar{\boldsymbol\mu}$ and variance $\Omega$. If these are saved in files, finding the robust optimal contribution selection is as simple as opening Python and running

import robustocs as rocs

selection, objective, merit, coancestry = rocs.solveROCS(
    sigma_filename="cohort-relationships.txt",
    mu_filename="breeding-means.txt",
    omega_filename="breeding-variances.txt",
    sex_filename="cohort-sexes.txt",
    method='robust', lam=0.5, kappa=1
)

where selection will be an array of optimal selections, objective is a score of the selection, merit the expected genetic merit, and coancestry the group co-ancestry.

Documentation

The GitHub wiki includes documentation which explains the usage and parameters in more detail, full rundowns of the key functions (including the quick-start's solveROCS), all alongside some worked examples using the more granular solver functions (the data for which is in examples/). This includes a realistic simulated example from Gregor Gorjanc and Ivan Pocrnić.