SpkDiarMonitor.h
2.9 KB
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#ifndef SPKDIARMONITOR_H
#define SPKDIARMONITOR_H
#include <QWidget>
#include <QGroupBox>
#include <QCheckBox>
#include <QRadioButton>
#include <QLabel>
#include <QTextEdit>
#include <armadillo>
#include "UtteranceTreeWidget.h"
class SpkDiarMonitor: public QWidget
{
Q_OBJECT
public:
SpkDiarMonitor(int treeWidth = 480, int treeHeight = 200, bool global = false, QWidget *parent = 0);
void exportResults();
public slots:
void setDiarData(const arma::mat &E, const arma::mat &Sigma, const arma::mat &W);
void setSpks(QList<int> spkIdx);
void setSpeakers(QList<QString> speakers, QMap<QString, qreal> spkWeight);
void getCurrentPattern(const QList<QPair<int, qreal>> &subFeatures);
void getPatternFirstShot(const QList<QPair<int, qreal>> &subFeatures);
void getPatternSecondShot(const QList<QPair<int, qreal>> &subFeatures);
void activL2();
void activMahal();
void activSigmaInv();
void activWInv();
void normalizeVectors(bool checked);
void activMin();
void activMax();
void activMean();
void activWard();
void activSilhouette();
void activBipartition();
void weightInstances(bool);
void playSubtitle(QList<int> utter);
void currentSubtitle(int subIdx);
void constrainClustering(bool checked);
void releasePosition(bool released);
void setLocalDer(const QString &score);
void setGlobalDer(const QString &score);
signals:
void updateUtteranceTree(const arma::mat &S, const arma::mat &W, const arma::umat &V, const arma::mat &SigmaInv);
void updateUtteranceTreeShot1(const arma::mat &S, const arma::mat &W, const arma::umat &V, const arma::mat &SigmaInv);
void updateUtteranceTreeShot2(const arma::mat &S, const arma::mat &W, const arma::umat &V, const arma::mat &SigmaInv);
void clearUtteranceTree();
void setDistance(UtteranceTree::DistType dist);
void setCovInv(const arma::mat &SigmaInv);
void normVectors(bool checked);
void setAgrCrit(UtteranceTree::AgrCrit agr);
void setPartitionMethod(UtteranceTree::PartMeth partMeth);
void setWeight(const arma::mat &W);
void playSub(QList<int> utter);
void currSubtitle(int subIdx);
void setDiff(const arma::mat &Diff);
void setSpeakerPartition(QList<QList<int>> partition);
void releasePos(bool released);
private:
QVector<QString> m_speakers;
QMap<QString, qreal> m_spkWeight;
QLabel *m_locDer;
QLabel *m_globDer;
QTextEdit *m_spks;
QRadioButton *m_l2;
QRadioButton *m_mahal;
QGroupBox *m_covBox;
QCheckBox *m_norm;
UtteranceTreeWidget *m_utterTree;
UtteranceTreeWidget *m_utterTreeShot1;
UtteranceTreeWidget *m_utterTreeShot2;
QCheckBox *m_weight;
arma::mat E;
arma::mat CovInv;
arma::mat SigmaInv;
arma::mat WInv;
QList<QPair<int, qreal>> m_currSubFeatures;
QList<QPair<int, qreal>> m_currSubFeaturesShot1;
QList<QPair<int, qreal>> m_currSubFeaturesShot2;
};
#endif