35 std::string
MMin::disp(
const std::vector<std::string>& arg)
const {
36 return "min(" + arg.at(0) +
")";
44 std::string
MMax::disp(
const std::vector<std::string>& arg)
const {
45 return "max(" + arg.at(0) +
")";
48 int MMin::eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const {
49 if (!res[0])
return 0;
54 int MMax::eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const {
55 if (!res[0])
return 0;
62 if (!res[0])
return 0;
69 if (!res[0])
return 0;
75 void MMin::eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const {
76 res[0] = mmin(arg[0]);
79 void MMax::eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const {
80 res[0] = mmax(arg[0]);
84 const std::vector<casadi_int>& arg,
85 const std::vector<casadi_int>& res,
86 const std::vector<bool>& arg_is_ref,
87 std::vector<bool>& res_is_ref)
const {
88 g << g.
workel(res[0]) <<
" = "
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 {
98 g << g.
workel(res[0]) <<
" = "
104 std::vector<std::vector<MX> >& fsens)
const {
105 MX m = shared_from_this<MX>()==
dep(0);
106 MX N = sum2(sum1(m));
107 for (casadi_int d=0; d<fsens.size(); ++d) {
108 fsens[d][0] =
dot(fseed[d][0], m) / N;
113 std::vector<std::vector<MX> >& asens)
const {
114 MX m = shared_from_this<MX>()==
dep(0);
115 MX N = sum2(sum1(m));
116 for (casadi_int d=0; d<aseed.size(); ++d) {
117 asens[d][0] += (aseed[d][0]/N)*m;
122 std::vector<std::vector<MX> >& fsens)
const {
123 MX m = shared_from_this<MX>()==
dep(0);
124 MX N = sum2(sum1(m));
125 for (casadi_int d=0; d<fsens.size(); ++d) {
126 fsens[d][0] =
dot(fseed[d][0], m) / N;
131 std::vector<std::vector<MX> >& asens)
const {
132 MX m = shared_from_this<MX>()==
dep(0);
133 MX N = sum2(sum1(m));
134 for (casadi_int d=0; d<aseed.size(); ++d) {
135 asens[d][0] += (aseed[d][0]/N)*m;
Helper class for C code generation.
std::string mmax(const std::string &x, casadi_int n, bool is_dense)
mmax
std::string work(casadi_int n, casadi_int sz, bool is_ref) const
std::string mmin(const std::string &x, casadi_int n, bool is_dense)
mmin
std::string workel(casadi_int n) const
int eval_sx(const SXElem **arg, SXElem **res, casadi_int *iw, SXElem *w) const override
Evaluate symbolically (SX)
void eval_mx(const std::vector< MX > &arg, std::vector< MX > &res) const override
Evaluate symbolically (MX)
void ad_reverse(const std::vector< std::vector< MX > > &aseed, std::vector< std::vector< MX > > &asens) const override
Calculate reverse mode directional derivatives.
MMax(const MX &x)
Constructor.
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.
void ad_forward(const std::vector< std::vector< MX > > &fseed, std::vector< std::vector< MX > > &fsens) const override
Calculate forward mode directional derivatives.
int eval(const double **arg, double **res, casadi_int *iw, double *w) const override
Evaluate numerically.
std::string disp(const std::vector< std::string > &arg) const override
Print expression.
int eval_sx(const SXElem **arg, SXElem **res, casadi_int *iw, SXElem *w) const override
Evaluate symbolically (SX)
void ad_forward(const std::vector< std::vector< MX > > &fseed, std::vector< std::vector< MX > > &fsens) const override
Calculate forward mode directional derivatives.
void eval_mx(const std::vector< MX > &arg, std::vector< MX > &res) const override
Evaluate symbolically (MX)
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.
std::string disp(const std::vector< std::string > &arg) const override
Print expression.
void ad_reverse(const std::vector< std::vector< MX > > &aseed, std::vector< std::vector< MX > > &asens) const override
Calculate reverse mode directional derivatives.
int eval(const double **arg, double **res, casadi_int *iw, double *w) const override
Evaluate numerically.
MMin(const MX &x)
Constructor.
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
void set_sparsity(const Sparsity &sparsity)
Set the sparsity.
void set_dep(const MX &dep)
Set unary dependency.
The basic scalar symbolic class of CasADi.
static Sparsity scalar(bool dense_scalar=true)
Create a scalar sparsity pattern *.
T1 casadi_mmax(const T1 *x, casadi_int n, T1 is_dense)
T dot(const std::vector< T > &a, const std::vector< T > &b)
T1 casadi_mmin(const T1 *x, casadi_int n, casadi_int is_dense)