PySCIPOpt  4.3.0
Python Interface for the SCIP Optimization Suite
Contributing to PySCIPOpt

Code contributions are very welcome and should comply to a few rules:

  1. Read Design principles of PySCIPOpt.
  2. New features should be covered by tests and examples. Please extend [tests](tests) and [examples](examples). Tests uses pytest and examples are meant to be accessible for PySCIPOpt newcomers (even advanced examples).
  3. New code should be documented in the same style as the rest of the code.
  4. New features or bugfixes have to be documented in the CHANGELOG.
  5. New code should be pep8-compliant. Help yourself with the style guide checker.
  6. Before implementing a new PySCIPOpt feature, check whether the feature exists in SCIP. If so, implement it as a pure wrapper, mimicking SCIP whenever possible. If the new feature does not exist in SCIP but it is close to an existing one, consider if implementing that way is substantially convenient (e.g. Pythonic). If it does something completely different, you are welcome to pull your request and discuss the implementation.
  7. PySCIPOpt uses semantic versioning. Version number increase only happens on master and must be tagged to build a new PyPI release.

For general reference, we suggest:

If you find this contributing guide unclear, please open an issue! :)

How to craft a release

  1. update CHANGELOG
  2. increase version number in src/pyscipopt/__init__.py according to semantic versioning
  3. commit changes to the master branch
  1. tag new version git tag vX.Y.Z
  2. git push && git push --tags

A new PyPI package is automatically created by the Travis build job when pushing a new tag onto the master and the version has been increased. Also the documentation is autmatically created in the process.

Design principles of PySCIPOpt

PySCIPOpt is meant to be a fast-prototyping interface of the pure SCIP C API. By design, we distinguish different functions in PySCIPOPT:

  • pure wrapping functions of SCIP;
  • convenience functions.

PySCIPOpt wrappers of SCIP functions should act:

  • with an expected behavior - and parameters, returns, attributes, ...
    • as close to SCIP as possible
  • without *"breaking"* Python and the purpose for what the language it is meant.

Ideally speaking, we want every SCIP function to be wrapped in PySCIPOpt.

Convenience functions are additional, non-detrimental features meant to help prototyping the Python way. Since these functions are not in SCIP, we wish to limit them to prevent difference in features between SCIP and PySCIPOPT, which are always difficult to maintain. A few convenience functions survive in PySCIPOpt when keeping them is doubtless beneficial.

Admittedly, there is a middle ground where functions are not completely wrappers or just convenient. That is the case, for instance, of fundamental Model{.sourceCode} methods like addCons{.sourceCode} or writeProblem{.sourceCode}. We want to leave their development to negotiation.