source: trunk/source/persistency/ascii/src/G4tgrEvaluator.cc @ 1347

Last change on this file since 1347 was 1347, checked in by garnier, 13 years ago

geant4 tag 9.4

File size: 4.3 KB
Line 
1//
2// ********************************************************************
3// * License and Disclaimer                                           *
4// *                                                                  *
5// * The  Geant4 software  is  copyright of the Copyright Holders  of *
6// * the Geant4 Collaboration.  It is provided  under  the terms  and *
7// * conditions of the Geant4 Software License,  included in the file *
8// * LICENSE and available at  http://cern.ch/geant4/license .  These *
9// * include a list of copyright holders.                             *
10// *                                                                  *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work  make  any representation or  warranty, express or implied, *
14// * regarding  this  software system or assume any liability for its *
15// * use.  Please see the license in the file  LICENSE  and URL above *
16// * for the full disclaimer and the limitation of liability.         *
17// *                                                                  *
18// * This  code  implementation is the result of  the  scientific and *
19// * technical work of the GEANT4 collaboration.                      *
20// * By using,  copying,  modifying or  distributing the software (or *
21// * any work based  on the software)  you  agree  to acknowledge its *
22// * use  in  resulting  scientific  publications,  and indicate your *
23// * acceptance of all terms of the Geant4 Software license.          *
24// ********************************************************************
25//
26//
27// $Id: G4tgrEvaluator.cc,v 1.1 2008/10/23 14:43:43 gcosmo Exp $
28// GEANT4 tag $Name: geant4-09-04-ref-00 $
29//
30//
31// class G4tgrEvaluator
32
33// History:
34// - Created.                                 P.Arce, CIEMAT (November 2007)
35// -------------------------------------------------------------------------
36
37#include "G4tgrEvaluator.hh"
38
39#include <cmath>
40
41// -------------------------------------------------------------------------
42G4tgrEvaluator::G4tgrEvaluator()
43{
44  AddCommonFunctions();
45}
46
47
48// -------------------------------------------------------------------------
49G4tgrEvaluator::~G4tgrEvaluator()
50{
51}
52
53
54// -------------------------------------------------------------------------
55void G4tgrEvaluator::print_error( G4int status ) const
56{
57  switch (status)
58  {
59    case ERROR_SYNTAX_ERROR:
60      G4cerr << "G4tgrEvaluator: syntax error!" << G4endl;
61      return;
62    default:
63      HepTool::Evaluator::print_error();   
64    return;
65  }
66} 
67 
68G4double fsin( G4double arg ){  return std::sin(arg); }
69G4double fcos( G4double arg ){  return std::cos(arg); }
70G4double ftan( G4double arg ){  return std::tan(arg); }
71G4double fasin( G4double arg ){  return std::asin(arg); }
72G4double facos( G4double arg ){  return std::acos(arg); }
73G4double fatan( G4double arg ){  return std::atan(arg); }
74G4double fatan2( G4double arg1, G4double arg2 ){ return std::atan2(arg1,arg2); }
75G4double fsinh( G4double arg ){  return std::sinh(arg); }
76G4double fcosh( G4double arg ){  return std::cosh(arg); }
77G4double ftanh( G4double arg ){  return std::tanh(arg); }
78// G4double fasinh( G4double arg ){  return std::asinh(arg); }
79// G4double facosh( G4double arg ){  return std::acosh(arg); }
80// G4double fatanh( G4double arg ){  return std::atanh(arg); }
81G4double fsqrt( G4double arg ){  return std::sqrt(arg); }
82G4double fexp( G4double arg ){  return std::exp(arg); }
83G4double flog( G4double arg ){  return std::log(arg); }
84G4double flog10( G4double arg ){  return std::log10(arg); }
85G4double fpow( G4double arg1, G4double arg2 ){  return std::pow(arg1,arg2); }
86
87
88//--------------------------------------------------------------------
89void G4tgrEvaluator::AddCommonFunctions()
90{
91  setFunction("sin", (*fsin));
92  setFunction("cos", (*fcos));
93  setFunction("tan", (*ftan));
94  setFunction("asin", (*fasin));
95  setFunction("acos", (*facos));
96  setFunction("atan", (*fatan));
97  setFunction("atan2", (*fatan2));
98  setFunction("sinh", (*fsinh));
99  setFunction("cosh", (*fcosh));
100  setFunction("tanh", (*ftanh));
101//  setFunction("asinh", (*fasinh));
102//  setFunction("acosh", (*facosh));
103//  setFunction("atanh", (*fatanh));
104  setFunction("sqrt", (*fsqrt));
105  setFunction("exp", (*fexp));
106  setFunction("log", (*flog));
107  setFunction("log10", (*flog10));
108  setFunction("pow", (*fpow));
109}
Note: See TracBrowser for help on using the repository browser.