File: Statistics.cpp

package info (click to toggle)
camitk 6.0.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 389,496 kB
  • sloc: cpp: 103,476; sh: 2,448; python: 1,618; xml: 984; makefile: 128; perl: 84; sed: 20
file content (107 lines) | stat: -rw-r--r-- 3,814 bytes parent folder | download
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
/*****************************************************************************
 * $CAMITK_LICENCE_BEGIN$
 *
 * CamiTK - Computer Assisted Medical Intervention ToolKit
 * (c) 2001-2025 Univ. Grenoble Alpes, CNRS, Grenoble INP - UGA, TIMC, 38000 Grenoble, France
 *
 * Visit http://camitk.imag.fr for more information
 *
 * This file is part of CamiTK.
 *
 * CamiTK is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License version 3
 * only, as published by the Free Software Foundation.
 *
 * CamiTK is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License version 3 for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * version 3 along with CamiTK.  If not, see <http://www.gnu.org/licenses/>.
 *
 * $CAMITK_LICENCE_END$
 ****************************************************************************/

#include "Statistics.h"

#include "MMLMonitorDisplayFactory.h"
#include "MMLDisplay.h"
#include "MMLComponent.h"

#include <monitoringgui/MonitoringGuiManager.h>
#include <monitoringgui/MonitoringDialog.h>

#include <QHeaderView>

bool statisticsRegistered = MMLMonitorDisplayFactory::getInstance()->registerClass<Statistics>("Statistics", Monitor::SCALARSET);

Statistics::Statistics(Monitor* monitor, MMLComponent* manager): MMLMonitorDisplay(monitor, manager) {
    QTableWidget* t = manager->getMonitoringGuiManager()->getDialog()->getMonitorsTableWidget();
    line = manager->getDisplay()->getDisplayedMonitorLine();
    int j = t->columnCount();
    oldRowSize = t->rowHeight(line);
    t->setColumnCount(j + 1);
    auto* item = new QTableWidgetItem();
    item->setText(("Statistics"));
    t->setHorizontalHeaderItem(j, item);
    table = new QTableWidget;
    table->setEditTriggers(QAbstractItemView::NoEditTriggers);
    t->setCellWidget(line, j, table);
}

Statistics::~Statistics() {
    //if (table)
    //  delete table;
}

// ---------------------- update ----------------------------
void Statistics::update() {
    table->clear();
    QTableWidget* t = manager->getMonitoringGuiManager()->getDialog()->getMonitorsTableWidget();
    QString s;
    table->setColumnCount(3);
    table->setRowCount(1);
    auto* item1 = new QTableWidgetItem();
    item1->setText(tr("minimum"));
    table->setHorizontalHeaderItem(0, item1);
    auto* item2 = new QTableWidgetItem();
    item2->setText(tr("maximum"));
    table->setHorizontalHeaderItem(1, item2);
    auto* item3 = new QTableWidgetItem();
    item3->setText(tr("average"));
    table->setHorizontalHeaderItem(2, item3);
    table->verticalHeader()->hide();
    t->setRowHeight(line, 3 * table->rowHeight(0));

    double min = monitor->getValue(0);
    double max = monitor->getValue(0);
    double sum = 0;
    for (unsigned int i = 0; i < monitor->getNumberOfValues(); i++) {
        double val = monitor->getValue(i);
        if (min > val) {
            min = val;
        }
        if (max < val) {
            max = val;
        }
        sum += val;
    }
    table->setItem(0, 0, new QTableWidgetItem(s.setNum(min)));
    table->setItem(0, 1, new QTableWidgetItem(s.setNum(max)));
    if (monitor->getNumberOfValues() > 0) {
        table->setItem(0, 2, new QTableWidgetItem(s.setNum(sum / monitor->getNumberOfValues())));
    }

}

// ---------------------- hide ----------------------------
void Statistics::hide() {
    table->clear();
    QTableWidget* t = manager->getMonitoringGuiManager()->getDialog()->getMonitorsTableWidget();
    int i = t->columnCount();
    t->removeColumn(i - 1);
    t->setColumnCount(i - 1);
    t->setRowHeight(line, oldRowSize);
}