1 | #ifndef RACQUPROC_H_SEEN
|
---|
2 | #define RACQUPROC_H_SEEN
|
---|
3 |
|
---|
4 | //----------------------------------------------------------------
|
---|
5 | // ---- classe de thread de traitememt acquisition BAORadio -----
|
---|
6 | // LAL - R. Ansari - 2008-2010
|
---|
7 | // A/ Juin 2008 - Juin 2009
|
---|
8 | // Classes DataProc, DataProc2C, DataProcFFT2C avec des
|
---|
9 | // threads de traitement mono-fibre
|
---|
10 | // B/ Novembre 2009
|
---|
11 | // MonitorProc : Classe de traitement pour monitoring multifibres
|
---|
12 | //----------------------------------------------------------------
|
---|
13 |
|
---|
14 |
|
---|
15 | #include "racqumem.h"
|
---|
16 | #include <string>
|
---|
17 | #include <vector>
|
---|
18 | #include <iostream>
|
---|
19 | #include "sopnamsp.h"
|
---|
20 | #include "zthread.h"
|
---|
21 | #include "tmatrix.h"
|
---|
22 |
|
---|
23 | #include "brtypes.h"
|
---|
24 | #include "brparam.h"
|
---|
25 |
|
---|
26 | using namespace std;
|
---|
27 |
|
---|
28 | // Quelques definitions globales
|
---|
29 | // Nombre maximum de fibres geres par les classes MonitorProc
|
---|
30 | #ifndef MAXNBFIB
|
---|
31 | #define MAXNBFIB 4
|
---|
32 | #endif
|
---|
33 |
|
---|
34 | //---------------------------------------------------------------------
|
---|
35 | // Classe thread de traitement/monitoring multifibre Raw/FFT
|
---|
36 | //---------------------------------------------------------------------
|
---|
37 | class MonitorProc : public ZThread {
|
---|
38 | public:
|
---|
39 | MonitorProc(RAcqMemZoneMgr& mem);
|
---|
40 | virtual ~MonitorProc();
|
---|
41 | virtual void run();
|
---|
42 | void Stop();
|
---|
43 | inline void STOP() { stop_ = true; }
|
---|
44 | protected:
|
---|
45 | int procData2C(ofstream& logf);
|
---|
46 | int procData1C(ofstream& logf);
|
---|
47 | int CheckFrameCounters();
|
---|
48 |
|
---|
49 | RAcqMemZoneMgr& memgr;
|
---|
50 | BRParList par_;
|
---|
51 | bool stop_;
|
---|
52 | uint_4 nmax_; // Nombre maxi de blocs MemZone traites
|
---|
53 | uint_4 step_; // 1/step_ paquet traite ds chaque bloc
|
---|
54 | uint_4 nmean_; // Nombre de blocs pour le calcul des moyennes
|
---|
55 | string path_;
|
---|
56 | uint_4 nfiles_;
|
---|
57 | TMatrix<r_4> spectre_;
|
---|
58 | vector<uint_4> nzm_;
|
---|
59 | uint_4 nblocproc_; // nombre total de bloc MemMgr traites
|
---|
60 | uint_8 nprocpaq_; // nombre de paquets traites entre deux mises a zero
|
---|
61 | uint_8 npaqsamefc_; // nombre de paquets avec meme framecounter entre deux mises a zero
|
---|
62 | uint_8 totnprocpaq_; // nombre de paquets traites entre deux mises a zero
|
---|
63 | uint_8 totnpaqsamefc_; // nombre de paquets avec meme framecounter entre deux mises a zero
|
---|
64 | TMatrix<uint_8> curfc_; // Numeros de FrameCounter dans le bloc
|
---|
65 | TMatrix<uint_1> cpaqok_; // Paquets OK ou pas dans le bloc
|
---|
66 | };
|
---|
67 |
|
---|
68 |
|
---|
69 | //-------------------------------------------------------------------
|
---|
70 | //-------- Premieres version - pour tmtacq.cc
|
---|
71 | //-------------------------------------------------------------------
|
---|
72 | //-------------------------------------------------------------------
|
---|
73 | // Classe thread de traitement avec 1 voie par frame (donnees brutes)
|
---|
74 | //-------------------------------------------------------------------
|
---|
75 | class DataProc : public ZThread {
|
---|
76 | public:
|
---|
77 | DataProc(RAcqMemZoneMgr& mem, string& path, uint_4 nmean=1, uint_4 step=1, uint_4 nmax=100);
|
---|
78 | virtual void run();
|
---|
79 | void Stop();
|
---|
80 | inline void STOP() { stop_ = true; }
|
---|
81 |
|
---|
82 | protected:
|
---|
83 | RAcqMemZoneMgr& memgr;
|
---|
84 | bool stop_;
|
---|
85 | uint_4 nmax_; // Nombre maxi de blocs MemZone traites
|
---|
86 | uint_4 step_; // 1/step_ frame traite ds chaque bloc
|
---|
87 | uint_4 nmean_; // Nombre de blocs pour le calcul des moyennes
|
---|
88 | string path_;
|
---|
89 | struct sigaction act;
|
---|
90 | };
|
---|
91 |
|
---|
92 | //---------------------------------------------------------------------
|
---|
93 | // Classe thread de traitement avec 2 voies par frame (donnees brutes)
|
---|
94 | //---------------------------------------------------------------------
|
---|
95 | class DataProc2C : public ZThread {
|
---|
96 | public:
|
---|
97 | DataProc2C(RAcqMemZoneMgr& mem, string& path, uint_4 nmean=1, uint_4 step=1, uint_4 nmax=100);
|
---|
98 | virtual void run();
|
---|
99 | void Stop();
|
---|
100 | inline void STOP() { stop_ = true; }
|
---|
101 | protected:
|
---|
102 | RAcqMemZoneMgr& memgr;
|
---|
103 | bool stop_;
|
---|
104 | uint_4 nmax_; // Nombre maxi de blocs MemZone traites
|
---|
105 | uint_4 step_; // 1/step_ frame traite ds chaque bloc
|
---|
106 | uint_4 nmean_; // Nombre de blocs pour le calcul des moyennes
|
---|
107 | string path_;
|
---|
108 | };
|
---|
109 |
|
---|
110 | //---------------------------------------------------------------------
|
---|
111 | // Classe thread de traitement donnees FFT avec 2 voies par frame
|
---|
112 | //---------------------------------------------------------------------
|
---|
113 | class DataProcFFT2C : public ZThread {
|
---|
114 | public:
|
---|
115 | DataProcFFT2C(RAcqMemZoneMgr& mem, string& path, uint_4 nmean=1, uint_4 step=1, uint_4 nmax=100);
|
---|
116 | virtual void run();
|
---|
117 | void Stop();
|
---|
118 | inline void STOP() { stop_ = true; }
|
---|
119 | protected:
|
---|
120 | RAcqMemZoneMgr& memgr;
|
---|
121 | bool stop_;
|
---|
122 | uint_4 nmax_; // Nombre maxi de blocs MemZone traites
|
---|
123 | uint_4 step_; // 1/step_ frame traite ds chaque bloc
|
---|
124 | uint_4 nmean_; // Nombre de blocs pour le calcul des moyennes
|
---|
125 | string path_;
|
---|
126 | };
|
---|
127 |
|
---|
128 | #endif
|
---|