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>;
};