Program Listing for File lmi_oracle.hpp

Return to documentation for file (ellcpp/oracles/lmi_oracle.hpp)

// -*- coding: utf-8 -*-
#pragma once

#include "ldlt_ext.hpp"
#include <gsl/span>
#include <optional>
#include <xtensor/xarray.hpp>

class lmi_oracle
{
    using Arr = xt::xarray<double, xt::layout_type::row_major>;
    using Cut = std::tuple<Arr, double>;

  private:
    const gsl::span<const Arr> _F;
    const Arr _F0;
    ldlt_ext _Q;

  public:
    lmi_oracle(gsl::span<const Arr> F, Arr B)
        : _F {F}
        , _F0 {std::move(B)}
        , _Q {this->_F0.shape()[0]}
    {
    }

    auto operator()(const Arr& x) -> std::optional<Cut>;
};