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.
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.
Suppose we have a breeding cohort whose relationships are modelled some matrix
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.
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ć.