1 /*****************************************************************************
4 ** File Name: ctsupport.h
5 ** Author: Kevin Rosenberg
6 ** Purpose: Header file for CT support library
7 ** Date Started: Dec. 83
9 ** This is part of the CTSim program
10 ** Copyright (c) 1983-2001 Kevin Rosenberg
15 ** This program is free software; you can redistribute it and/or modify
16 ** it under the terms of the GNU General Public License (version 2) as
17 ** published by the Free Software Foundation.
19 ** This program is distributed in the hope that it will be useful,
20 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
21 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 ** GNU General Public License for more details.
24 ** You should have received a copy of the GNU General Public License
25 ** along with this program; if not, write to the Free Software
26 ** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
27 ******************************************************************************/
37 #include "msvc_compat.h"
40 #define STR_MAX_LEN 255
41 #define STR_SIZE STR_MAX_LEN+1
51 #if defined(MSVC) || HAVE_SSTREAM
54 #include <sstream_subst>
65 /*----------------------------------------------------------------------*/
67 #define SHOW(var, fmt) { cerr << "var = " << var << endl; }
69 /*----------------------------------------------------------------------*/
76 /*----------------------------------------------------------------------*/
83 /*----------------------------------------------------------------------*/
86 /* codes for open command */
88 #define OPEN_RDONLY O_RDONLY /* other system use standard codes */
89 #define OPEN_WRONLY O_WRONLY /* for binary */
90 #define OPEN_RDWR O_RDWR
92 #define OPEN_RDONLY 0 /* other system use standard codes */
93 #define OPEN_WRONLY 1 /* for binary */
97 /*----------------------------------------------------------------------*/
99 #if !defined(O_BINARY) && !defined(MSVC)
104 #define S_IWRITE S_IWUSR
107 /*----------------------------------------------------------------------*/
109 #if defined(MSVC) || ! defined(SIZEOF_INT)
111 #define SIZEOF_LONG 4
112 #define SIZEOF_SHORT 2
113 #define SIZEOF_FLOAT 4
114 #define SIZEOF_DOUBLE 8
117 typedef signed char kint8;
118 typedef unsigned char kuint8;
122 typedef unsigned int kuint32;
123 #elif SIZEOF_LONG == 4
124 typedef long int kint32;
125 typedef unsigned int kuint32;
128 #if SIZEOF_SHORT == 2
129 typedef short int kint16;
130 typedef unsigned short int kuint16;
131 #elif SIZEOF_INT == 2
133 typedef unsigned int kuint16;
136 #if SIZEOF_FLOAT == 4
137 typedef float kfloat32;
139 #if SIZEOF_DOUBLE == 8
140 typedef double kfloat64;
145 fileBasename (const char* const filename)
147 const char* p = strrchr (filename, '/');
148 return (p ? p + 1 : filename);
153 char* str_skip_head(const char* str, const char* const charlist);
154 char* str_skip_head(const char* str, char* charlist);
155 char *str_lower(char *s);
156 char *str_wrm_tail(char *str);
157 char *str_rm_tail(char *str, const char* const charlist);
158 char *str_upper(char *str);
161 void sys_error(int severity, const char *msg, ...);
162 void sys_verror (std::string& strOutput, int severity, const char *msg, va_list arg);
163 void sys_error_level(int severity);
164 extern unsigned long int g_lSysErrorMaxCount;
170 #define PI 3.14159265358979323846
171 #define HALFPI 1.57079632679489661923 /* PI divided by 2 */
172 #define QUARTPI 0.78539816339744830962 /* PI divided by 4 */
173 #define I_PI 0.31830988618379067154 /* Inverse of PI */
174 #define I_PID2 0.63661977236758134308 /* Inverse of PID2 */
176 #define TWOPI 6.28318530717958647692
177 #define SQRT2 1.414213562373095049
179 #define F_EPSILON 1.0E-6
180 #define D_EPSILON 1.0E-10
182 #define ASSUMEDZERO 1E-10
184 typedef double GRFMTX_2D[3][3];
185 typedef double GRFMTX_3D[4][4];
188 convertDegreesToRadians (double x)
189 { return (x * (PI/180.)); }
192 convertRadiansToDegrees (double x)
193 { return (x*(180./PI)); }
196 inline T nearest (double x)
197 { return (x > 0 ? static_cast<T>(x+0.5) : static_cast<T>(x-0.5)); }
200 inline T maxValue (T x, T y)
201 { return (x > y ? x : y); }
203 inline bool isEven (int n)
204 { return (n % 2) == 0; }
206 inline bool isOdd (int n)
207 { return (n % 2) != 0; }
210 inline bool isEven (long n)
211 { return (n % 2) == 0; }
213 inline bool isOdd (long n)
214 { return (n % 2) != 0; }
217 inline int imax (int a, int b)
218 { return (a >= b ? a : b); }
220 inline double dmax (double a, double b)
221 { return (a >= b ? a : b); }
224 inline T clamp (T value, T lowerBounds, T upperBounds)
225 { return (value >= upperBounds ? upperBounds : (value <= lowerBounds ? lowerBounds : value )); }
228 inline T lineLength (T x1, T y1, T x2, T y2)
229 { return static_cast<T>( sqrt ((x2-x1)*(x2-x1) + (y2-y1)*(y2-y1)) ); }
232 inline void minmax_array (const T* array, const int n, T& min, T& max)
234 max = min = array[0];
236 for (int i = 1; i < n; i++)
239 else if (array[i] > max)
244 //////////////////////////////////////////////////////////////
245 // FUNTION DECLARATIONS
246 //////////////////////////////////////////////////////////////
249 bool clip_rect (double& x1, double& y1, double& x2, double& y2, const double rect[4]);
250 bool clip_segment (double& x1, double& y1, double& x2, double& y2, const double u, const double v);
251 bool clip_sector (double& x1, double& y1, double& x2, double& y2, const double u, const double v);
252 bool clip_circle (double& x1, double& y1, double& x2, double& y2, const double cx, const double cy, const double radius, double t1, double t2);
253 bool clip_triangle (double& x1, double& y1, double& x2, double& y2, const double u, const double v, const int clip_xaxis);
257 void indent_mtx2 (GRFMTX_2D m);
258 void xlat_mtx2 (GRFMTX_2D m, const double x, const double y);
259 void scale_mtx2 (GRFMTX_2D m, const double sx, const double sy);
260 void rot_mtx2 (GRFMTX_2D m, const double theta);
261 void mult_mtx2 (const GRFMTX_2D m1, const GRFMTX_2D m2, GRFMTX_2D result);
262 void xform_mtx2 (const GRFMTX_2D m, double& x, double& y);
263 void rotate2d (double x[], double y[], int pts, double angle);
264 void xlat2d (double x[], double y[], int pts, double xoffset, double yoffset);
265 void scale2d (double x[], double y[], int pts, double xfact, double yfact);
268 double normalizeAngle (double theta);
269 double integrateSimpson (const double xmin, const double xmax, const double *y, const int np);
270 void vectorNumericStatistics (std::vector<double> vec, const int nPoints, double& min, double& max, double& mean, double& mode, double& median, double& stddev);
273 /*----------------------------------------------------------------------*/
275 /* screen character codes */
284 void cio_tone(double freq, double length);
287 void cio_put_c(int c);
288 void cio_put_cc(int c, int count);
289 void cio_put_str(const char *str);
292 unsigned int cio_kb_getc(void);
293 void cio_kb_ungetc(unsigned int c);
294 char *cio_kb_gets(char *str, int maxlen);
295 unsigned int cio_kb_waitc(const char *astr, int beep);
301 #define KEY_RETURN 13
302 #define KEY_ESCAPE 27
314 #define BACKSLASH '\\'
333 #define AMPERSAND '&'
344 #endif /* #ifndef CTSUPPORT_H */