src/main/cpp/numerics4cpp/math.h

00001 /*
00002  * Copyright (c) 2005-2007, DoodleProject
00003  * All rights reserved.
00004  * 
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  * 
00009  * Redistributions of source code must retain the above copyright
00010  * notice, this list of conditions and the following disclaimer.
00011  * 
00012  * Redistributions in binary form must reproduce the above copyright
00013  * notice, this list of conditions and the following disclaimer in
00014  * the documentation and/or other materials provided with the
00015  * distribution.
00016  * 
00017  * Neither the name of DoodleProject nor the names of its contributors
00018  * may be used to endorse or promote products derived from this
00019  * software without specific prior written permission.
00020  * 
00021  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
00022  * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
00023  * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
00024  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00025  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
00026  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
00027  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
00028  * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00029  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
00030  * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
00031  * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
00032  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00033  * SUCH DAMAGE.
00034  */
00035 
00036 #ifndef _NUMERICS4CPP_MATH_H_
00037 #define _NUMERICS4CPP_MATH_H_
00038 
00039 #include <cmath>
00040 #include "numerics.h"
00041 
00042 NUM_NAMESPACE_BEGIN
00043 
00045 static const double LOG_2 = std::log(2.0);
00046 
00048 static const double PI = std::acos(-1.0);
00049 
00051 static const double PI_2 = PI + PI;
00052     
00054 static const double LOG_2_PI = std::log(PI_2);
00055 
00057 static const double LOG_PI = std::log(PI);
00058     
00060 static const double HALF_LOG_2_PI = 0.5 * LOG_2_PI;
00061 
00063 static const double SQRT_2 = std::sqrt(2.0);
00064 
00071 bool is_positive_infinity(double x);
00072 
00079 bool is_negative_infinity(double x);
00080 
00088 bool is_nan(double x);
00089 
00096 bool is_finite(double x);
00097 
00104 bool is_infinite(double x);
00105 
00106 NUM_NAMESPACE_END
00107 
00108 #endif

Generated on Wed Nov 21 22:22:15 2007 for numerics4c++ by  doxygen 1.5.3