9#include <gch/small_vector.hpp>
11#include "sleipnir/optimization/solver/exit_status.hpp"
12#include "sleipnir/util/function_ref.hpp"
21template <
typename Scalar,
typename DecisionVariables>
44template <
typename Scalar,
typename DecisionVariables>
50 gch::small_vector<std::future<MultistartResult<Scalar, DecisionVariables>>>
58 gch::small_vector<MultistartResult<Scalar, DecisionVariables>> results;
59 results.reserve(futures.size());
61 for (
auto& future : futures) {
62 results.emplace_back(future.get());
65 return *std::ranges::min_element(results, [](
const auto& a,
const auto& b) {
67 if (a.status == ExitStatus::SUCCESS && b.status != ExitStatus::SUCCESS) {
72 return a.cost < b.cost;
Definition intrusive_shared_ptr.hpp:27
Definition function_ref.hpp:13
Definition multistart.hpp:22
ExitStatus status
The solver exit status.
Definition multistart.hpp:24
Scalar cost
The solution's cost.
Definition multistart.hpp:26
DecisionVariables variables
The decision variables.
Definition multistart.hpp:28