File indexing completed on 2024-12-22 04:18:15

0001 /***************************************************************************
0002  *                                                                         *
0003  *   copyright : (C) 2007 The University of Toronto                        *
0004  *                   netterfield@astro.utoronto.ca                         *
0005  *   copyright : (C) 2005  University of British Columbia                  *
0006  *                   dscott@phas.ubc.ca                                    *
0007  *                                                                         *
0008  *   This program is free software; you can redistribute it and/or modify  *
0009  *   it under the terms of the GNU General Public License as published by  *
0010  *   the Free Software Foundation; either version 2 of the License, or     *
0011  *   (at your option) any later version.                                   *
0012  *                                                                         *
0013  ***************************************************************************/
0014 
0015 #ifndef FITSINUSOIDWEIGHTEDPLUGIN_H
0016 #define FITSINUSOIDWEIGHTEDPLUGIN_H
0017 
0018 #include <QFile>
0019 
0020 #include <basicplugin.h>
0021 #include <dataobjectplugin.h>
0022 
0023 class FitSinusoidWeightedSource : public Kst::BasicPlugin {
0024   Q_OBJECT
0025 
0026   public:
0027     virtual QString _automaticDescriptiveName() const;
0028 
0029     Kst::VectorPtr vectorX() const;
0030     Kst::VectorPtr vectorY() const;
0031     Kst::VectorPtr vectorWeights() const;
0032     Kst::ScalarPtr scalarHarmonics() const;
0033     Kst::ScalarPtr scalarPeriod() const;
0034 
0035     virtual void change(Kst::DataObjectConfigWidget *configWidget);
0036 
0037     void setupOutputs();
0038     virtual bool algorithm();
0039 
0040     virtual QStringList inputVectorList() const;
0041     virtual QStringList inputScalarList() const;
0042     virtual QStringList inputStringList() const;
0043     virtual QStringList outputVectorList() const;
0044     virtual QStringList outputScalarList() const;
0045     virtual QStringList outputStringList() const;
0046 
0047     virtual void saveProperties(QXmlStreamWriter &s);
0048 
0049   protected:
0050     FitSinusoidWeightedSource(Kst::ObjectStore *store);
0051     ~FitSinusoidWeightedSource();
0052 
0053     virtual QString parameterName(int index) const;
0054 
0055   friend class Kst::ObjectStore;
0056 
0057 
0058 };
0059 
0060 
0061 class FitSinusoidWeightedPlugin : public QObject, public Kst::DataObjectPluginInterface {
0062     Q_OBJECT
0063     Q_INTERFACES(Kst::DataObjectPluginInterface)
0064     Q_PLUGIN_METADATA(IID "com.kst.DataObjectPluginInterface/2.0")
0065   public:
0066     virtual ~FitSinusoidWeightedPlugin() {}
0067 
0068     virtual QString pluginName() const;
0069     virtual QString pluginDescription() const;
0070 
0071     virtual DataObjectPluginInterface::PluginTypeID pluginType() const { return Fit; }
0072 
0073     virtual bool hasConfigWidget() const { return true; }
0074 
0075     virtual Kst::DataObject *create(Kst::ObjectStore *store, Kst::DataObjectConfigWidget *configWidget, bool setupInputsOutputs = true) const;
0076 
0077     virtual Kst::DataObjectConfigWidget *configWidget(QSettings *settingsObject) const;
0078 };
0079 
0080 #endif
0081 // vim: ts=2 sw=2 et