35 std::string
NormF::disp(
const std::vector<std::string>& arg)
const {
36 return "||" + arg.at(0) +
"||_F";
39 int NormF::eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const {
40 return eval_gen<double>(arg, res, iw, w);
43 int Norm1::eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const {
44 return eval_gen<double>(arg, res, iw, w);
47 int NormInf::eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const {
48 return eval_gen<double>(arg, res, iw, w);
52 eval_gen<SXElem>(arg, res, iw, w);
57 eval_gen<SXElem>(arg, res, iw, w);
62 eval_gen<SXElem>(arg, res, iw, w);
84 void NormF::eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const {
85 res[0] = arg[0]->get_norm_fro();
88 void Norm1::eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const {
89 res[0] = arg[0]->get_norm_1();
93 res[0] = arg[0]->get_norm_inf();
96 void Norm2::eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const {
97 res[0] = arg[0]->get_norm_2();
101 std::vector<std::vector<MX> >& fsens)
const {
102 MX self = shared_from_this<MX>();
103 for (casadi_int d=0; d<fsens.size(); ++d) {
104 fsens[d][0] =
dep(0)->
get_dot(fseed[d][0]) /
self;
109 std::vector<std::vector<MX> >& asens)
const {
110 MX self = shared_from_this<MX>();
111 for (casadi_int d=0; d<aseed.size(); ++d) {
112 asens[d][0] += (aseed[d][0]/
self) *
dep(0);
117 std::vector<std::vector<MX> >& fsens)
const {
119 for (casadi_int d=0; d<fsens.size(); ++d) {
120 fsens[d][0] = s->
get_dot(fseed[d][0]);
125 std::vector<std::vector<MX> >& asens)
const {
127 for (casadi_int d=0; d<aseed.size(); ++d) {
128 asens[d][0] += s*aseed[d][0];
133 std::vector<std::vector<MX> >& fsens)
const {
134 MX m = shared_from_this<MX>()==fabs(
dep(0));
136 MX N = sum2(sum1(m));
137 for (casadi_int d=0; d<fsens.size(); ++d) {
138 fsens[d][0] =
dot(s*fseed[d][0], m) / N;
143 std::vector<std::vector<MX> >& asens)
const {
144 MX m = shared_from_this<MX>()==fabs(
dep(0));
145 MX N = sum2(sum1(m));
147 for (casadi_int d=0; d<aseed.size(); ++d) {
148 asens[d][0] += (s*aseed[d][0]/N)*m;
153 const std::vector<casadi_int>& arg,
154 const std::vector<casadi_int>& res,
155 const std::vector<bool>& arg_is_ref,
156 std::vector<bool>& res_is_ref)
const {
157 std::string a = g.
work(arg[0],
dep(0).
nnz(), arg_is_ref[0]);
162 const std::vector<casadi_int>& arg,
163 const std::vector<casadi_int>& res,
164 const std::vector<bool>& arg_is_ref,
165 std::vector<bool>& res_is_ref)
const {
166 std::string a = g.
work(arg[0],
dep(0).
nnz(), arg_is_ref[0]);
171 const std::vector<casadi_int>& arg,
172 const std::vector<casadi_int>& res,
173 const std::vector<bool>& arg_is_ref,
174 std::vector<bool>& res_is_ref)
const {
175 std::string a = g.
work(arg[0],
dep(0).
nnz(), arg_is_ref[0]);
179 std::string
Norm2::disp(
const std::vector<std::string>& arg)
const {
180 return "||" + arg.at(0) +
"||_2";
183 std::string
Norm1::disp(
const std::vector<std::string>& arg)
const {
184 return "||" + arg.at(0) +
"||_1";
188 return "||" + arg.at(0) +
"||_inf";
Helper class for C code generation.
std::string work(casadi_int n, casadi_int sz, bool is_ref) const
std::string norm_2(casadi_int n, const std::string &x)
norm_2
std::string workel(casadi_int n) const
std::string norm_inf(casadi_int n, const std::string &x)
norm_inf
std::string norm_1(casadi_int n, const std::string &x)
norm_1
virtual MX get_dot(const MX &y) const
Inner product.
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.
int eval_sx(const SXElem **arg, SXElem **res, casadi_int *iw, SXElem *w) const override
Evaluate the function symbolically (SX)
void ad_reverse(const std::vector< std::vector< MX > > &aseed, std::vector< std::vector< MX > > &asens) const override
Calculate reverse mode directional derivatives.
void eval_mx(const std::vector< MX > &arg, std::vector< MX > &res) const override
Evaluate symbolically (MX)
void ad_forward(const std::vector< std::vector< MX > > &fseed, std::vector< std::vector< MX > > &fsens) const override
Calculate forward mode directional derivatives.
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.
int eval_gen(const T **arg, T **res, casadi_int *iw, T *w) const
Evaluate the function (template)
int eval(const double **arg, double **res, casadi_int *iw, double *w) const override
Evaluate the function numerically.
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)
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.
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.
int eval(const double **arg, double **res, casadi_int *iw, double *w) const override
Evaluate the function numerically.
void eval_mx(const std::vector< MX > &arg, std::vector< MX > &res) const override
Evaluate symbolically (MX)
int eval_sx(const SXElem **arg, SXElem **res, casadi_int *iw, SXElem *w) const override
Evaluate the function 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.
int eval_gen(const T **arg, T **res, casadi_int *iw, T *w) const
Evaluate the function (template)
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 the function numerically.
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_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.
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.
void eval_mx(const std::vector< MX > &arg, std::vector< MX > &res) const override
Evaluate symbolically (MX)
Norm(const MX &x)
Constructor.
The basic scalar symbolic class of CasADi.
static Sparsity scalar(bool dense_scalar=true)
Create a scalar sparsity pattern *.
T1 casadi_norm_1(casadi_int n, const T1 *x)
NORM_1: ||x||_1 -> return.
double sign(double x)
Sign function, note that sign(nan) == nan.
T1 casadi_norm_2(casadi_int n, const T1 *x)
NORM_2: ||x||_2 -> return.
T dot(const std::vector< T > &a, const std::vector< T > &b)
T1 casadi_norm_inf(casadi_int n, const T1 *x)