source: Sophya/trunk/SophyaLib/SkyT/specrespvector.cc@ 2908

Last change on this file since 2908 was 2873, checked in by ansari, 20 years ago

Portage/compilation sur AIX-XlC (regatta): Ajout qualification de nom pour instanciation explicite de template + correction petit bug - Reza 3 Jan 2006

File size: 4.6 KB
Line 
1//--------------------------------------------------------------------------
2// File and Version Information:
3// $Id: specrespvector.cc,v 1.12 2006-01-03 14:29:37 ansari Exp $
4//
5// Description:
6// Aim of the class: To give the energy density
7// The unity used here is W/m^2/Hz/sr
8//
9// History (add to end):
10// Sophie Oct, 1999 - creation
11//
12//------------------------------------------------------------------------
13
14//---------------
15// C++ Headers --
16//---------------
17#include "sopnamsp.h"
18#include "machdefs.h"
19#include <iostream>
20#include <math.h>
21// #include <typeinfo>
22
23#include "specrespvector.h"
24#include "pexceptions.h"
25#include "fioarr.h"
26//----------------
27// Constructor --
28//----------------
29/*!
30 * \class SOPHYA::SpecRespVec
31 \ingroup SkyT
32 One may also want to defined the filter of a detector by two vectors:
33 one for the frequencies and one for the corresponding transmission values.
34 In this case on should use the SpecRespVec class !
35*/
36SpecRespVec::SpecRespVec()
37 : SpectralResponse()
38{
39}
40
41/*! Constructor:
42 \param nu vector of the frequencies
43 \param fdenu vector of the corresponding transmission values of the filter
44*/
45SpecRespVec::SpecRespVec(Vector const & nu, Vector const & fdenu, double numin, double numax)
46 : SpectralResponse(numin, numax)
47{
48 if(nu.NElts() != fdenu.NElts())
49 throw SzMismatchError("SpecRespVec::SpecRespVec() - Non equal vector sizes");
50 _vecOfNu = nu;
51 _vecOfFDeNu = fdenu;
52 _size = nu.NElts();
53}
54
55SpecRespVec::SpecRespVec(Vector const & nu, Vector const & fdenu)
56 : SpectralResponse()
57{
58 if(nu.NElts() != fdenu.NElts())
59 throw SzMismatchError("SpecRespVec::SpecRespVec() - Non equal vector sizes");
60 _vecOfNu = nu;
61 _vecOfFDeNu = fdenu;
62 _numin = nu(0);
63 _numax = nu(nu.NElts()-1);
64 _size = nu.NElts();
65}
66
67
68//--------------
69// Destructor --
70//--------------
71SpecRespVec::~SpecRespVec()
72{
73}
74
75// ---------------------------
76// -- Function Definitions --
77// ---------------------------
78
79
80
81/*! The transmission function extrapolates the transmission values for the
82 frequencies that are not present in the nu vector <BR>
83 given at the instanciation of the class.
84*/
85double
86SpecRespVec::transmission(double nu) const
87{
88 if ( (nu < _numin) || (nu > _numax) ) return(0.);
89 double value = 0.;
90 int sizeVecOfNu = _vecOfNu.NElts();
91 if(nu <= _vecOfNu(0)) return _vecOfFDeNu(0);
92 if(nu >= _vecOfNu(sizeVecOfNu-1)) return _vecOfFDeNu(sizeVecOfNu-1);
93
94 for (int i=1; i<sizeVecOfNu; i++)
95 {
96 if(nu < _vecOfNu(i))
97 {
98 double up = _vecOfFDeNu(i) ;
99 double down = _vecOfFDeNu(i-1);
100 double xmin = _vecOfNu(i-1);
101 double xmax = _vecOfNu(i);
102 double a = ((up-down)/(xmax-xmin));
103 value = a*nu+(up-a*xmax);
104 return value;
105 }
106 }
107 return value;
108}
109
110
111
112void
113SpecRespVec::Print(ostream& os) const
114{
115
116 // os << "SpecRespVec::Print (" << typeid(*this).name()
117 //<< ") - Fmin,Fmax= " << minFreq() << "," << maxFreq() << endl;
118 os << "SpecRespVec ::Print - Fmin,Fmax= " << minFreq() << "," << maxFreq() << endl;
119 os << "MeanFreq= " << meanFreq() << " Transmission= " << transmission(meanFreq()) << endl;
120 os << "PeakFreq= " << peakFreq() << " Transmission= " << transmission(peakFreq()) << endl;
121
122}
123
124
125DECL_TEMP_SPEC /* equivalent a template <> , pour SGI-CC en particulier */
126void
127ObjFileIO<SpecRespVec>::WriteSelf(POutPersist& s) const
128{
129 if(dobj == NULL)
130 {
131 cout << " ObjFileIO<SpecRespVec>::WriteSelf:: dobj= null " << endl;
132 return;
133 }
134
135 int_4 version, nothing;
136 version = 1;
137 nothing = 0; // Reserved for future use
138 s.PutI4(version);
139 s.PutI4(nothing);
140
141 s.PutR8(dobj->minFreq());
142 s.PutR8(dobj->maxFreq());
143
144 // TVector<T> has Persistence Manager
145 s << dobj->getNuVec();
146 {
147 Vector& xv2 = dobj->getTNuVec();
148 cout << xv2 ;
149 FIO_TArray<double> vio2(&xv2);
150 vio2.Write(s);
151 }
152}
153
154DECL_TEMP_SPEC /* equivalent a template <> , pour SGI-CC en particulier */
155void
156ObjFileIO<SpecRespVec>::ReadSelf(PInPersist& s)
157{
158 int_4 version, nothing;
159 version = 1;
160 nothing = 0; // Reserved for future use
161 s.GetI4(version);
162 s.GetI4(nothing);
163
164 if(dobj == NULL)
165 {
166 dobj= new SpecRespVec();
167 ownobj= true;
168 }
169 r_8 minf, maxf;
170 s.GetR8(minf);
171 s.GetR8(maxf);
172 dobj->setMinMaxFreq(minf, maxf);
173 // TVector<T> has Persistence Manager
174 FIO_TArray<double> vio(&(dobj->getNuVec()));
175 vio.Read(s);
176 FIO_TArray<double> vio2(&(dobj->getTNuVec()));
177 vio2.Read(s);
178}
179
180
181#ifdef __CXX_PRAGMA_TEMPLATES__
182#pragma define_template ObjFileIO<SpecRespVec>
183#endif
184
185#if defined(ANSI_TEMPLATES) || defined(GNU_TEMPLATES)
186template class SOPHYA::ObjFileIO<SpecRespVec>;
187#endif
Note: See TracBrowser for help on using the repository browser.