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