26 #ifndef CASADI_CALCULUS_HPP
27 #define CASADI_CALCULUS_HPP
34 #include "casadi_common.hpp"
44 const double pi = M_PI;
46 const double pi = 3.14159265358979323846;
50 const double inf = std::numeric_limits<double>::infinity();
53 const double nan = std::numeric_limits<double>::quiet_NaN();
56 const double eps = std::numeric_limits<double>::epsilon();
213 #define NUM_BUILT_IN_OPS (OP_REMAINDER+1)
243 using std::remainder;
264 inline double sign(
double x) {
return x<0 ? -1 : x>0 ? 1 : x;}
272 inline double constpow(
double x,
double y) {
return pow(x, y);}
274 std::ios::fmtflags f(
uout().flags());
275 uout() <<
"|> " << y <<
" : ";
276 uout() << std::setprecision(std::numeric_limits<double>::digits10 + 1) << std::scientific;
277 uout() << x << std::endl;
281 inline bool is_equal(
double x,
double y, casadi_int depth=0) {
return x==y;}
285 inline casadi_int
casadi_max(casadi_int x, casadi_int y) {
return std::max(x, y);}
286 inline casadi_int
casadi_min(casadi_int x, casadi_int y) {
return std::min(x, y);}
290 inline double if_else(
double x,
double y,
double z) {
return x==0 ? z : y;}
299 return x==-1 ? -
inf :
nan;
301 double z = sqrt(-log((1.0+x)/2.0));
302 return -(((1.641345311*z+3.429567803)*z-1.624906493)*z-1.970840454)/
303 ((1.637067800*z+3.543889200)*z+1.0);
308 y = x*(((-0.140543331*z+0.914624893)*z-1.645349621)*z+0.886226899)/
309 ((((-0.329097515*z+0.012229801)*z+1.442710462)*z-2.118377725)*z+1.0);
311 double z = sqrt(-log((1.0-x)/2.0));
312 y = (((1.641345311*z+3.429567803)*z-1.624906493)*z-1.970840454)/
313 ((1.637067800*z+3.543889200)*z+1.0);
317 y = y - (erf(y) - x) / (2.0/sqrt(
pi) * exp(-y*y));
318 y = y - (erf(y) - x) / (2.0/sqrt(
pi) * exp(-y*y));
335 template<casadi_
int I>
338 template<
typename T>
static inline void fcn(
const T& x, T& f);
341 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d);
344 template<casadi_
int I>
347 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) {
351 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
355 template<casadi_
int I>
358 template<
typename T>
static inline T fcn(
const T& x,
const T& y) {
366 template<casadi_
int I>
369 template<
typename T>
static inline void derf(
const T& x,
const T& y, T& f, T* d) {
388 template<casadi_
int I>
391 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f, casadi_int n) {
396 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d,
404 template<casadi_
int I>
407 template<
typename T>
static inline void fcn(
const T* x,
const T* y, T* f, casadi_int n) {
408 for (casadi_int i=0; i<n; ++i) {
414 template<
typename T>
static inline void der(
const T* x,
const T* y,
415 const T* f, T* d, casadi_int n) {
416 for (casadi_int i=0; i<n; ++i, d+=2) {
423 template<casadi_
int I>
426 template<
typename T>
static inline void fcn(
const T* x,
const T& y, T* f, casadi_int n) {
427 for (casadi_int i=0; i<n; ++i) {
433 template<
typename T>
static inline void der(
const T* x,
const T& y,
434 const T* f, T* d, casadi_int n) {
435 for (casadi_int i=0; i<n; ++i, d+=2) {
442 template<casadi_
int I>
445 template<
typename T>
static inline void fcn(
const T& x,
const T* y, T* f, casadi_int n) {
446 for (casadi_int i=0; i<n; ++i) {
452 template<
typename T>
static inline void der(
const T& x,
const T* y,
453 const T* f, T* d, casadi_int n) {
454 for (casadi_int i=0; i<n; ++i, d+=2) {
595 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = x;}
596 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = 1; }
603 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x+y;}
604 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
612 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x-y;}
613 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
621 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x*y;}
622 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
630 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x/y;}
631 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
632 d[0]=1/y; d[1]=-f/y;}
639 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = -x;}
640 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0]=-1;}
647 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = exp(x);}
648 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0]=f;}
655 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = log(x);}
656 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0]=1/x;}
663 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = pow(x, y);}
665 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
666 d[0]=y*pow(x, y-1); d[1]=log(x)*f;}
673 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = pow(x, y);}
674 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
675 d[0]=y*pow(x, y-1); d[1]=0;}
682 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = sqrt(x);}
683 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0]=1/(
twice(f));}
690 template<
typename T>
static inline void fcn(
const T& x, T& f) { f =
sq(x);}
691 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0]=
twice(x);}
697 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = 2.*x;}
698 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = 2; }
705 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = sin(x);}
706 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0]=cos(x);}
713 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = cos(x);}
714 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0]=-sin(x);}
721 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = tan(x);}
722 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d)
723 { d[0] = 1/
sq(cos(x));}
730 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = asin(x);}
731 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0]=1/sqrt(1-x*x);}
738 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = acos(x);}
739 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d)
740 { d[0]=-1/sqrt(1-x*x);}
747 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = atan(x);}
748 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = 1/(1+x*x);}
755 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x < y;}
756 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
764 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x <= y;}
765 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
773 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = floor(x);}
774 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = 0;}
781 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = ceil(x);}
782 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = 0;}
788 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = fmod(x, y);}
789 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
790 d[0]=1; d[1]=(f-x)/y;}
796 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) {
797 f = remainder(x, y);}
798 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
799 d[0]=1; d[1]=(f-x)/y;}
805 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x==y;}
806 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
813 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x!=y;}
814 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
822 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = !x;}
823 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = 0;}
829 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x && y;}
830 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
837 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x || y;}
838 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
845 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = erf(x);}
846 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) {
847 d[0] = (2/sqrt(
pi))*exp(-x*x);}
853 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = fabs(x);}
854 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) {
861 template<
typename T>
static inline void fcn(
const T& x, T& f) { f =
sign(x);}
862 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0]=0;}
868 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = copysign(x, y);}
869 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
870 T e = 1; d[0]=copysign(e, y); d[1]=0;}
876 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = fmin(x, y);}
877 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
887 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = fmax(x, y);}
888 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
898 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = 1./x;}
899 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = -f*f; }
905 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = sinh(x);}
906 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = cosh(x); }
912 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = cosh(x);}
913 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = sinh(x); }
919 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = tanh(x);}
920 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = 1-f*f; }
926 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = asinh(x);}
927 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) {
928 d[0] = 1/sqrt(1+x*x); }
934 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = acosh(x);}
935 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) {
936 d[0] = 1/sqrt(x-1)/sqrt(x+1); }
942 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = atanh(x);}
943 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) { d[0] = 1/(1-x*x); }
949 template<
typename T>
static inline void fcn(
const T& x, T& f) { f =
erfinv(x);}
950 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) {
951 d[0] = (sqrt(
pi)/2)*exp(f*f); }
957 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = log1p(x);}
958 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) {
965 template<
typename T>
static inline void fcn(
const T& x, T& f) { f = expm1(x);}
966 template<
typename T>
static inline void der(
const T& x,
const T& f, T* d) {
973 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) {f =
printme(x, y); }
974 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
982 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = atan2(x, y);}
983 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
984 T t = x*x+y*y; d[0]=y/t; d[1]=-x/t;}
991 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) {
993 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
1000 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = x;}
1001 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
1002 d[0] = 1; d[1] = 0; }
1008 template<
typename T>
static inline void fcn(
const T& x,
const T& y, T& f) { f = hypot(x, y);}
1009 template<
typename T>
static inline void der(
const T& x,
const T& y,
const T& f, T* d) {
1010 d[0] = x/f; d[1] = y/f; }
1013 template<
template<casadi_
int>
class F,
typename T>
1016 case OP_ASSIGN:
return F<OP_ASSIGN>::check;
1017 case OP_ADD:
return F<OP_ADD>::check;
1018 case OP_SUB:
return F<OP_SUB>::check;
1019 case OP_MUL:
return F<OP_MUL>::check;
1020 case OP_DIV:
return F<OP_DIV>::check;
1021 case OP_NEG:
return F<OP_NEG>::check;
1022 case OP_EXP:
return F<OP_EXP>::check;
1023 case OP_LOG:
return F<OP_LOG>::check;
1024 case OP_POW:
return F<OP_POW>::check;
1026 case OP_SQRT:
return F<OP_SQRT>::check;
1027 case OP_SQ:
return F<OP_SQ>::check;
1028 case OP_TWICE:
return F<OP_TWICE>::check;
1029 case OP_SIN:
return F<OP_SIN>::check;
1030 case OP_COS:
return F<OP_COS>::check;
1031 case OP_TAN:
return F<OP_TAN>::check;
1032 case OP_ASIN:
return F<OP_ASIN>::check;
1033 case OP_ACOS:
return F<OP_ACOS>::check;
1034 case OP_ATAN:
return F<OP_ATAN>::check;
1035 case OP_LT:
return F<OP_LT>::check;
1036 case OP_LE:
return F<OP_LE>::check;
1037 case OP_EQ:
return F<OP_EQ>::check;
1038 case OP_NE:
return F<OP_NE>::check;
1039 case OP_NOT:
return F<OP_NOT>::check;
1040 case OP_AND:
return F<OP_AND>::check;
1041 case OP_OR:
return F<OP_OR>::check;
1042 case OP_FLOOR:
return F<OP_FLOOR>::check;
1043 case OP_CEIL:
return F<OP_CEIL>::check;
1044 case OP_FMOD:
return F<OP_FMOD>::check;
1046 case OP_FABS:
return F<OP_FABS>::check;
1047 case OP_SIGN:
return F<OP_SIGN>::check;
1050 case OP_ERF:
return F<OP_ERF>::check;
1051 case OP_FMIN:
return F<OP_FMIN>::check;
1052 case OP_FMAX:
return F<OP_FMAX>::check;
1053 case OP_INV:
return F<OP_INV>::check;
1054 case OP_SINH:
return F<OP_SINH>::check;
1055 case OP_COSH:
return F<OP_COSH>::check;
1056 case OP_TANH:
return F<OP_TANH>::check;
1057 case OP_ASINH:
return F<OP_ASINH>::check;
1058 case OP_ACOSH:
return F<OP_ACOSH>::check;
1059 case OP_ATANH:
return F<OP_ATANH>::check;
1060 case OP_ATAN2:
return F<OP_ATAN2>::check;
1061 case OP_CONST:
return F<OP_CONST>::check;
1062 case OP_INPUT:
return F<OP_INPUT>::check;
1063 case OP_OUTPUT:
return F<OP_OUTPUT>::check;
1065 case OP_CALL:
return F<OP_CALL>::check;
1066 case OP_FIND:
return F<OP_FIND>::check;
1067 case OP_LOW:
return F<OP_LOW>::check;
1068 case OP_MAP:
return F<OP_MAP>::check;
1069 case OP_MTIMES:
return F<OP_MTIMES>::check;
1070 case OP_SOLVE:
return F<OP_SOLVE>::check;
1073 case OP_INVERSE:
return F<OP_INVERSE>::check;
1074 case OP_DOT:
return F<OP_DOT>::check;
1075 case OP_BILIN:
return F<OP_BILIN>::check;
1076 case OP_RANK1:
return F<OP_RANK1>::check;
1077 case OP_HORZCAT:
return F<OP_HORZCAT>::check;
1078 case OP_VERTCAT:
return F<OP_VERTCAT>::check;
1079 case OP_DIAGCAT:
return F<OP_DIAGCAT>::check;
1083 case OP_RESHAPE:
return F<OP_RESHAPE>::check;
1085 case OP_SUBREF:
return F<OP_SUBREF>::check;
1093 case OP_PROJECT:
return F<OP_PROJECT>::check;
1095 case OP_MONITOR:
return F<OP_MONITOR>::check;
1096 case OP_NORM2:
return F<OP_NORM2>::check;
1097 case OP_NORM1:
return F<OP_NORM1>::check;
1098 case OP_NORMINF:
return F<OP_NORMINF>::check;
1099 case OP_NORMF:
return F<OP_NORMF>::check;
1100 case OP_MMIN:
return F<OP_MMIN>::check;
1101 case OP_MMAX:
return F<OP_MMAX>::check;
1104 case OP_ERFINV:
return F<OP_ERFINV>::check;
1105 case OP_PRINTME:
return F<OP_PRINTME>::check;
1106 case OP_LIFT:
return F<OP_LIFT>::check;
1108 case OP_BSPLINE:
return F<OP_BSPLINE>::check;
1110 case OP_LOG1P:
return F<OP_LOG1P>::check;
1111 case OP_EXPM1:
return F<OP_EXPM1>::check;
1112 case OP_HYPOT:
return F<OP_HYPOT>::check;
1118 template<
template<casadi_
int>
class F>
1120 return operation_getter<F, bool>(op);
1124 template<
typename T>
1130 static inline void fun(
unsigned char op,
const T& x,
const T& y,
T& f);
1135 static inline void fun(
unsigned char op,
const T* x,
const T* y,
T* f, casadi_int n);
1140 static inline void fun(
unsigned char op,
const T* x,
const T& y,
T* f, casadi_int n);
1145 static inline void fun(
unsigned char op,
const T& x,
const T* y,
T* f, casadi_int n);
1150 static inline void der(
unsigned char op,
const T& x,
const T& y,
const T& f,
T* d);
1155 static inline void derF(
unsigned char op,
const T& x,
const T& y,
T& f,
T* d);
1160 static inline void fun_linear(
unsigned char op,
const T*x,
const T* y,
T* f);
1165 static inline bool is_binary(
unsigned char op);
1170 static inline bool is_unary(
unsigned char op);
1175 static inline casadi_int
ndeps(
unsigned char op);
1180 static inline std::string
print(
unsigned char op,
const std::string& x,
1181 const std::string& y);
1182 static inline std::string
print(
unsigned char op,
const std::string& x);
1183 static inline std::string
name(
unsigned char op);
1184 static inline std::string
pre(
unsigned char op);
1185 static inline std::string
sep(
unsigned char op);
1186 static inline std::string
post(
unsigned char op);
1196 static inline void fun(
unsigned char op,
const casadi_int& x,
1197 const casadi_int& y, casadi_int& f) {
1200 f =
static_cast<casadi_int
>(ff);
1203 static inline void fun(
unsigned char op,
const casadi_int* x,
const casadi_int* y,
1204 casadi_int* f, casadi_int n) {
1205 for (casadi_int i=0; i<n; ++i) {
1208 *f++ =
static_cast<casadi_int
>(ff);
1212 static inline void fun(
unsigned char op,
const casadi_int* x,
const casadi_int& y,
1213 casadi_int* f, casadi_int n) {
1214 for (casadi_int i=0; i<n; ++i) {
1217 *f++ =
static_cast<casadi_int
>(ff);
1221 static inline void fun(
unsigned char op,
const casadi_int& x,
const casadi_int* y,
1222 casadi_int* f, casadi_int n) {
1223 for (casadi_int i=0; i<n; ++i) {
1226 *f++ =
static_cast<casadi_int
>(ff);
1233 static inline void der(
unsigned char op,
const casadi_int& x,
const casadi_int& y,
1234 const casadi_int& f, casadi_int* d) {
1235 double d_real[2] = {
static_cast<double>(d[0]),
static_cast<double>(d[1])};
1237 static_cast<double>(f), d_real);
1238 d[0] =
static_cast<casadi_int
>(d_real[0]);
1239 d[1] =
static_cast<casadi_int
>(d_real[1]);
1245 static inline void derF(
unsigned char op,
const casadi_int& x,
const casadi_int& y,
1246 casadi_int& f, casadi_int* d) {
1247 double d_real[2] = {
static_cast<double>(d[0]),
static_cast<double>(d[1])};
1248 double f_real =
static_cast<double>(f);
1250 f =
static_cast<casadi_int
>(f_real);
1251 d[0] =
static_cast<casadi_int
>(d_real[0]);
1252 d[1] =
static_cast<casadi_int
>(d_real[1]);
1258 static inline casadi_int
ndeps(
unsigned char op) {
1265 static inline std::string
print(
unsigned char op,
const std::string& x,
1266 const std::string& y) {
1269 static inline std::string
print(
unsigned char op,
const std::string& x) {
1272 static inline std::string
pre(
unsigned char op) {
1275 static inline std::string
name(
unsigned char op) {
1278 static inline std::string
sep(
unsigned char op) {
1281 static inline std::string
post(
unsigned char op) {
1288 template<
typename T>
1292 #define CASADI_MATH_FUN_BUILTIN_GEN(CNAME, X, Y, F, N) \
1293 case OP_ASSIGN: CNAME<OP_ASSIGN>::fcn(X, Y, F, N); break; \
1294 case OP_ADD: CNAME<OP_ADD>::fcn(X, Y, F, N); break; \
1295 case OP_SUB: CNAME<OP_SUB>::fcn(X, Y, F, N); break; \
1296 case OP_MUL: CNAME<OP_MUL>::fcn(X, Y, F, N); break; \
1297 case OP_DIV: CNAME<OP_DIV>::fcn(X, Y, F, N); break; \
1298 case OP_NEG: CNAME<OP_NEG>::fcn(X, Y, F, N); break; \
1299 case OP_EXP: CNAME<OP_EXP>::fcn(X, Y, F, N); break; \
1300 case OP_LOG: CNAME<OP_LOG>::fcn(X, Y, F, N); break; \
1301 case OP_POW: CNAME<OP_POW>::fcn(X, Y, F, N); break; \
1302 case OP_CONSTPOW: CNAME<OP_CONSTPOW>::fcn(X, Y, F, N); break; \
1303 case OP_SQRT: CNAME<OP_SQRT>::fcn(X, Y, F, N); break; \
1304 case OP_SQ: CNAME<OP_SQ>::fcn(X, Y, F, N); break; \
1305 case OP_TWICE: CNAME<OP_TWICE>::fcn(X, Y, F, N); break; \
1306 case OP_SIN: CNAME<OP_SIN>::fcn(X, Y, F, N); break; \
1307 case OP_COS: CNAME<OP_COS>::fcn(X, Y, F, N); break; \
1308 case OP_TAN: CNAME<OP_TAN>::fcn(X, Y, F, N); break; \
1309 case OP_ASIN: CNAME<OP_ASIN>::fcn(X, Y, F, N); break; \
1310 case OP_ACOS: CNAME<OP_ACOS>::fcn(X, Y, F, N); break; \
1311 case OP_ATAN: CNAME<OP_ATAN>::fcn(X, Y, F, N); break; \
1312 case OP_LT: CNAME<OP_LT>::fcn(X, Y, F, N); break; \
1313 case OP_LE: CNAME<OP_LE>::fcn(X, Y, F, N); break; \
1314 case OP_EQ: CNAME<OP_EQ>::fcn(X, Y, F, N); break; \
1315 case OP_NE: CNAME<OP_NE>::fcn(X, Y, F, N); break; \
1316 case OP_NOT: CNAME<OP_NOT>::fcn(X, Y, F, N); break; \
1317 case OP_AND: CNAME<OP_AND>::fcn(X, Y, F, N); break; \
1318 case OP_OR: CNAME<OP_OR>::fcn(X, Y, F, N); break; \
1319 case OP_IF_ELSE_ZERO: CNAME<OP_IF_ELSE_ZERO>::fcn(X, Y, F, N); break; \
1320 case OP_FLOOR: CNAME<OP_FLOOR>::fcn(X, Y, F, N); break; \
1321 case OP_CEIL: CNAME<OP_CEIL>::fcn(X, Y, F, N); break; \
1322 case OP_FMOD: CNAME<OP_FMOD>::fcn(X, Y, F, N); break; \
1323 case OP_REMAINDER: CNAME<OP_REMAINDER>::fcn(X, Y, F, N); break; \
1324 case OP_FABS: CNAME<OP_FABS>::fcn(X, Y, F, N); break; \
1325 case OP_SIGN: CNAME<OP_SIGN>::fcn(X, Y, F, N); break; \
1326 case OP_COPYSIGN: CNAME<OP_COPYSIGN>::fcn(X, Y, F, N); break; \
1327 case OP_ERF: CNAME<OP_ERF>::fcn(X, Y, F, N); break; \
1328 case OP_FMIN: CNAME<OP_FMIN>::fcn(X, Y, F, N); break; \
1329 case OP_FMAX: CNAME<OP_FMAX>::fcn(X, Y, F, N); break; \
1330 case OP_INV: CNAME<OP_INV>::fcn(X, Y, F, N); break; \
1331 case OP_SINH: CNAME<OP_SINH>::fcn(X, Y, F, N); break; \
1332 case OP_COSH: CNAME<OP_COSH>::fcn(X, Y, F, N); break; \
1333 case OP_TANH: CNAME<OP_TANH>::fcn(X, Y, F, N); break; \
1334 case OP_ASINH: CNAME<OP_ASINH>::fcn(X, Y, F, N); break; \
1335 case OP_ACOSH: CNAME<OP_ACOSH>::fcn(X, Y, F, N); break; \
1336 case OP_ATANH: CNAME<OP_ATANH>::fcn(X, Y, F, N); break; \
1337 case OP_ATAN2: CNAME<OP_ATAN2>::fcn(X, Y, F, N); break; \
1338 case OP_ERFINV: CNAME<OP_ERFINV>::fcn(X, Y, F, N); break; \
1339 case OP_LIFT: CNAME<OP_LIFT>::fcn(X, Y, F, N); break; \
1340 case OP_PRINTME: CNAME<OP_PRINTME>::fcn(X, Y, F, N); break; \
1341 case OP_LOG1P: CNAME<OP_LOG1P>::fcn(X, Y, F, N); break; \
1342 case OP_EXPM1: CNAME<OP_EXPM1>::fcn(X, Y, F, N); break; \
1343 case OP_HYPOT: CNAME<OP_HYPOT>::fcn(X, Y, F, N); break;
1345 #define CASADI_MATH_FUN_BUILTIN(X, Y, F) CASADI_MATH_FUN_BUILTIN_GEN(BinaryOperationSS, X, Y, F, 1)
1348 CASADI_MATH_FUN_BUILTIN(x, y, f)
1352 template<
typename T>
1359 template<
typename T>
1366 template<
typename T>
1374 template<
typename T>
1378 #define CASADI_MATH_DER_BUILTIN(X, Y, F, D) \
1379 case OP_ASSIGN: BinaryOperation<OP_ASSIGN>::der(X, Y, F, D); break; \
1380 case OP_ADD: BinaryOperation<OP_ADD>::der(X, Y, F, D); break; \
1381 case OP_SUB: BinaryOperation<OP_SUB>::der(X, Y, F, D); break; \
1382 case OP_MUL: BinaryOperation<OP_MUL>::der(X, Y, F, D); break; \
1383 case OP_DIV: BinaryOperation<OP_DIV>::der(X, Y, F, D); break; \
1384 case OP_NEG: BinaryOperation<OP_NEG>::der(X, Y, F, D); break; \
1385 case OP_EXP: BinaryOperation<OP_EXP>::der(X, Y, F, D); break; \
1386 case OP_LOG: BinaryOperation<OP_LOG>::der(X, Y, F, D); break; \
1387 case OP_POW: BinaryOperation<OP_POW>::der(X, Y, F, D); break; \
1388 case OP_CONSTPOW: BinaryOperation<OP_CONSTPOW>::der(X, Y, F, D); break; \
1389 case OP_SQRT: BinaryOperation<OP_SQRT>::der(X, Y, F, D); break; \
1390 case OP_SQ: BinaryOperation<OP_SQ>::der(X, Y, F, D); break; \
1391 case OP_TWICE: BinaryOperation<OP_TWICE>::der(X, Y, F, D); break; \
1392 case OP_SIN: BinaryOperation<OP_SIN>::der(X, Y, F, D); break; \
1393 case OP_COS: BinaryOperation<OP_COS>::der(X, Y, F, D); break; \
1394 case OP_TAN: BinaryOperation<OP_TAN>::der(X, Y, F, D); break; \
1395 case OP_ASIN: BinaryOperation<OP_ASIN>::der(X, Y, F, D); break; \
1396 case OP_ACOS: BinaryOperation<OP_ACOS>::der(X, Y, F, D); break; \
1397 case OP_ATAN: BinaryOperation<OP_ATAN>::der(X, Y, F, D); break; \
1398 case OP_LT: BinaryOperation<OP_LT>::der(X, Y, F, D); break; \
1399 case OP_LE: BinaryOperation<OP_LE>::der(X, Y, F, D); break; \
1400 case OP_EQ: BinaryOperation<OP_EQ>::der(X, Y, F, D); break; \
1401 case OP_NE: BinaryOperation<OP_NE>::der(X, Y, F, D); break; \
1402 case OP_NOT: BinaryOperation<OP_NOT>::der(X, Y, F, D); break; \
1403 case OP_AND: BinaryOperation<OP_AND>::der(X, Y, F, D); break; \
1404 case OP_OR: BinaryOperation<OP_OR>::der(X, Y, F, D); break; \
1405 case OP_IF_ELSE_ZERO: BinaryOperation<OP_IF_ELSE_ZERO>::der(X, Y, F, D); break; \
1406 case OP_FLOOR: BinaryOperation<OP_FLOOR>::der(X, Y, F, D); break; \
1407 case OP_CEIL: BinaryOperation<OP_CEIL>::der(X, Y, F, D); break; \
1408 case OP_FMOD: BinaryOperation<OP_FMOD>::der(X, Y, F, D); break; \
1409 case OP_REMAINDER: BinaryOperation<OP_REMAINDER>::der(X, Y, F, D); break; \
1410 case OP_FABS: BinaryOperation<OP_FABS>::der(X, Y, F, D); break; \
1411 case OP_SIGN: BinaryOperation<OP_SIGN>::der(X, Y, F, D); break; \
1412 case OP_COPYSIGN: BinaryOperation<OP_COPYSIGN>::der(X, Y, F, D); break; \
1413 case OP_ERF: BinaryOperation<OP_ERF>::der(X, Y, F, D); break; \
1414 case OP_FMIN: BinaryOperation<OP_FMIN>::der(X, Y, F, D); break; \
1415 case OP_FMAX: BinaryOperation<OP_FMAX>::der(X, Y, F, D); break; \
1416 case OP_INV: BinaryOperation<OP_INV>::der(X, Y, F, D); break; \
1417 case OP_SINH: BinaryOperation<OP_SINH>::der(X, Y, F, D); break; \
1418 case OP_COSH: BinaryOperation<OP_COSH>::der(X, Y, F, D); break; \
1419 case OP_TANH: BinaryOperation<OP_TANH>::der(X, Y, F, D); break; \
1420 case OP_ASINH: BinaryOperation<OP_ASINH>::der(X, Y, F, D); break; \
1421 case OP_ACOSH: BinaryOperation<OP_ACOSH>::der(X, Y, F, D); break; \
1422 case OP_ATANH: BinaryOperation<OP_ATANH>::der(X, Y, F, D); break; \
1423 case OP_ATAN2: BinaryOperation<OP_ATAN2>::der(X, Y, F, D); break; \
1424 case OP_ERFINV: BinaryOperation<OP_ERFINV>::der(X, Y, F, D); break; \
1425 case OP_LIFT: BinaryOperation<OP_LIFT>::der(X, Y, F, D); break; \
1426 case OP_PRINTME: BinaryOperation<OP_PRINTME>::der(X, Y, F, D); break; \
1427 case OP_LOG1P: BinaryOperation<OP_LOG1P>::der(X, Y, F, D); break; \
1428 case OP_EXPM1: BinaryOperation<OP_EXPM1>::der(X, Y, F, D); break; \
1429 case OP_HYPOT: BinaryOperation<OP_HYPOT>::der(X, Y, F, D); break;
1431 CASADI_MATH_DER_BUILTIN(x, y, f, d)
1436 template<
typename T>
1440 #define CASADI_MATH_DERF_BUILTIN(X, Y, F, D) \
1441 case OP_ASSIGN: DerBinaryOperation<OP_ASSIGN>::derf(X, Y, F, D); break; \
1442 case OP_ADD: DerBinaryOperation<OP_ADD>::derf(X, Y, F, D); break; \
1443 case OP_SUB: DerBinaryOperation<OP_SUB>::derf(X, Y, F, D); break; \
1444 case OP_MUL: DerBinaryOperation<OP_MUL>::derf(X, Y, F, D); break; \
1445 case OP_DIV: DerBinaryOperation<OP_DIV>::derf(X, Y, F, D); break; \
1446 case OP_NEG: DerBinaryOperation<OP_NEG>::derf(X, Y, F, D); break; \
1447 case OP_EXP: DerBinaryOperation<OP_EXP>::derf(X, Y, F, D); break; \
1448 case OP_LOG: DerBinaryOperation<OP_LOG>::derf(X, Y, F, D); break; \
1449 case OP_POW: DerBinaryOperation<OP_POW>::derf(X, Y, F, D); break; \
1450 case OP_CONSTPOW: DerBinaryOperation<OP_CONSTPOW>::derf(X, Y, F, D); break; \
1451 case OP_SQRT: DerBinaryOperation<OP_SQRT>::derf(X, Y, F, D); break; \
1452 case OP_SQ: DerBinaryOperation<OP_SQ>::derf(X, Y, F, D); break; \
1453 case OP_TWICE: DerBinaryOperation<OP_TWICE>::derf(X, Y, F, D); break; \
1454 case OP_SIN: DerBinaryOperation<OP_SIN>::derf(X, Y, F, D); break; \
1455 case OP_COS: DerBinaryOperation<OP_COS>::derf(X, Y, F, D); break; \
1456 case OP_TAN: DerBinaryOperation<OP_TAN>::derf(X, Y, F, D); break; \
1457 case OP_ASIN: DerBinaryOperation<OP_ASIN>::derf(X, Y, F, D); break; \
1458 case OP_ACOS: DerBinaryOperation<OP_ACOS>::derf(X, Y, F, D); break; \
1459 case OP_ATAN: DerBinaryOperation<OP_ATAN>::derf(X, Y, F, D); break; \
1460 case OP_LT: DerBinaryOperation<OP_LT>::derf(X, Y, F, D); break; \
1461 case OP_LE: DerBinaryOperation<OP_LE>::derf(X, Y, F, D); break; \
1462 case OP_EQ: DerBinaryOperation<OP_EQ>::derf(X, Y, F, D); break; \
1463 case OP_NE: DerBinaryOperation<OP_NE>::derf(X, Y, F, D); break; \
1464 case OP_NOT: DerBinaryOperation<OP_NOT>::derf(X, Y, F, D); break; \
1465 case OP_AND: DerBinaryOperation<OP_AND>::derf(X, Y, F, D); break; \
1466 case OP_OR: DerBinaryOperation<OP_OR>::derf(X, Y, F, D); break; \
1467 case OP_IF_ELSE_ZERO: DerBinaryOperation<OP_IF_ELSE_ZERO>::derf(X, Y, F, D); break; \
1468 case OP_FLOOR: DerBinaryOperation<OP_FLOOR>::derf(X, Y, F, D); break; \
1469 case OP_CEIL: DerBinaryOperation<OP_CEIL>::derf(X, Y, F, D); break; \
1470 case OP_FMOD: DerBinaryOperation<OP_FMOD>::derf(X, Y, F, D); break; \
1471 case OP_REMAINDER: DerBinaryOperation<OP_REMAINDER>::derf(X, Y, F, D); break; \
1472 case OP_FABS: DerBinaryOperation<OP_FABS>::derf(X, Y, F, D); break; \
1473 case OP_SIGN: DerBinaryOperation<OP_SIGN>::derf(X, Y, F, D); break; \
1474 case OP_COPYSIGN: DerBinaryOperation<OP_COPYSIGN>::derf(X, Y, F, D); break; \
1475 case OP_ERF: DerBinaryOperation<OP_ERF>::derf(X, Y, F, D); break; \
1476 case OP_FMIN: DerBinaryOperation<OP_FMIN>::derf(X, Y, F, D); break; \
1477 case OP_FMAX: DerBinaryOperation<OP_FMAX>::derf(X, Y, F, D); break; \
1478 case OP_INV: DerBinaryOperation<OP_INV>::derf(X, Y, F, D); break; \
1479 case OP_SINH: DerBinaryOperation<OP_SINH>::derf(X, Y, F, D); break; \
1480 case OP_COSH: DerBinaryOperation<OP_COSH>::derf(X, Y, F, D); break; \
1481 case OP_TANH: DerBinaryOperation<OP_TANH>::derf(X, Y, F, D); break; \
1482 case OP_ASINH: DerBinaryOperation<OP_ASINH>::derf(X, Y, F, D); break; \
1483 case OP_ACOSH: DerBinaryOperation<OP_ACOSH>::derf(X, Y, F, D); break; \
1484 case OP_ATANH: DerBinaryOperation<OP_ATANH>::derf(X, Y, F, D); break; \
1485 case OP_ATAN2: DerBinaryOperation<OP_ATAN2>::derf(X, Y, F, D); break; \
1486 case OP_ERFINV: DerBinaryOperation<OP_ERFINV>::derf(X, Y, F, D); break; \
1487 case OP_LIFT: DerBinaryOperation<OP_LIFT>::derf(X, Y, F, D); break; \
1488 case OP_PRINTME: DerBinaryOperation<OP_PRINTME>::derf(X, Y, F, D); break; \
1489 case OP_LOG1P: DerBinaryOperation<OP_LOG1P>::derf(X, Y, F, D); break; \
1490 case OP_EXPM1: DerBinaryOperation<OP_EXPM1>::derf(X, Y, F, D); break; \
1491 case OP_HYPOT: DerBinaryOperation<OP_HYPOT>::derf(X, Y, F, D); break;
1493 CASADI_MATH_DERF_BUILTIN(x, y, f, d)
1497 #define CASADI_MATH_BINARY_BUILTIN \
1512 case OP_REMAINDER: \
1520 #define CASADI_MATH_UNARY_BUILTIN \
1551 template<
typename T>
1554 for (
int i=0;i<3;++i) {
1555 f[i] = T::binary(op, x[i], y[i]);
1558 for (
int i=0;i<3;++i) {
1559 f[i] = T::unary(op, x[i]);
1572 bool const_argy = y[1].is_zero() && y[2].is_zero();
1578 f[2] = (x[0]+x[1]+x[2])/(y[0]+y[1]+y[2]);
1581 bool const_arg = x[1].is_zero() && x[2].is_zero();
1583 f[0] = T::unary(op, x[0]);
1585 f[2] = T::unary(op, x[0]+x[1]+x[2]);
1589 bool const_argx = x[1].is_zero() && x[2].is_zero();
1590 bool const_argy = y[1].is_zero() && y[2].is_zero();
1591 if (const_argx && const_argy) {
1592 f[0] = T::binary(op, x[0], y[0]);
1594 f[2] = T::binary(op, x[0]+x[1]+x[2], y[0]+y[1]+y[2]);
1597 casadi_error(
"Not implemented");
1601 template<
typename T>
1604 CASADI_MATH_BINARY_BUILTIN
1612 template<
typename T>
1615 CASADI_MATH_UNARY_BUILTIN
1622 template<
typename T>
1629 CASADI_MATH_BINARY_BUILTIN
1639 template<
typename T>
1642 const std::string& x,
const std::string& y) {
1643 casadi_assert_dev(ndeps(op)==2);
1644 return pre(op) + x + sep(op) + y + post(op);
1647 template<
typename T>
1650 casadi_assert_dev(ndeps(op)==1);
1651 return pre(op) + x + post(op);
1654 template<
typename T>
1658 case OP_ADD:
return "add";
1659 case OP_SUB:
return "sub";
1660 case OP_MUL:
return "mul";
1661 case OP_DIV:
return "div";
1662 case OP_NEG:
return "neg";
1663 case OP_EXP:
return "exp";
1664 case OP_LOG:
return "log";
1666 case OP_POW:
return "pow";
1668 case OP_SQ:
return "sq";
1670 case OP_SIN:
return "sin";
1671 case OP_COS:
return "cos";
1672 case OP_TAN:
return "tan";
1676 case OP_LT:
return "lt";
1677 case OP_LE:
return "le";
1678 case OP_EQ:
return "eq";
1679 case OP_NE:
return "ne";
1680 case OP_NOT:
return "not";
1681 case OP_AND:
return "and";
1682 case OP_OR:
return "or";
1691 case OP_ERF:
return "erf";
1694 case OP_INV:
return "inv";
1712 case OP_DOT:
return "dot";
1746 return "<invalid-op>";
1749 template<
typename T>
1757 case OP_NEG:
return "(-";
1759 case OP_LT:
return "(";
1760 case OP_LE:
return "(";
1761 case OP_EQ:
return "(";
1762 case OP_NE:
return "(";
1763 case OP_NOT:
return "(!";
1765 case OP_OR:
return "(";
1767 case OP_INV:
return "(1./";
1768 default:
return name(op) +
"(";
1772 template<
typename T>
1779 case OP_LT:
return "<";
1780 case OP_LE:
return "<=";
1781 case OP_EQ:
return "==";
1782 case OP_NE:
return "!=";
1783 case OP_AND:
return "&&";
1784 case OP_OR:
return "||";
1786 default:
return ",";
1790 template<
typename T>
1795 default:
return ")";
bool is_equal(double x, double y, casadi_int depth=0)
double if_else_zero(double x, double y)
Conditional assignment.
const double eps
Machine epsilon.
double if_else(double x, double y, double z)
double sign(double x)
Sign function, note that sign(nan) == nan.
casadi_int casadi_min(casadi_int x, casadi_int y)
double printme(double x, double y)
bool operation_checker(casadi_int op)
const double nan
Not a number.
double constpow(double x, double y)
T operation_getter(casadi_int op)
casadi_int casadi_max(casadi_int x, casadi_int y)
Operation
Enum for quick access to any node.
double simplify(double x)
const double pi
Define pi.
static T fcn(const T &x, const T &y)
Function evaluation.
Perform a binary operation on two scalars.
static void der(const T &x, const T &y, const T &f, T *d, casadi_int n)
Partial derivatives - binary function.
static void fcn(const T &x, const T &y, T &f, casadi_int n)
Function evaluation.
Perform a binary operation on a scalar and a vector.
static void der(const T &x, const T *y, const T *f, T *d, casadi_int n)
Partial derivatives - binary function.
static void fcn(const T &x, const T *y, T *f, casadi_int n)
Function evaluation.
Perform a binary operation on a vector and a scalar.
static void fcn(const T *x, const T &y, T *f, casadi_int n)
Function evaluation.
static void der(const T *x, const T &y, const T *f, T *d, casadi_int n)
Partial derivatives - binary function.
Perform a binary operation on two vectors.
static void fcn(const T *x, const T *y, T *f, casadi_int n)
Function evaluation.
static void der(const T *x, const T *y, const T *f, T *d, casadi_int n)
Partial derivatives - binary function.
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
static void der(const T &x, const T &y, const T &f, T *d)
static void fcn(const T &x, const T &y, T &f)
static void der(const T &x, const T &y, const T &f, T *d)
Partial derivatives - binary function.
static void fcn(const T &x, const T &y, T &f)
Function evaluation.
Calculate function and derivative.
static void derf(const T &x, const T &y, T &f, T *d)
Perform the operation.
static const casadi_int check
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
static void der(const T &x, const T &f, T *d)
static void fcn(const T &x, T &f)
Function evaluation.
static void der(const T &x, const T &f, T *d)
Partial derivatives.
static casadi_int ndeps(unsigned char op)
Number of dependencies.
static std::string pre(unsigned char op)
static std::string post(unsigned char op)
static void fun(unsigned char op, const casadi_int &x, const casadi_int &y, casadi_int &f)
Evaluate a built in function.
static void derF(unsigned char op, const casadi_int &x, const casadi_int &y, casadi_int &f, casadi_int *d)
Evaluate the function and the derivative function.
static void fun(unsigned char op, const casadi_int *x, const casadi_int *y, casadi_int *f, casadi_int n)
static std::string sep(unsigned char op)
static void der(unsigned char op, const casadi_int &x, const casadi_int &y, const casadi_int &f, casadi_int *d)
Evaluate a built in derivative function.
static std::string print(unsigned char op, const std::string &x, const std::string &y)
Print.
static void fun(unsigned char op, const casadi_int *x, const casadi_int &y, casadi_int *f, casadi_int n)
static std::string print(unsigned char op, const std::string &x)
static void fun(unsigned char op, const casadi_int &x, const casadi_int *y, casadi_int *f, casadi_int n)
static std::string name(unsigned char op)
Easy access to all the functions for a particular type.
static bool is_binary(unsigned char op)
Is binary operation?
static std::string post(unsigned char op)
static std::string pre(unsigned char op)
static void der(unsigned char op, const T &x, const T &y, const T &f, T *d)
Evaluate a built in derivative function.
static void fun_linear(unsigned char op, const T *x, const T *y, T *f)
Evaluate function on a const/linear/nonlinear partition.
static casadi_int ndeps(unsigned char op)
Number of dependencies.
static std::string print(unsigned char op, const std::string &x, const std::string &y)
Print.
static std::string name(unsigned char op)
static void fun(unsigned char op, const T &x, const T &y, T &f)
Evaluate a built in function (scalar-scalar)
static std::string sep(unsigned char op)
static void derF(unsigned char op, const T &x, const T &y, T &f, T *d)
Evaluate the function and the derivative function.
static bool is_unary(unsigned char op)
Is unary operation?