1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
|
#ifndef INTERFACEGHSOM_H
#define INTERFACEGHSOM_H
#include <vector>
#include <interfaces.h>
#include "ui_paramsGHSOM.h"
class GHSOMProjector : public QObject, public ProjectorInterface
{
Q_OBJECT
Q_INTERFACES(ProjectorInterface)
private:
Ui::paramsGHSOM *params;
QWidget *widget;
public:
GHSOMProjector();
~GHSOMProjector();
// virtual functions to manage the algorithm creation
Projector *GetProjector();
void DrawInfo(Canvas *canvas, QPainter &painter, Projector *projector);
void DrawModel(Canvas *canvas, QPainter &painter, Projector *projector);
void DrawGL(Canvas *canvas, GLWidget *glw, Projector *projector);
// virtual functions to manage the GUI and I/O
QString GetName(){return QString("Self Organizing Maps");}
QString GetAlgoString();
QString GetInfoFile(){return "ghsom.html";}
QWidget *GetParameterWidget(){return widget;}
void SetParams(Projector *projector);
void SaveOptions(QSettings &settings);
bool LoadOptions(QSettings &settings);
void SaveParams(QTextStream &stream);
bool LoadParams(QString name, float value);
void SetParams(Projector *projector, fvec parameters);
fvec GetParams();
void GetParameterList(std::vector<QString> ¶meterNames,
std::vector<QString> ¶meterTypes,
std::vector< std::vector<QString> > ¶meterValues);
public slots:
void ChangeOptions();
};
#endif // INTERFACEGHSOM_H
|