GeopsyCore/StationProcessSignals.h
Go to the documentation of this file.
00001 /***************************************************************************
00002 **
00003 **  This file is part of GeopsyCore.
00004 **
00005 **  This library is free software; you can redistribute it and/or
00006 **  modify it under the terms of the GNU Lesser General Public
00007 **  License as published by the Free Software Foundation; either
00008 **  version 2.1 of the License, or (at your option) any later version.
00009 **
00010 **  This file is distributed in the hope that it will be useful, but WITHOUT
00011 **  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
00012 **  FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
00013 **  License for more details.
00014 **
00015 **  You should have received a copy of the GNU Lesser General Public
00016 **  License along with this library; if not, write to the Free Software
00017 **  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
00018 **
00019 **  See http://www.geopsy.org for more information.
00020 **
00021 **  Created : 2008-02-21
00022 **  Authors :
00023 **    Marc Wathelet
00024 **    Marc Wathelet (LGIT, Grenoble, France)
00025 **
00026 ***************************************************************************/
00027 
00028 #ifndef STATIONPROCESSSIGNALS_H
00029 #define STATIONPROCESSSIGNALS_H
00030 
00031 #include "GeopsyCoreDLLExport.h"
00032 #include "StationSignals.h"
00033 
00034 namespace GeopsyCore {
00035 
00036 class GEOPSYCORE_EXPORT StationProcessSignals
00037 {
00038   TRANSLATIONS("StationProcessSignals")
00039 public:
00040   StationProcessSignals(const StationSignals * originalSignals);
00041   virtual ~StationProcessSignals();
00042 
00043   int nComponents() const {return _originals->nComponents();}
00044   const StationSignals * originalSignals() const {return _originals;}
00045 
00046   void setHighPassFilter(double frequency);
00047 
00048   virtual void setProcessed(const TimeRange& tw, AbstractParameters * param)=0;
00049   DoubleSignal * processed (int iComp) const {return _signals[iComp].processed;}
00050   DoubleSignal *& processed(int iComp) {return _signals[iComp].processed;}
00051   const double * processedSamples(int iComp) {return _signals[iComp].processedSamples;}
00052 
00053   bool lockSamples();
00054   void unlockSamples();
00055 
00056 protected:
00057   void copyOriginalSignal(int iComp, const TimeRange& tw);
00058 private:
00059   const StationSignals * _originals;
00060   class ComponentSignals {
00061   public:
00062     ComponentSignals() {processed=0; merged=0; filtered=0;processedSamples=0;}
00063     QList<DoubleSignal *> * merged;
00064     QList<DoubleSignal *> * filtered;
00065     DoubleSignal * processed;
00066     const double * processedSamples;
00067   };
00068   ComponentSignals * _signals;
00069 
00070   bool setKeep(int iComp, const TimeRange& tw, const WindowingParameters& param, int stationIndex);
00071 };
00072 
00073 } // namespace GeopsyCore
00074 
00075 #endif // STATIONPROCESSSIGNALS_H
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Defines