-
Notifications
You must be signed in to change notification settings - Fork 54
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Refactoring of linopy solvers to object oriented architecture #349
Conversation
…h also changes the call of solvers in model.py
for more information, see https://pre-commit.ci
Great work @daniel-rdt and really efficient! I try to find time to review this asap. In case I am not able to @lkstrp has to jump in. Perhaps you try solving the type and test coverage warnings. I have the feeling that |
for more information, see https://pre-commit.ci
for more information, see https://pre-commit.ci
…ile. Also renaming of Solver class solve method to 'solve_problem()'.
for more information, see https://pre-commit.ci
I've addressed the type check issues (except the type check for the pandas groupby which was addressed by PR #352). I've also adjusted the architecture of the direct solving from a linopy model vs solving from a problem file. The solver instance is not initialized with As far as code coverage is concerned, I have not yet been able to get around to tackling that with adjusted unit tests unfortunately. Apart from this, @lkstrp, I think it's ready for your review. |
In this PR the
solvers.py
file is refactored to an object-oriented architecture. For this, a Solver superclass is introduced, as well as subclasses for each of the implemented solvers. A given problem can now be solved from a problem file without a linopy model using a specified solver. To solve a problem, for each Solver subclass the methodsolve_problem_file()
is implemented. The implementation is based on the following logic suggested by @FabianHofmann in #198 (comment):To solve a problem directly from a problem file, for example using linopy's Gurobi solver interface:
For direct execution using a linopy model, the method
set_direct_model
used that adds the model to the Solver instance:Two unit tests (
test_solver_classes_from_problem_file
andtest_solver_classes_direct
) were also added to test the functionality of the solver classes from a problem file and directly from a model. @finozzifa, any feedback on this is welcome.