arithfunctor.h

00001 
00004 
00005 //
00006 // Copyright (c) 2001-2004 California Institute of Technology
00007 // Copyright (c) 2004-2007 University of Southern California
00008 // Rob Peters <rjpeters at usc dot edu>
00009 //
00010 // created: Thu Mar  8 16:27:36 2001 (split from num.h)
00011 // commit: $Id: arithfunctor.h 10065 2007-04-12 05:54:56Z rjpeters $
00012 // $HeadURL: file:///lab/rjpeters/svnrepo/code/trunk/groovx/src/mtx/arithfunctor.h $
00013 //
00014 // --------------------------------------------------------------------
00015 //
00016 // This file is part of GroovX.
00017 //   [http://ilab.usc.edu/rjpeters/groovx/]
00018 //
00019 // GroovX is free software; you can redistribute it and/or modify it
00020 // under the terms of the GNU General Public License as published by
00021 // the Free Software Foundation; either version 2 of the License, or
00022 // (at your option) any later version.
00023 //
00024 // GroovX is distributed in the hope that it will be useful, but
00025 // WITHOUT ANY WARRANTY; without even the implied warranty of
00026 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00027 // General Public License for more details.
00028 //
00029 // You should have received a copy of the GNU General Public License
00030 // along with GroovX; if not, write to the Free Software Foundation,
00031 // Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
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

The software described here is Copyright (c) 1998-2005, Rob Peters.
This page was generated Wed Dec 3 06:49:39 2008 by Doxygen version 1.5.5.