Geant4
9.6.p02
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
geant4_9_6_p02
source
global
management
include
templates.hh
Go to the documentation of this file.
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$
28
//
29
//
30
// -*- C++ -*-
31
//
32
// -----------------------------------------------------------------------
33
// This file should define some platform dependent features and some
34
// useful utilities.
35
// -----------------------------------------------------------------------
36
37
// =======================================================================
38
// Gabriele Cosmo - Created: 5th September 1995
39
// Gabriele Cosmo - Minor change: 08/02/1996
40
// Gabriele Cosmo - Added DBL_MIN, FLT_MIN, DBL_DIG,
41
// DBL_MAX, FLT_DIG, FLT_MAX : 12/04/1996
42
// Gabriele Cosmo - Removed boolean enum definition : 29/11/1996
43
// Gunter Folger - Added G4SwapPtr() and G4SwapObj() : 31/07/1997
44
// Gabriele Cosmo - Adapted signatures of min(), max() to
45
// STL's ones, thanks to E.Tcherniaev : 31/07/1997
46
// Gabriele Cosmo,
47
// Evgueni Tcherniaev - Migrated to CLHEP: 04/12/1997
48
// =======================================================================
49
50
#ifndef templates_h
51
#define templates_h 1
52
53
#include <limits>
54
#include <climits>
55
56
//
57
// If HIGH_PRECISION is defined to TRUE (ie. != 0) then the type "Float"
58
// is typedefed to "double". If it is FALSE (ie. 0) it is typedefed
59
// to "float".
60
//
61
#ifndef HIGH_PRECISION
62
#define HIGH_PRECISION 1
63
#endif
64
65
#if HIGH_PRECISION
66
typedef
double
Float
;
67
#else
68
typedef
float
Float
;
69
#endif
70
71
// Following values have been taken from limits.h
72
// and temporarly defined for portability on HP-UX.
73
74
#ifndef DBL_MIN
/* Min decimal value of a double */
75
#define DBL_MIN std::numeric_limits<double>::min() // 2.2250738585072014e-308
76
#endif
77
78
#ifndef DBL_DIG
/* Digits of precision of a double */
79
#define DBL_DIG std::numeric_limits<double>::digits10 // 15
80
#endif
81
82
#ifndef DBL_MAX
/* Max decimal value of a double */
83
#define DBL_MAX std::numeric_limits<double>::max() // 1.7976931348623157e+308
84
#endif
85
86
#ifndef DBL_EPSILON
87
#define DBL_EPSILON std::numeric_limits<double>::epsilon()
88
#endif // 2.2204460492503131e-16
89
90
#ifndef FLT_MIN
/* Min decimal value of a float */
91
#define FLT_MIN std::numeric_limits<float>::min() // 1.17549435e-38F
92
#endif
93
94
#ifndef FLT_DIG
/* Digits of precision of a float */
95
#define FLT_DIG std::numeric_limits<float>::digits10 // 6
96
#endif
97
98
#ifndef FLT_MAX
/* Max decimal value of a float */
99
#define FLT_MAX std::numeric_limits<float>::max() // 3.40282347e+38F
100
#endif
101
102
#ifndef FLT_EPSILON
103
#define FLT_EPSILON std::numeric_limits<float>::epsilon()
104
#endif // 1.192092896e-07F
105
106
#ifndef MAXFLOAT
/* Max decimal value of a float */
107
#define MAXFLOAT std::numeric_limits<float>::max() // 3.40282347e+38F
108
#endif
109
110
#ifndef INT_MAX
/* Max decimal value of a int */
111
#define INT_MAX std::numeric_limits<int>::max() // 2147483647
112
#endif
113
114
#ifndef INT_MIN
/* Min decimal value of a int */
115
#define INT_MIN std::numeric_limits<int>::min() // -2147483648
116
#endif
117
118
//---------------------------------
119
120
template
<
class
T>
121
inline
void
G4SwapPtr
(T*&
a
, T*&
b
)
122
{
123
T*
tmp
=
a
;
124
a =
b
;
125
b =
tmp
;
126
}
127
128
template
<
class
T>
129
inline
void
G4SwapObj
(T*
a
, T*
b
)
130
{
131
T
tmp
= *
a
;
132
*a = *
b
;
133
*b =
tmp
;
134
}
135
136
//-----------------------------
137
138
#ifndef G4_SQR_DEFINED
139
#define G4_SQR_DEFINED
140
#ifdef sqr
141
#undef sqr
142
#endif
143
144
template
<
class
T>
145
inline
T
sqr
(
const
T&
x
)
146
{
147
return
x*
x
;
148
}
149
#endif
150
151
#ifdef G4_ABS_DEFINED
152
#ifdef abs
153
#undef abs
154
#endif
155
156
template
<
class
T>
157
inline
T std::abs(
const
T&
a
)
158
{
159
return
a < 0 ? -a :
a
;
160
}
161
#endif
162
163
inline
int
G4lrint
(
double
ad)
164
{
165
return
(ad>0) ?
static_cast<
int
>
(ad+.5) :
static_cast<
int
>
(ad-.5);
166
}
167
168
inline
int
G4lint
(
double
ad)
169
{
170
return
(ad>0) ?
static_cast<
int
>
(ad) : static_cast<int>(ad-1.);
171
}
172
173
inline
int
G4rint
(
double
ad)
174
{
175
return
(ad>0) ?
static_cast<
int
>
(ad+1) : static_cast<int>(ad);
176
}
177
178
#endif // templates_h
Generated on Sat May 25 2013 14:33:18 for Geant4 by
1.8.4