mirror of
https://github.com/paboyle/Grid.git
synced 2024-11-14 01:35:36 +00:00
369 lines
8.1 KiB
C
369 lines
8.1 KiB
C
|
/*
|
||
|
Mike Clark - 25th May 2005
|
||
|
|
||
|
bigfloat.h
|
||
|
|
||
|
Simple C++ wrapper for multiprecision datatype used by AlgRemez
|
||
|
algorithm
|
||
|
*/
|
||
|
|
||
|
#ifndef INCLUDED_BIGFLOAT_H
|
||
|
#define INCLUDED_BIGFLOAT_H
|
||
|
|
||
|
#ifdef HAVE_GMP
|
||
|
#include <gmp.h>
|
||
|
#include <mpf2mpfr.h>
|
||
|
#include <mpfr.h>
|
||
|
class bigfloat {
|
||
|
|
||
|
private:
|
||
|
|
||
|
mpf_t x;
|
||
|
|
||
|
public:
|
||
|
|
||
|
bigfloat() { mpf_init(x); }
|
||
|
bigfloat(const bigfloat& y) { mpf_init_set(x, y.x); }
|
||
|
bigfloat(const unsigned long u) { mpf_init_set_ui(x, u); }
|
||
|
bigfloat(const long i) { mpf_init_set_si(x, i); }
|
||
|
bigfloat(const int i) {mpf_init_set_si(x,(long)i);}
|
||
|
bigfloat(const float d) { mpf_init_set_d(x, (double)d); }
|
||
|
bigfloat(const double d) { mpf_init_set_d(x, d); }
|
||
|
bigfloat(const char *str) { mpf_init_set_str(x, (char*)str, 10); }
|
||
|
~bigfloat(void) { mpf_clear(x); }
|
||
|
operator const double (void) const { return (double)mpf_get_d(x); }
|
||
|
static void setDefaultPrecision(unsigned long dprec) {
|
||
|
unsigned long bprec = (unsigned long)(3.321928094 * (double)dprec);
|
||
|
mpf_set_default_prec(bprec);
|
||
|
}
|
||
|
|
||
|
void setPrecision(unsigned long dprec) {
|
||
|
unsigned long bprec = (unsigned long)(3.321928094 * (double)dprec);
|
||
|
mpf_set_prec(x,bprec);
|
||
|
}
|
||
|
|
||
|
unsigned long getPrecision(void) const { return mpf_get_prec(x); }
|
||
|
|
||
|
unsigned long getDefaultPrecision(void) const { return mpf_get_default_prec(); }
|
||
|
|
||
|
bigfloat& operator=(const bigfloat& y) {
|
||
|
mpf_set(x, y.x);
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
bigfloat& operator=(const unsigned long y) {
|
||
|
mpf_set_ui(x, y);
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
bigfloat& operator=(const signed long y) {
|
||
|
mpf_set_si(x, y);
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
bigfloat& operator=(const float y) {
|
||
|
mpf_set_d(x, (double)y);
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
bigfloat& operator=(const double y) {
|
||
|
mpf_set_d(x, y);
|
||
|
return *this;
|
||
|
}
|
||
|
|
||
|
size_t write(void);
|
||
|
size_t read(void);
|
||
|
|
||
|
/* Arithmetic Functions */
|
||
|
|
||
|
bigfloat& operator+=(const bigfloat& y) { return *this = *this + y; }
|
||
|
bigfloat& operator-=(const bigfloat& y) { return *this = *this - y; }
|
||
|
bigfloat& operator*=(const bigfloat& y) { return *this = *this * y; }
|
||
|
bigfloat& operator/=(const bigfloat& y) { return *this = *this / y; }
|
||
|
|
||
|
friend bigfloat operator+(const bigfloat& x, const bigfloat& y) {
|
||
|
bigfloat a;
|
||
|
mpf_add(a.x,x.x,y.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator+(const bigfloat& x, const unsigned long y) {
|
||
|
bigfloat a;
|
||
|
mpf_add_ui(a.x,x.x,y);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator-(const bigfloat& x, const bigfloat& y) {
|
||
|
bigfloat a;
|
||
|
mpf_sub(a.x,x.x,y.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator-(const unsigned long x, const bigfloat& y) {
|
||
|
bigfloat a;
|
||
|
mpf_ui_sub(a.x,x,y.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator-(const bigfloat& x, const unsigned long y) {
|
||
|
bigfloat a;
|
||
|
mpf_sub_ui(a.x,x.x,y);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator-(const bigfloat& x) {
|
||
|
bigfloat a;
|
||
|
mpf_neg(a.x,x.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator*(const bigfloat& x, const bigfloat& y) {
|
||
|
bigfloat a;
|
||
|
mpf_mul(a.x,x.x,y.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator*(const bigfloat& x, const unsigned long y) {
|
||
|
bigfloat a;
|
||
|
mpf_mul_ui(a.x,x.x,y);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator/(const bigfloat& x, const bigfloat& y){
|
||
|
bigfloat a;
|
||
|
mpf_div(a.x,x.x,y.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator/(const unsigned long x, const bigfloat& y){
|
||
|
bigfloat a;
|
||
|
mpf_ui_div(a.x,x,y.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator/(const bigfloat& x, const unsigned long y){
|
||
|
bigfloat a;
|
||
|
mpf_div_ui(a.x,x.x,y);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat sqrt_bf(const bigfloat& x){
|
||
|
bigfloat a;
|
||
|
mpf_sqrt(a.x,x.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat sqrt_bf(const unsigned long x){
|
||
|
bigfloat a;
|
||
|
mpf_sqrt_ui(a.x,x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat abs_bf(const bigfloat& x){
|
||
|
bigfloat a;
|
||
|
mpf_abs(a.x,x.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat pow_bf(const bigfloat& a, long power) {
|
||
|
bigfloat b;
|
||
|
mpf_pow_ui(b.x,a.x,power);
|
||
|
return b;
|
||
|
}
|
||
|
|
||
|
friend bigfloat pow_bf(const bigfloat& a, bigfloat &power) {
|
||
|
bigfloat b;
|
||
|
mpfr_pow(b.x,a.x,power.x,GMP_RNDN);
|
||
|
return b;
|
||
|
}
|
||
|
|
||
|
friend bigfloat exp_bf(const bigfloat& a) {
|
||
|
bigfloat b;
|
||
|
mpfr_exp(b.x,a.x,GMP_RNDN);
|
||
|
return b;
|
||
|
}
|
||
|
|
||
|
/* Comparison Functions */
|
||
|
|
||
|
friend int operator>(const bigfloat& x, const bigfloat& y) {
|
||
|
int test;
|
||
|
test = mpf_cmp(x.x,y.x);
|
||
|
if (test > 0) return 1;
|
||
|
else return 0;
|
||
|
}
|
||
|
|
||
|
friend int operator<(const bigfloat& x, const bigfloat& y) {
|
||
|
int test;
|
||
|
test = mpf_cmp(x.x,y.x);
|
||
|
if (test < 0) return 1;
|
||
|
else return 0;
|
||
|
}
|
||
|
|
||
|
friend int sgn(const bigfloat&);
|
||
|
|
||
|
};
|
||
|
#else
|
||
|
|
||
|
typedef double mfloat;
|
||
|
class bigfloat {
|
||
|
private:
|
||
|
|
||
|
mfloat x;
|
||
|
|
||
|
public:
|
||
|
|
||
|
bigfloat() { }
|
||
|
bigfloat(const bigfloat& y) { x=y.x; }
|
||
|
bigfloat(const unsigned long u) { x=u; }
|
||
|
bigfloat(const long i) { x=i; }
|
||
|
bigfloat(const int i) { x=i;}
|
||
|
bigfloat(const float d) { x=d;}
|
||
|
bigfloat(const double d) { x=d;}
|
||
|
bigfloat(const char *str) { x=std::stod(std::string(str));}
|
||
|
~bigfloat(void) { }
|
||
|
operator double (void) const { return (double)x; }
|
||
|
static void setDefaultPrecision(unsigned long dprec) {
|
||
|
}
|
||
|
|
||
|
void setPrecision(unsigned long dprec) {
|
||
|
}
|
||
|
|
||
|
unsigned long getPrecision(void) const { return 64; }
|
||
|
unsigned long getDefaultPrecision(void) const { return 64; }
|
||
|
|
||
|
bigfloat& operator=(const bigfloat& y) { x=y.x; return *this; }
|
||
|
bigfloat& operator=(const unsigned long y) { x=y; return *this; }
|
||
|
bigfloat& operator=(const signed long y) { x=y; return *this; }
|
||
|
bigfloat& operator=(const float y) { x=y; return *this; }
|
||
|
bigfloat& operator=(const double y) { x=y; return *this; }
|
||
|
|
||
|
size_t write(void);
|
||
|
size_t read(void);
|
||
|
|
||
|
/* Arithmetic Functions */
|
||
|
|
||
|
bigfloat& operator+=(const bigfloat& y) { return *this = *this + y; }
|
||
|
bigfloat& operator-=(const bigfloat& y) { return *this = *this - y; }
|
||
|
bigfloat& operator*=(const bigfloat& y) { return *this = *this * y; }
|
||
|
bigfloat& operator/=(const bigfloat& y) { return *this = *this / y; }
|
||
|
|
||
|
friend bigfloat operator+(const bigfloat& x, const bigfloat& y) {
|
||
|
bigfloat a;
|
||
|
a.x=x.x+y.x;
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator+(const bigfloat& x, const unsigned long y) {
|
||
|
bigfloat a;
|
||
|
a.x=x.x+y;
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator-(const bigfloat& x, const bigfloat& y) {
|
||
|
bigfloat a;
|
||
|
a.x=x.x-y.x;
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator-(const unsigned long x, const bigfloat& y) {
|
||
|
bigfloat bx(x);
|
||
|
return bx-y;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator-(const bigfloat& x, const unsigned long y) {
|
||
|
bigfloat by(y);
|
||
|
return x-by;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator-(const bigfloat& x) {
|
||
|
bigfloat a;
|
||
|
a.x=-x.x;
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator*(const bigfloat& x, const bigfloat& y) {
|
||
|
bigfloat a;
|
||
|
a.x=x.x*y.x;
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator*(const bigfloat& x, const unsigned long y) {
|
||
|
bigfloat a;
|
||
|
a.x=x.x*y;
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator/(const bigfloat& x, const bigfloat& y){
|
||
|
bigfloat a;
|
||
|
a.x=x.x/y.x;
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator/(const unsigned long x, const bigfloat& y){
|
||
|
bigfloat bx(x);
|
||
|
return bx/y;
|
||
|
}
|
||
|
|
||
|
friend bigfloat operator/(const bigfloat& x, const unsigned long y){
|
||
|
bigfloat by(y);
|
||
|
return x/by;
|
||
|
}
|
||
|
|
||
|
friend bigfloat sqrt_bf(const bigfloat& x){
|
||
|
bigfloat a;
|
||
|
a.x= sqrt(x.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat sqrt_bf(const unsigned long x){
|
||
|
bigfloat a(x);
|
||
|
return sqrt_bf(a);
|
||
|
}
|
||
|
|
||
|
friend bigfloat abs_bf(const bigfloat& x){
|
||
|
bigfloat a;
|
||
|
a.x=abs(x.x);
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
friend bigfloat pow_bf(const bigfloat& a, long power) {
|
||
|
bigfloat b;
|
||
|
b.x=pow(a.x,power);
|
||
|
return b;
|
||
|
}
|
||
|
|
||
|
friend bigfloat pow_bf(const bigfloat& a, bigfloat &power) {
|
||
|
bigfloat b;
|
||
|
b.x=pow(a.x,power.x);
|
||
|
return b;
|
||
|
}
|
||
|
|
||
|
friend bigfloat exp_bf(const bigfloat& a) {
|
||
|
bigfloat b;
|
||
|
b.x=exp(a.x);
|
||
|
return b;
|
||
|
}
|
||
|
|
||
|
/* Comparison Functions */
|
||
|
friend int operator>(const bigfloat& x, const bigfloat& y) {
|
||
|
return x.x>y.x;
|
||
|
}
|
||
|
|
||
|
friend int operator<(const bigfloat& x, const bigfloat& y) {
|
||
|
return x.x<y.x;
|
||
|
}
|
||
|
|
||
|
friend int sgn(const bigfloat& x) {
|
||
|
if ( x.x>=0 ) return 1;
|
||
|
else return 0;
|
||
|
}
|
||
|
|
||
|
/* Miscellaneous Functions */
|
||
|
|
||
|
// friend bigfloat& random(void);
|
||
|
};
|
||
|
|
||
|
#endif
|
||
|
|
||
|
#endif
|