ADDED: GMM Marginal display window
[mldemos:allopens-mldemos.git] / _AlgorithmsPlugins / GMM / interfaceGMMRegress.h
1 /*********************************************************************
2 MLDemos: A User-Friendly visualization toolkit for machine learning
3 Copyright (C) 2010  Basilio Noris
4 Contact: mldemos@b4silio.com
5
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public License,
8 version 3 as published by the Free Software Foundation.
9
10 This library is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13 Lesser General Public License for more details.
14
15 You should have received a copy of the GNU Lesser General Public
16 License along with this library; if not, write to the Free
17 Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18 *********************************************************************/
19 #ifndef _INTERFACEGMMREGRESS_H_
20 #define _INTERFACEGMMREGRESS_H_
21
22 #include <vector>
23 #include <interfaces.h>
24 #include "regressorGMR.h"
25 #include "ui_paramsGMMregr.h"
26 #include "marginalwidget.h"
27
28 class RegrGMM : public QObject, public RegressorInterface
29 {
30         Q_OBJECT
31         Q_INTERFACES(RegressorInterface)
32 private:
33         Ui::ParametersGMMRegr *params;
34     QWidget *widget;
35     MarginalWidget *marginalWidget;
36
37 public:
38         RegrGMM();
39     ~RegrGMM();
40         // virtual functions to manage the algorithm creation
41         Regressor *GetRegressor();
42         void DrawInfo(Canvas *canvas, QPainter &painter, Regressor *regressor);
43         void DrawModel(Canvas *canvas, QPainter &painter, Regressor *regressor);
44     void DrawGL(Canvas *canvas, GLWidget *glw, Regressor *regressor);
45     void DrawConfidence(Canvas *canvas, Regressor *regressor);
46
47         // virtual functions to manage the GUI and I/O
48     QString GetName(){return QString("Gaussian Mixture Regression");}
49         QString GetAlgoString();
50     QString GetInfoFile(){return "gmm.html";}
51     QWidget *GetParameterWidget(){return widget;}
52         void SetParams(Regressor *regressor);
53         void SaveOptions(QSettings &settings);
54         bool LoadOptions(QSettings &settings);
55         void SaveParams(QTextStream &stream);
56         bool LoadParams(QString name, float value);
57     void SetParams(Regressor *regressor, fvec parameters);
58     fvec GetParams();
59     void GetParameterList(std::vector<QString> &parameterNames,
60                                  std::vector<QString> &parameterTypes,
61                                  std::vector< std::vector<QString> > &parameterValues);
62
63  public slots:
64      void ShowMarginals();
65 };
66
67 #endif // _INTERFACEGMMREGRESS_H_