9#include <gch/small_vector.hpp>
11#include "sleipnir/optimization/solver/exit_status.hpp"
12#include "sleipnir/util/function_ref.hpp"
22template <
typename DecisionVariables>
46template <
typename DecisionVariables>
49 const DecisionVariables& initial_guess)>
51 std::span<const DecisionVariables> initial_guesses) {
52 gch::small_vector<std::future<MultistartResult<DecisionVariables>>> futures;
53 futures.reserve(initial_guesses.size());
55 for (
const auto& initial_guess : initial_guesses) {
56 futures.emplace_back(std::async(std::launch::async, solve, initial_guess));
59 gch::small_vector<MultistartResult<DecisionVariables>> results;
60 results.reserve(futures.size());
62 for (
auto& future : futures) {
63 results.emplace_back(future.get());
66 return *std::ranges::min_element(results, [](
const auto& a,
const auto& b) {
68 if (a.status == ExitStatus::SUCCESS && b.status != ExitStatus::SUCCESS) {
73 return a.cost < b.cost;
Definition function_ref.hpp:13
Definition multistart.hpp:23
double cost
The solution's cost.
Definition multistart.hpp:27
ExitStatus status
The solver exit status.
Definition multistart.hpp:25
DecisionVariables variables
The decision variables.
Definition multistart.hpp:29