ExtMath.cpp File Reference

Go to the source code of this file.

Functions

FENNEL_BEGIN_NAMESPACE void mathLn (RegisterRef< double > *result, RegisterRef< double > *x)
 mathLn. Calculates the natural logarithm
void mathLn (RegisterRef< double > *result, RegisterRef< long long > *x)
void mathLog10 (RegisterRef< double > *result, RegisterRef< double > *x)
 mathLog10. Calculates the base-ten logarithm
void mathLog10 (RegisterRef< double > *result, RegisterRef< long long > *x)
void mathAbs (RegisterRef< double > *result, RegisterRef< double > *x)
 mathAbs. Returns the absolute value.
void mathAbs (RegisterRef< long long > *result, RegisterRef< long long > *x)
 mathAbs. Returns the absolute value.
void mathPow (RegisterRef< double > *result, RegisterRef< double > *x, RegisterRef< double > *y)
 mathPow.
void ExtMathRegister (ExtendedInstructionTable *eit)


Function Documentation

void ExtMathRegister ( ExtendedInstructionTable eit  ) 

Definition at line 169 of file ExtMath.cpp.

References ExtendedInstructionTable::add(), mathAbs(), mathLn(), mathLog10(), mathPow(), STANDARD_TYPE_DOUBLE, and STANDARD_TYPE_INT_64.

Referenced by CalcInit::instance().

00170 {
00171     assert(eit != NULL);
00172 
00173     vector<StandardTypeDescriptorOrdinal> params_2D;
00174     params_2D.push_back(STANDARD_TYPE_DOUBLE);
00175     params_2D.push_back(STANDARD_TYPE_DOUBLE);
00176 
00177     vector<StandardTypeDescriptorOrdinal> params_DI;
00178     params_DI.push_back(STANDARD_TYPE_DOUBLE);
00179     params_DI.push_back(STANDARD_TYPE_INT_64);
00180 
00181     vector<StandardTypeDescriptorOrdinal> params_DII;
00182     params_DII.push_back(STANDARD_TYPE_DOUBLE);
00183     params_DII.push_back(STANDARD_TYPE_INT_64);
00184     params_DII.push_back(STANDARD_TYPE_INT_64);
00185 
00186     vector<StandardTypeDescriptorOrdinal> params_DID;
00187     params_DID.push_back(STANDARD_TYPE_DOUBLE);
00188     params_DID.push_back(STANDARD_TYPE_INT_64);
00189     params_DID.push_back(STANDARD_TYPE_DOUBLE);
00190 
00191     vector<StandardTypeDescriptorOrdinal> params_DDI;
00192     params_DDI.push_back(STANDARD_TYPE_DOUBLE);
00193     params_DDI.push_back(STANDARD_TYPE_DOUBLE);
00194     params_DDI.push_back(STANDARD_TYPE_INT_64);
00195 
00196 
00197     vector<StandardTypeDescriptorOrdinal> params_3D(params_2D);
00198     params_3D.push_back(STANDARD_TYPE_DOUBLE);
00199 
00200     vector<StandardTypeDescriptorOrdinal> params_2I;
00201     params_2I.push_back(STANDARD_TYPE_INT_64);
00202     params_2I.push_back(STANDARD_TYPE_INT_64);
00203 
00204     vector<StandardTypeDescriptorOrdinal> params_3I(params_2I);
00205     params_3I.push_back(STANDARD_TYPE_INT_64);
00206 
00207     eit->add(
00208         "LN", params_2D,
00209         (ExtendedInstruction2<double, double>*) NULL,
00210         &mathLn);
00211 
00212     eit->add(
00213         "LN", params_DI,
00214         (ExtendedInstruction2<double, long long>*) NULL,
00215         &mathLn);
00216 
00217     eit->add(
00218         "LOG10", params_2D,
00219         (ExtendedInstruction2<double, double>*) NULL,
00220         &mathLog10);
00221 
00222     eit->add(
00223         "LOG10", params_DI,
00224         (ExtendedInstruction2<double, long long>*) NULL,
00225         &mathLog10);
00226 
00227     eit->add(
00228         "ABS", params_2D,
00229         (ExtendedInstruction2<double, double>*) NULL,
00230         &mathAbs);
00231 
00232     eit->add(
00233         "ABS", params_2I,
00234         (ExtendedInstruction2<long long, long long>*) NULL,
00235         &mathAbs);
00236 
00237     eit->add(
00238         "POW", params_3D,
00239         (ExtendedInstruction3<double, double, double>*) NULL,
00240         &mathPow);
00241 
00242 }

void mathAbs ( RegisterRef< long long > *  result,
RegisterRef< long long > *  x 
)

mathAbs. Returns the absolute value.

Definition at line 121 of file ExtMath.cpp.

References RegisterRef< TMPLT >::isNull(), STANDARD_TYPE_INT_64, RegisterRef< TMPLT >::toNull(), RegisterReference::type(), and RegisterRef< TMPLT >::value().

00124 {
00125     assert(x->type() == STANDARD_TYPE_INT_64);
00126 
00127     if (x->isNull()) {
00128         result->toNull();
00129     } else {
00130         // Due to various include problems with gcc, it's easy to get
00131         // abs doubly defined. Just arbitrarily using std::abs to
00132         // avoid problems with gcc3.x built-ins.
00133         result->value(std::abs(x->value()));
00134     }
00135 }

void mathAbs ( RegisterRef< double > *  result,
RegisterRef< double > *  x 
)

mathAbs. Returns the absolute value.

Definition at line 107 of file ExtMath.cpp.

Referenced by ExtMathRegister().

00110 {
00111     assert(StandardTypeDescriptor::isApprox(x->type()));
00112 
00113     if (x->isNull()) {
00114         result->toNull();
00115     } else {
00116         result->value(fabs(x->value()));
00117     }
00118 }

void mathLn ( RegisterRef< double > *  result,
RegisterRef< long long > *  x 
)

Definition at line 53 of file ExtMath.cpp.

References StandardTypeDescriptor::isExact(), RegisterRef< TMPLT >::isNull(), RegisterRef< TMPLT >::toNull(), RegisterReference::type(), and RegisterRef< TMPLT >::value().

00056 {
00057     assert(StandardTypeDescriptor::isExact(x->type()));
00058 
00059     if (x->isNull()) {
00060         result->toNull();
00061     } else if (x->value() <= 0) {
00062         result->toNull();
00063         // SQL99 Part 2 Section 22.1 22-023 "invalid parameter value"
00064         throw "22023";
00065     } else {
00066         result->value(log(double(x->value()))); //using the c math library log
00067     }
00068 }

FENNEL_BEGIN_NAMESPACE void mathLn ( RegisterRef< double > *  result,
RegisterRef< double > *  x 
)

mathLn. Calculates the natural logarithm

Definition at line 35 of file ExtMath.cpp.

Referenced by ExtMathRegister().

00038 {
00039     assert(StandardTypeDescriptor::isApprox(x->type()));
00040 
00041     if (x->isNull()) {
00042         result->toNull();
00043     } else if (x->value() <= 0.0) {
00044         result->toNull();
00045         // SQL99 Part 2 Section 22.1 22-023 "invalid parameter value"
00046         throw "22023";
00047     } else {
00048         result->value(log(x->value())); //using the c math library log
00049     }
00050 }

void mathLog10 ( RegisterRef< double > *  result,
RegisterRef< long long > *  x 
)

Definition at line 89 of file ExtMath.cpp.

References StandardTypeDescriptor::isExact(), RegisterRef< TMPLT >::isNull(), RegisterRef< TMPLT >::toNull(), RegisterReference::type(), and RegisterRef< TMPLT >::value().

00092 {
00093     assert(StandardTypeDescriptor::isExact(x->type()));
00094 
00095     if (x->isNull()) {
00096         result->toNull();
00097     } else if (x->value() <= 0) {
00098         result->toNull();
00099         // SQL99 Part 2 Section 22.1 22-023 "invalid parameter value"
00100         throw "22023";
00101     } else {
00102         result->value(log10(double(x->value())));
00103     }
00104 }

void mathLog10 ( RegisterRef< double > *  result,
RegisterRef< double > *  x 
)

mathLog10. Calculates the base-ten logarithm

Definition at line 71 of file ExtMath.cpp.

Referenced by ExtMathRegister().

00074 {
00075     assert(StandardTypeDescriptor::isApprox(x->type()));
00076 
00077     if (x->isNull()) {
00078         result->toNull();
00079     } else if (x->value() <= 0.0) {
00080         result->toNull();
00081         // SQL99 Part 2 Section 22.1 22-023 "invalid parameter value"
00082         throw "22023";
00083     } else {
00084         result->value(log10(x->value()));
00085     }
00086 }

void mathPow ( RegisterRef< double > *  result,
RegisterRef< double > *  x,
RegisterRef< double > *  y 
)

mathPow.

Calculates x^y.

Throws an error and sets the result to null if x<0 and y is not an integer value

Definition at line 138 of file ExtMath.cpp.

References StandardTypeDescriptor::isApprox(), RegisterRef< TMPLT >::isNull(), RegisterRef< TMPLT >::toNull(), RegisterReference::type(), and RegisterRef< TMPLT >::value().

Referenced by ExtMathRegister().

00142 {
00143     assert(StandardTypeDescriptor::isApprox(x->type()));
00144     assert(StandardTypeDescriptor::isApprox(y->type()));
00145 
00146     if (x->isNull() || y->isNull()) {
00147         result->toNull();
00148     } else {
00149         double r = pow(x->value(), y->value());
00150         if ((x->value() == 0.0 && y->value() < 0.0) ||
00151             (x->value() <  0.0 && isnan(r)))
00152         {
00153             // we should get here when x^y have
00154             // x=0 AND y < 0 OR
00155             // x<0 AND y is an non integer.
00156             // If this is the case then the result is NaN
00157 
00158             result->toNull();
00159             // SQL99 Part 2 Section 22.1 22-023 "invalid parameter value"
00160             throw "22023";
00161 
00162         } else {
00163             result->value(r);
00164         }
00165     }
00166 }


Generated on Mon Jun 22 04:00:22 2009 for Fennel by  doxygen 1.5.1