From aa21bc6cc8cce0911d99278cb040542fafb7ad8d Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Tue, 29 Mar 2016 19:59:29 -0700 Subject: [PATCH] InteractiveLPBackend.dictionary, .interactive_lp_problem: Add docstrings and tests --- .../backends/interactivelp_backend.pyx | 43 +++++++++++++++++++ 1 file changed, 43 insertions(+) diff --git a/src/sage/numerical/backends/interactivelp_backend.pyx b/src/sage/numerical/backends/interactivelp_backend.pyx index e9d667a37bf..9130ba4072a 100644 --- a/src/sage/numerical/backends/interactivelp_backend.pyx +++ b/src/sage/numerical/backends/interactivelp_backend.pyx @@ -1232,9 +1232,52 @@ cdef class InteractiveLPBackend: # which would for other solvers return backend dictionaries (#18804) """ Return a dictionary representing the current basis. + + EXAMPLE:: + + sage: p = MixedIntegerLinearProgram(maximization=True,\ + solver="InteractiveLP") + sage: x = p.new_variable(nonnegative=True) + sage: p.add_constraint(-x[0] + x[1] <= 2) + sage: p.add_constraint(8 * x[0] + 2 * x[1] <= 17) + sage: p.set_objective(11/2 * x[0] - 3 * x[1]) + sage: b = p.get_backend() + sage: # Backend-specific commands to instruct solver to use simplex method here + sage: b.solve() + 0 + sage: d = b.dictionary(); d + LP problem dictionary ... + sage: set(d.basic_variables()) + {x1, x3} + sage: d.basic_solution() + (17/8, 0) + + TESTS: + + Compare with a dictionary obtained in another way:: + + sage: lp, basis = p.interactive_lp_problem() + sage: lp.dictionary(*basis).basic_solution() + (17/8, 0) + """ return self.final_dictionary cpdef interactive_lp_problem(self): + """ + Return the :class:`InteractiveLPProblem` object associated with this backend. + + EXAMPLE:: + + sage: p = MixedIntegerLinearProgram(maximization=True,\ + solver="InteractiveLP") + sage: x = p.new_variable(nonnegative=True) + sage: p.add_constraint(-x[0] + x[1] <= 2) + sage: p.add_constraint(8 * x[0] + 2 * x[1] <= 17) + sage: p.set_objective(11/2 * x[0] - 3 * x[1]) + sage: b = p.get_backend() + sage: b.interactive_lp_problem() + LP problem ... + """ return self.lp