26 #ifndef CASADI_BSPLINE_HPP
27 #define CASADI_BSPLINE_HPP
29 #include "mx_node.hpp"
42 class CASADI_EXPORT BSplineCommon :
public MXNode {
46 BSplineCommon(
const std::vector<double>& knots,
47 const std::vector<casadi_int>& offset,
48 const std::vector<casadi_int>& degree,
50 const std::vector<casadi_int>& lookup_mode);
53 ~BSplineCommon()
override {}
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);
72 std::vector<double> knots_;
73 std::vector<casadi_int> offset_;
74 std::vector<casadi_int> degree_;
76 std::vector<casadi_int> lookup_mode_;
79 std::vector<casadi_int> strides_;
80 std::vector<casadi_int> coeffs_dims_;
81 casadi_int coeffs_size_;
89 mutable MX jac_cache_;
91 #ifdef CASADI_WITH_THREADSAFE_SYMBOLICS
93 mutable std::mutex jac_cache_mtx_;
96 virtual MX jac_cached()
const = 0;
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;
121 casadi_int op()
const override {
return OP_BSPLINE;}
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;
138 void generate(CodeGenerator& g,
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;
147 virtual std::string generate(CodeGenerator& g,
148 const std::vector<casadi_int>& arg,
149 const std::vector<bool>& arg_is_ref)
const = 0;
154 static MXNode* deserialize(DeserializingStream& s);
157 MX jac(
const MX& x,
const T& coeffs)
const;
162 void serialize_body(SerializingStream& s)
const override;
169 explicit BSplineCommon(DeserializingStream& s);
181 class CASADI_EXPORT BSpline :
public BSplineCommon {
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);
199 ~BSpline()
override {}
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;
212 std::string generate(CodeGenerator& g,
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;
222 std::vector<double> coeffs_;
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,
243 void serialize_body(SerializingStream& s)
const override;
247 void serialize_type(SerializingStream& s)
const override;
252 explicit BSpline(DeserializingStream& s);
256 class CASADI_EXPORT BSplineParametric :
public BSplineCommon {
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,
265 BSplineParametric(
const MX& x,
const MX& coeffs,
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);
273 ~BSplineParametric()
override {}
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;
288 std::string generate(CodeGenerator& g,
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;
300 void serialize_type(SerializingStream& s)
const override;
305 explicit BSplineParametric(DeserializingStream& s) : BSplineCommon(s) {}
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.