source: Sophya/trunk/SophyaLib/BaseTools/mutyv.h@ 3863

Last change on this file since 3863 was 3750, checked in by ansari, 16 years ago

Prise en charge de float 128 bits (r_16, complex<r_16>) par les NDataBlock<T> et PPersist, controlee par le flag de compilation SO_LDBLE128 defini ds machdefs.h , Reza 03/03/2010

File size: 6.8 KB
RevLine 
[1080]1// This may look like C code, but it is really -*- C++ -*-
2// Classe MuTyV : Variable multi-type numerique
3// Reza Ansari - 96-2000
4
5#ifndef MUTYV_H_SEEN
6#define MUTYV_H_SEEN
7
8#include "machdefs.h"
9
10#include <string>
11#include <complex>
[2826]12#include "timestamp.h"
13
[2322]14#include <iostream>
[1080]15
16namespace SOPHYA {
17
18// Classe utilitaire pour manipuler des variables typees
19//! A simple class for holding string, integer, float and complex type values.
20
21class MuTyV {
22public:
23
[1310]24 enum MTVType {
25 MTVInteger,
26 MTVFloat,
27 MTVComplex,
[2826]28 MTVString,
29 MTVTimeStamp
[1310]30 };
31
32 inline MuTyV() { typ = MTVInteger; iv = 0; dv = dv_im = 0.; strv = NULL; }
[1080]33 MuTyV(MuTyV const & a);
[3661]34 inline MuTyV(uint_1 i) { typ = MTVInteger; iv = (int_8)i; dv = (r_8)i; dv_im = 0.; strv = NULL; }
[1310]35 inline MuTyV(uint_2 i) { typ = MTVInteger; iv = (int_8)i; dv = (r_8)i; dv_im = 0.; strv = NULL; }
[3525]36 inline MuTyV(uint_4 i) { typ = MTVInteger; iv = (int_8)i; dv = (r_8)i; dv_im = 0.; strv = NULL; }
[1544]37 inline MuTyV(uint_8 i) { typ = MTVInteger; iv = (int_8)i; dv = (r_8)i; dv_im = 0.; strv = NULL; }
[3661]38 inline MuTyV(int_1 i) { typ = MTVInteger; iv = (int_8)i; dv = (r_8)i; dv_im = 0.; strv = NULL; }
[3525]39 inline MuTyV(int_2 i) { typ = MTVInteger; iv = (int_8)i; dv = (r_8)i; dv_im = 0.; strv = NULL; }
[1310]40 inline MuTyV(int_4 i) { typ = MTVInteger; iv = (int_8)i; dv = (r_8)i; dv_im = 0.; strv = NULL; }
41 inline MuTyV(int_8 i) { typ = MTVInteger; iv = i; dv = (r_8)i; dv_im = 0.; strv = NULL; }
42 inline MuTyV(r_4 f) { typ = MTVFloat; dv = (r_8)f; iv = (int_8)f; dv_im = 0.; strv = NULL; }
43 inline MuTyV(r_8 d) { typ = MTVFloat; dv = d; iv = (int_8)d; dv_im = 0.; strv = NULL; }
[1870]44 inline MuTyV(complex<r_4> const& z) { typ = MTVComplex; dv = (r_8)z.real(); dv_im = z.imag();
[1080]45 iv = (int_8)dv; strv = NULL; }
[1870]46 inline MuTyV(complex<r_8> const& z) { typ = MTVComplex; dv = z.real(); dv_im = z.imag();
[1080]47 iv = (int_8)dv; strv = NULL; }
48
49 MuTyV(char const* s);
50 MuTyV(string const& s);
[2826]51 MuTyV(TimeStamp const& ts);
52
[1080]53 ~MuTyV();
54
55 MuTyV & operator= (MuTyV const & a);
[3661]56 inline MuTyV & operator= (uint_1 v) { typ = MTVInteger; iv = (int_8)v; dv = (r_8)v; dv_im = 0.; return(*this); }
[1870]57 inline MuTyV & operator= (uint_2 v) { typ = MTVInteger; iv = (int_8)v; dv = (r_8)v; dv_im = 0.; return(*this); }
[2926]58 inline MuTyV & operator= (uint_4 v) { typ = MTVInteger; iv = (int_8)v; dv = (r_8)v; dv_im = 0.; return(*this); }
[1870]59 inline MuTyV & operator= (uint_8 v) { typ = MTVInteger; iv = (int_8)v; dv = (r_8)v; dv_im = 0.; return(*this); }
[3661]60 inline MuTyV & operator= (int_1 v) { typ = MTVInteger; iv = (int_8)v; dv = (r_8)v; dv_im = 0.; return(*this); }
[2926]61 inline MuTyV & operator= (int_2 v) { typ = MTVInteger; iv = (int_8)v; dv = (r_8)v; dv_im = 0.; return(*this); }
[1870]62 inline MuTyV & operator= (int_4 v) { typ = MTVInteger; iv = (int_8)v; dv = (r_8)v; dv_im = 0.; return(*this); }
63 inline MuTyV & operator= (int_8 v) { typ = MTVInteger; iv = v; dv = (r_8)v; dv_im = 0.; return(*this); }
64 inline MuTyV & operator= (r_4 v) { typ = MTVFloat; dv = (r_8)v; iv = (int_8)v; dv_im = 0.; return(*this); }
65 inline MuTyV & operator= (r_8 v) { typ = MTVFloat; dv = v; iv = (int_8)v; dv_im = 0.; return(*this); }
[3750]66 inline MuTyV & operator= (complex<r_4> const& v) { typ = MTVComplex; dv = (r_8)v.real(); dv_im = (r_8)v.imag();
[1870]67 iv = (int_8)dv; return(*this); }
68 inline MuTyV & operator= (complex<r_8> const& v) { typ = MTVComplex; dv = (r_8)v.real(); dv_im = v.imag();
69 iv = (int_8)dv; return(*this); }
[3750]70#ifdef SO_LDBLE128
71 inline MuTyV & operator= (r_16 v) { typ = MTVFloat; dv = (r_8)v; iv = (int_8)v; dv_im = 0.; return(*this); }
72 inline MuTyV & operator= (complex<r_16> const& v) { typ = MTVComplex; dv = (r_8)v.real(); dv_im = (r_8)v.imag();
73 iv = (int_8)dv; return(*this); }
74#endif
75 const char* operator= (const char* s);
76 string const& operator= (string const & s);
77 TimeStamp const& operator= (TimeStamp const & s);
[1080]78
[3661]79 inline operator uint_1() const { return((uint_1)iv); }
[1080]80 inline operator uint_2() const { return((uint_2)iv); }
[1875]81 inline operator uint_4() const { return((uint_4)iv); }
[1544]82 inline operator uint_8() const { return((uint_8)iv); }
[3661]83 inline operator int_1() const { return((int_1)iv); }
[2926]84 inline operator int_2() const { return((int_2)iv); }
[1080]85 inline operator int_4() const { return((int_4)iv); }
86 inline operator int_8() const { return(iv); }
87 inline operator r_4() const { return((r_4)dv); }
88 inline operator r_8() const { return(dv); }
89 inline operator complex<r_4>() const { return(complex<r_4>((r_4)dv, (r_4)dv_im)); }
90 inline operator complex<r_8>() const { return(complex<r_8>(dv, dv_im)); }
[3750]91#ifdef SO_LDBLE128
92 inline operator r_16() const { return((r_16)dv); }
93 inline operator complex<r_16>() const { return(complex<r_16>((r_16)dv, (r_16)dv_im)); }
94#endif
[1080]95
[3750]96 operator string() const ;
97 operator TimeStamp() const ;
[1080]98
[3661]99 inline uint_1 Convert(uint_1& x) const { x = (uint_1)iv; return x; }
[2884]100 inline uint_2 Convert(uint_2& x) const { x = (uint_2)iv; return x; }
101 inline uint_4 Convert(uint_4& x) const { x = (uint_4)iv; return x; }
102 inline uint_8 Convert(uint_8& x) const { x = (uint_8)iv; return x; }
[3661]103 inline int_1 Convert(int_1& x) const { x = (int_1)iv; return x; }
104 inline int_2 Convert(int_2& x) const { x = (int_2)iv; return x; }
[2884]105 inline int_4 Convert(int_4& x) const { x = (int_4)iv; return x; }
106 inline int_8 Convert(int_8& x) const { x = iv; return x; }
107 inline r_4 Convert(r_4& x) const { x = (r_4)dv; return x; }
108 inline r_8 Convert(r_8& x) const { x = dv; return x; }
109 inline complex<r_4> Convert(complex<r_4> & x) const
110 { x = complex< r_4 > ((r_4)dv, (r_4)dv_im); return x; }
111 inline complex<r_8> Convert(complex<r_8> & x) const
112 { x = complex< r_8 > (dv, dv_im); return x; }
[3750]113#ifdef SO_LDBLE128
114 inline r_16 Convert(r_16& x) const { x = (r_16)dv; return x; }
115 inline complex<r_16> Convert(complex<r_16> & x) const
116 { x = complex< r_16 > ((r_16)dv, (r_16)dv_im); return x; }
117#endif
[2884]118 string& Convert(string& x) const ;
119 TimeStamp& Convert(TimeStamp& x) const ;
120
[1870]121 inline MTVType Type() const { return typ; }
122 inline int_8 GetIntPart() const { return iv; }
123 inline r_8 GetRealPart() const { return dv; }
124 inline r_8 GetImagPart() const { return dv_im; }
125 inline string* GetStringPointer() const { return (strv); }
126
127protected:
[1080]128 int_8 iv;
129 r_8 dv;
130 r_8 dv_im; /* for holding imaginary part of a complex */
[2826]131 string * strv;
[1310]132 MTVType typ;
[1080]133
134};
135
136inline ostream& operator << (ostream& s, MuTyV const & mtv)
137{ s << (string)mtv; return(s); }
138
139
140} // namespace SOPHYA
141
142#endif /* MUTYV_H_SEEN */
143
144
Note: See TracBrowser for help on using the repository browser.