Skip to content

Commit

Permalink
Release GIL in optimize and compute_marginals
Browse files Browse the repository at this point in the history
Relates to #839
  • Loading branch information
RainerKuemmerle committed Nov 17, 2024
1 parent 4763286 commit d04a7ad
Showing 1 changed file with 28 additions and 22 deletions.
50 changes: 28 additions & 22 deletions python/core/py_sparse_optimizer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -44,28 +44,34 @@ void declareSparseOptimizer(py::module& m) {
&CLS::computeInitialGuess),
"propagator"_a) // virtual

.def("optimize", &CLS::optimize, "iterations"_a,
"online"_a = false) // -> int
.def("compute_marginals",
[](CLS& optimizer,
const std::vector<std::pair<int, int> >& block_indices) {
auto* spinv = new SparseBlockMatrix<MatrixX>();
bool result = optimizer.computeMarginals(*spinv, block_indices);
return std::make_pair(spinv, result);
})
.def("compute_marginals",
[](CLS& optimizer, const OptimizableGraph::Vertex* vertex) {
auto* spinv = new SparseBlockMatrix<MatrixX>();
bool result = optimizer.computeMarginals(*spinv, vertex);
return std::make_pair(spinv, result);
})
.def("compute_marginals",
[](CLS& optimizer,
const OptimizableGraph::VertexContainer& vertices) {
auto* spinv = new SparseBlockMatrix<MatrixX>();
bool result = optimizer.computeMarginals(*spinv, vertices);
return std::make_pair(spinv, result);
})
.def("optimize", &CLS::optimize, "iterations"_a, "online"_a = false,
py::call_guard<py::gil_scoped_release>()) // -> int
.def(
"compute_marginals",
[](CLS& optimizer,
const std::vector<std::pair<int, int> >& block_indices) {
auto* spinv = new SparseBlockMatrix<MatrixX>();
bool result = optimizer.computeMarginals(*spinv, block_indices);
return std::make_pair(spinv, result);
},
py::call_guard<py::gil_scoped_release>())
.def(
"compute_marginals",
[](CLS& optimizer, const OptimizableGraph::Vertex* vertex) {
auto* spinv = new SparseBlockMatrix<MatrixX>();
bool result = optimizer.computeMarginals(*spinv, vertex);
return std::make_pair(spinv, result);
},
py::call_guard<py::gil_scoped_release>())
.def(
"compute_marginals",
[](CLS& optimizer,
const OptimizableGraph::VertexContainer& vertices) {
auto* spinv = new SparseBlockMatrix<MatrixX>();
bool result = optimizer.computeMarginals(*spinv, vertices);
return std::make_pair(spinv, result);
},
py::call_guard<py::gil_scoped_release>())

// The gauge should be fixed() and then the optimization can work (if no
// additional dof are in the system. The default implementation returns a
Expand Down

0 comments on commit d04a7ad

Please sign in to comment.