26 #ifndef CASADI_BSPLINE_HPP
27 #define CASADI_BSPLINE_HPP
29 #include "mx_node.hpp"
47 const std::vector<casadi_int>& offset,
48 const std::vector<casadi_int>& degree,
50 const std::vector<casadi_int>& lookup_mode);
55 static void prepare(casadi_int m,
const std::vector<casadi_int>& offset,
56 const std::vector<casadi_int>& degree, casadi_int &coeffs_size,
57 std::vector<casadi_int>& coeffs_dims, std::vector<casadi_int>& strides);
59 static casadi_int get_coeff_size(casadi_int m,
const std::vector<casadi_int>& offset,
60 const std::vector<casadi_int>& degree);
63 static M derivative_coeff(casadi_int i,
64 const std::vector<double>& knots,
65 const std::vector<casadi_int>& offset,
66 const std::vector<casadi_int>& degree,
67 const std::vector<casadi_int>& coeffs_dims,
69 std::vector< std::vector<double> >& new_knots,
70 std::vector<casadi_int>& new_degree);
91 #ifdef CASADI_WITH_THREADSAFE_SYMBOLICS
93 mutable std::mutex jac_cache_mtx_;
101 static size_t n_iw(
const std::vector<casadi_int> °ree);
106 static size_t n_w(
const std::vector<casadi_int> °ree);
111 size_t sz_iw()
const override;
116 size_t sz_w()
const override;
126 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
127 std::vector<std::vector<MX> >& fsens)
const override;
132 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
133 std::vector<std::vector<MX> >& asens)
const override;
139 const std::vector<casadi_int>& arg,
140 const std::vector<casadi_int>& res,
141 const std::vector<bool>& arg_is_ref,
142 std::vector<bool>& res_is_ref)
const override;
148 const std::vector<casadi_int>& arg,
149 const std::vector<bool>& arg_is_ref)
const = 0;
157 MX jac(
const MX& x,
const T& coeffs)
const;
184 static MX create(
const MX& x,
const std::vector< std::vector<double> >& knots,
185 const std::vector<double>& coeffs,
186 const std::vector<casadi_int>& degree,
191 BSpline(
const MX& x,
const std::vector<double>& knots,
192 const std::vector<casadi_int>& offset,
193 const std::vector<double>& coeffs,
194 const std::vector<casadi_int>& degree,
196 const std::vector<casadi_int>& lookup_mode);
202 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
207 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
213 const std::vector<casadi_int>& arg,
214 const std::vector<bool>& arg_is_ref)
const override;
219 std::string disp(
const std::vector<std::string>& arg)
const override;
224 MX jac_cached()
const override;
236 static DM dual(
const std::vector<double>& x,
237 const std::vector< std::vector<double> >& knots,
238 const std::vector<casadi_int>& degree,
258 static MX create(
const MX& x,
const MX& coeffs,
259 const std::vector< std::vector<double> >& knots,
260 const std::vector<casadi_int>& degree,
266 const std::vector<double>& knots,
267 const std::vector<casadi_int>& offset,
268 const std::vector<casadi_int>& degree,
270 const std::vector<casadi_int>& lookup_mode);
276 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
281 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
283 MX jac_cached()
const override;
289 const std::vector<casadi_int>& arg,
290 const std::vector<bool>& arg_is_ref)
const override;
295 std::string disp(
const std::vector<std::string>& arg)
const override;
std::vector< casadi_int > lookup_mode_
std::vector< double > knots_
virtual std::string generate(CodeGenerator &g, const std::vector< casadi_int > &arg, const std::vector< bool > &arg_is_ref) const =0
Generate code for the operation.
~BSplineCommon() override
Destructor.
std::vector< casadi_int > degree_
std::vector< casadi_int > offset_
std::vector< casadi_int > coeffs_dims_
std::vector< casadi_int > strides_
virtual MX jac_cached() const =0
casadi_int op() const override
Get the operation.
BSplineParametric(DeserializingStream &s)
Deserializing constructor.
~BSplineParametric() override
Destructor.
~BSpline() override
Destructor.
std::vector< double > coeffs_
Helper class for C code generation.
Helper class for Serialization.
Node class for MX objects.
Helper class for Serialization.
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.