26 #include "sparsity_cast.hpp"
27 #include "casadi_misc.hpp"
28 #include "getnonzeros.hpp"
33 casadi_assert_dev(x.
nnz()==sp.
nnz());
39 return eval_gen<double>(arg, res, iw, w);
43 return eval_gen<SXElem>(arg, res, iw, w);
48 if (arg[0]!=res[0]) std::copy(arg[0], arg[0]+
nnz(), res[0]);
64 return "nonzeros(" + arg.at(0) +
")";
66 return "sparsity_cast(" + arg.at(0) +
")";
71 res[0] = sparsity_cast(arg[0],
sparsity());
75 std::vector<std::vector<MX> >& fsens)
const {
76 for (casadi_int d = 0; d<fsens.size(); ++d) {
79 fsens[d][0] = sparsity_cast(fseed[d][0], sp);
84 std::vector<std::vector<MX> >& asens)
const {
85 for (casadi_int d=0; d<aseed.size(); ++d) {
86 MX seed = aseed[d][0];
89 asens[d][0] += sparsity_cast(seed, sp);
94 const std::vector<casadi_int>& arg,
95 const std::vector<casadi_int>& res,
96 const std::vector<bool>& arg_is_ref,
97 std::vector<bool>& res_is_ref)
const {
103 return reshape(
dep(0), sp);
110 return sparsity_cast(
dep(0), sp);
140 typename std::vector<T>::iterator& it)
const {
145 split_primitives_gen<MX>(x, it);
149 split_primitives_gen<SX>(x, it);
153 split_primitives_gen<DM>(x, it);
162 return join_primitives_gen<MX>(it);
166 return join_primitives_gen<SX>(it);
170 return join_primitives_gen<DM>(it);
Helper class for C code generation.
casadi_int nnz() const
Get the number of (structural) non-zero elements.
static MX create(const Sparsity &sp, const MX &x, const std::vector< casadi_int > &nz)
virtual void reset_input() const
Reset the marker for an input expression.
virtual casadi_int n_primitives() const
Get the number of symbolic primitives.
virtual MX get_sparsity_cast(const Sparsity &sp) const
Sparsity cast.
static void copy_fwd(const bvec_t *arg, bvec_t *res, casadi_int len)
Propagate sparsities forward through a copy operation.
virtual bool has_duplicates() const
Detect duplicate symbolic expressions.
virtual bool is_valid_input() const
Check if valid function input.
static void copy_rev(bvec_t *arg, bvec_t *res, casadi_int len)
Propagate sparsities backwards through a copy operation.
void generate_copy(CodeGenerator &g, const std::vector< casadi_int > &arg, const std::vector< casadi_int > &res, const std::vector< bool > &arg_is_ref, std::vector< bool > &res_is_ref, casadi_int i) const
const Sparsity & sparsity() const
Get the sparsity.
casadi_int nnz(casadi_int i=0) const
const MX & dep(casadi_int ind=0) const
dependencies - functions that have to be evaluated before this one
virtual MX get_reshape(const Sparsity &sp) const
Reshape.
virtual void primitives(std::vector< MX >::iterator &it) const
Get symbolic primitives.
void set_sparsity(const Sparsity &sparsity)
Set the sparsity.
virtual MX get_transpose() const
Transpose.
void set_dep(const MX &dep)
Set unary dependency.
virtual void split_primitives(const MX &x, std::vector< MX >::iterator &it) const
Split up an expression along symbolic primitives.
const Sparsity & sparsity() const
Get the sparsity pattern.
Sparse matrix class. SX and DM are specializations.
The basic scalar symbolic class of CasADi.
bool has_duplicates() const override
Detect duplicate symbolic expressions.
int sp_forward(const bvec_t **arg, bvec_t **res, casadi_int *iw, bvec_t *w) const override
Propagate sparsity forward.
void ad_forward(const std::vector< std::vector< MX > > &fseed, std::vector< std::vector< MX > > &fsens) const override
Calculate forward mode directional derivatives.
void primitives(std::vector< MX >::iterator &it) const override
Get symbolic primitives.
int eval(const double **arg, double **res, casadi_int *iw, double *w) const override
Evaluate the function numerically.
void split_primitives(const MX &x, std::vector< MX >::iterator &it) const override
Split up an expression along symbolic primitives.
void split_primitives_gen(const T &x, typename std::vector< T >::iterator &it) const
Split up an expression along primitives (template)
casadi_int n_primitives() const override
Get the number of symbolic primitives.
T join_primitives_gen(typename std::vector< T >::const_iterator &it) const
Join an expression along symbolic primitives (template)
MX get_transpose() const override
Transpose (if a dimension is one)
void ad_reverse(const std::vector< std::vector< MX > > &aseed, std::vector< std::vector< MX > > &asens) const override
Calculate reverse mode directional derivatives.
bool is_valid_input() const override
Check if valid function input.
int eval_gen(const T **arg, T **res, casadi_int *iw, T *w) const
Evaluate the function (template)
std::string disp(const std::vector< std::string > &arg) const override
Print expression.
void eval_mx(const std::vector< MX > &arg, std::vector< MX > &res) const override
Evaluate symbolically (MX)
SparsityCast(const MX &x, Sparsity sp)
Constructor.
MX get_reshape(const Sparsity &sp) const override
SparsityCast.
MX get_nzref(const Sparsity &sp, const std::vector< casadi_int > &nz) const override
Get the nonzeros of matrix.
int eval_sx(const SXElem **arg, SXElem **res, casadi_int *iw, SXElem *w) const override
Evaluate the function symbolically (SX)
void generate(CodeGenerator &g, const std::vector< casadi_int > &arg, const std::vector< casadi_int > &res, const std::vector< bool > &arg_is_ref, std::vector< bool > &res_is_ref) const override
Generate code for the operation.
MX join_primitives(std::vector< MX >::const_iterator &it) const override
Join an expression along symbolic primitives.
int sp_reverse(bvec_t **arg, bvec_t **res, casadi_int *iw, bvec_t *w) const override
Propagate sparsity backwards.
MX get_sparsity_cast(const Sparsity &sp) const override
SparsityCast.
void reset_input() const override
Reset the marker for an input expression.
bool is_subset(const Sparsity &rhs) const
Is subset?
bool is_reshape(const Sparsity &y) const
Check if the sparsity is a reshape of another.
casadi_int nnz() const
Get the number of (structural) non-zeros.
Sparsity sparsity_cast_mod(const Sparsity &X, const Sparsity &Y) const
Propagates subset according to sparsity cast.
unsigned long long bvec_t