// -*- C++ -*- // $Id: FunctionQuotient.cc,v 1.3 2003/09/06 14:04:14 boudreau Exp $ #include "CLHEP/GenericFunctions/FunctionQuotient.hh" #include namespace Genfun { FUNCTION_OBJECT_IMP(FunctionQuotient) FunctionQuotient::FunctionQuotient(const AbsFunction *arg1, const AbsFunction *arg2): _arg1(arg1->clone()), _arg2(arg2->clone()) { if (arg1->dimensionality()!=arg2->dimensionality()) { std::cout << "Warning: dimension mismatch in function quotient" << std::endl; assert(0); } } FunctionQuotient::FunctionQuotient( const FunctionQuotient & right) : _arg1(right._arg1->clone()), _arg2(right._arg2->clone()) {} FunctionQuotient::~FunctionQuotient() { delete _arg1; delete _arg2; } unsigned int FunctionQuotient::dimensionality() const { return _arg1->dimensionality(); } double FunctionQuotient::operator ()(double x) const { return (*_arg1)(x)/(*_arg2)(x); } double FunctionQuotient::operator ()(const Argument & x) const { return (*_arg1)(x)/(*_arg2)(x); } Derivative FunctionQuotient::partial(unsigned int index) const { const AbsFunction & fPrime = ((_arg1->partial(index))*(*_arg2)-(*_arg1)*(_arg2->partial(index))) / (*_arg2)/ (*_arg2); return Derivative(&fPrime); } } // namespace Genfun