QGpCoreWave/AutocorrCurves.h
Go to the documentation of this file.
00001 /***************************************************************************
00002 **
00003 **  This file is part of QGpCoreWave.
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 : 2007-05-22
00022 **  Authors :
00023 **    Marc Wathelet
00024 **    Marc Wathelet (LGIT, Grenoble, France)
00025 **
00026 ***************************************************************************/
00027 
00028 #ifndef AUTOCORRCURVES_H
00029 #define AUTOCORRCURVES_H
00030 
00031 #include <QGpCoreTools.h>
00032 #include "AutocorrRing.h"
00033 #include "ModalCurve.h"
00034 #include "QGpCoreWaveDLLExport.h"
00035 
00036 namespace QGpCoreWave {
00037 
00038 class QGPCOREWAVE_EXPORT AutocorrCurves : public XMLClass
00039 {
00040   TRANSLATIONS("AutocorrCurves");
00041 public:
00042 
00043   virtual const QString& xml_tagName() const {return xmlAutocorrCurvesTag;}
00044   static const QString xmlAutocorrCurvesTag;
00045 
00046   bool isEmpty() const {return _curves.isEmpty();}
00047   int ringCount() const {return _rings.count();}
00048   void addRing() {addRing(AutocorrRing());}
00049   void addRing(const AutocorrRing& r);
00050   void removeRing(int index);
00051   void add(const AutocorrCurves& curves);
00052   void sort();
00053 
00054   const AutocorrRing& ring(int index) const {return _rings[index];}
00055   AutocorrRing& ring(int index) {return _rings[index];}
00056   int indexOf(const AutocorrRing& r) const {return _rings.indexOf(r);}
00057   const QVector<AutocorrRing> * rings() const {return &_rings;}
00058 
00059   void addCurve(const ModalCurve& c);
00060   const QList<ModalCurve>& curves() const {return _curves;}
00061   QList<ModalCurve>& curves() {return _curves;}
00062   ModalCurve& lastCurve() {return _curves.last();}
00063   ModalCurve dispersionCurve(int index, double kmin, double kmax, int maxSolutionCount) const;
00064 
00065   QList<ModalCurve> ringCurves(int index) const;
00066 protected:
00067   void xml_writeChildren(XML_WRITECHILDREN_ARGS) const;
00068   XMLMember xml_member(XML_MEMBER_ARGS);
00069 private:
00070   QList<ModalCurve> _curves;
00071   QVector<AutocorrRing> _rings;
00072 };
00073 
00074 } // namespace QGpCoreWave
00075 
00076 #endif // AUTOCORRCURVES_H
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Defines