00001
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00034
00035 #ifndef GROOVX_PKGS_MTX_ARITHFUNCTOR_H_UTC20050626084022_DEFINED
00036 #define GROOVX_PKGS_MTX_ARITHFUNCTOR_H_UTC20050626084022_DEFINED
00037
00038 #include <cmath>
00039
00040 namespace dash
00041 {
00043 struct mul
00044 {
00045 const double factor;
00046
00047 mul(double fac) : factor(fac) {}
00048 double operator()(double d) { return d*factor; }
00049 };
00050
00052 struct div : public mul
00053 {
00054 div(double div) : mul(1.0/div) {}
00055 };
00056
00058 struct add
00059 {
00060 const double x;
00061
00062 add(double x_) : x(x_) {}
00063 double operator()(double d) { return d + x; }
00064 };
00065
00067 struct sub : public add
00068 {
00069 sub(double x_) : add(-x_) {}
00070 };
00071
00073 struct to_power
00074 {
00075 const double p;
00076
00077 to_power(double p_) : p(p_) {}
00078 double operator()(double v) { return pow(v, p); }
00079 };
00080
00082 struct square
00083 {
00084 double operator()(double x) { return x*x; }
00085 };
00086
00088 struct min
00089 {
00090 double operator()(double v1, double v2)
00091 { return (v1 < v2) ? v1 : v2; }
00092 };
00093
00095 struct max
00096 {
00097 double operator()(double v1, double v2)
00098 { return (v1 > v2) ? v1 : v2; }
00099 };
00100
00102 struct setter
00103 {
00104 const double v;
00105 setter(double v_) : v(v_) {}
00106 double operator()(double) { return v; }
00107 };
00108 }
00109
00110 static const char __attribute__((used)) vcid_groovx_pkgs_mtx_arithfunctor_h_utc20050626084022[] = "$Id: arithfunctor.h 10065 2007-04-12 05:54:56Z rjpeters $ $HeadURL: file:
00111 #endif // !GROOVX_PKGS_MTX_ARITHFUNCTOR_H_UTC20050626084022_DEFINED