created a histogram class for 1D histogram
This commit is contained in:
parent
a3deb59e0c
commit
73c2286005
|
@ -6,76 +6,59 @@
|
||||||
#include <QStandardItemModel>
|
#include <QStandardItemModel>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
|
|
||||||
Canvas::Canvas(Digitizer ** digi, unsigned int nDigi, ReadDataThread ** readDataThread, QMainWindow * parent) : QMainWindow(parent){
|
Canvas::Canvas(Digitizer ** digi, unsigned int nDigi, QMainWindow * parent) : QMainWindow(parent){
|
||||||
|
|
||||||
this->digi = digi;
|
this->digi = digi;
|
||||||
this->nDigi = nDigi;
|
this->nDigi = nDigi;
|
||||||
this->readDataThread = readDataThread;
|
|
||||||
|
|
||||||
setWindowTitle("Canvas");
|
setWindowTitle("Canvas");
|
||||||
setGeometry(0, 0, 1000, 800);
|
setGeometry(0, 0, 1000, 800);
|
||||||
//setWindowFlags( this->windowFlags() & ~Qt::WindowCloseButtonHint );
|
//setWindowFlags( this->windowFlags() & ~Qt::WindowCloseButtonHint );
|
||||||
|
|
||||||
|
QWidget * layoutWidget = new QWidget(this);
|
||||||
|
setCentralWidget(layoutWidget);
|
||||||
|
QVBoxLayout * layout = new QVBoxLayout(layoutWidget);
|
||||||
|
layoutWidget->setLayout(layout);
|
||||||
|
|
||||||
QVector<int> data = {1, 1, 2, 2, 3, 1, 2, 4, 5, 6, 5, 3, 4, 1, 3};
|
|
||||||
double xMax = 5;
|
|
||||||
double xMin = -1;
|
|
||||||
double binSize = 0.5;
|
|
||||||
|
|
||||||
// Calculate the number of bins based on the X-axis range and bin size
|
//========================
|
||||||
int numBins = static_cast<int>((xMax - xMin) / binSize) + 1;
|
QGroupBox * controlBox = new QGroupBox("Control", this);
|
||||||
|
layout->addWidget(controlBox);
|
||||||
|
QGridLayout * ctrlLayout = new QGridLayout(controlBox);
|
||||||
|
controlBox->setLayout(ctrlLayout);
|
||||||
|
|
||||||
// Create a bar series
|
QPushButton * bnClearHist = new QPushButton("Clear Hist.", this);
|
||||||
barSeries = new QBarSeries();
|
ctrlLayout->addWidget(bnClearHist, 0, 0);
|
||||||
|
|
||||||
// Create a histogram data array with the number of bins
|
//========================
|
||||||
QVector<int> histogramData(numBins, 0);
|
QGroupBox * histBox = new QGroupBox("Histgrams", this);
|
||||||
|
layout->addWidget(histBox);
|
||||||
|
QGridLayout * histLayout = new QGridLayout(histBox);
|
||||||
|
histBox->setLayout(histLayout);
|
||||||
|
|
||||||
// Calculate the histogram bin counts
|
double xMax = 4000;
|
||||||
for (double value : data) {
|
double xMin = 0;
|
||||||
int binIndex = static_cast<int>((value - xMin) / binSize);
|
double nBin = 100;
|
||||||
if (binIndex >= 0 && binIndex < numBins) {
|
|
||||||
histogramData[binIndex]++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create bar sets and add them to the series
|
Histogram * hist = new Histogram("test", xMin, xMax, nBin);
|
||||||
for (int i = 0; i < numBins; ++i) {
|
|
||||||
double binStart = xMin + i * binSize;
|
|
||||||
double binEnd = binStart + binSize;
|
|
||||||
QString binLabel = QString("%1-%2").arg(binStart).arg(binEnd);
|
|
||||||
|
|
||||||
QBarSet *barSet = new QBarSet(binLabel);
|
hist->Fill(1);
|
||||||
*barSet << histogramData[i];
|
hist->Fill(300);
|
||||||
barSeries->append(barSet);
|
hist->Fill(350);
|
||||||
}
|
|
||||||
|
|
||||||
// Create the chart and set the series
|
TraceView * plotView = new TraceView(hist->GetTrace(), this);
|
||||||
chart = new QChart();
|
histLayout->addWidget(plotView, 0, 0);
|
||||||
chart->addSeries(barSeries);
|
|
||||||
|
|
||||||
// Create the X-axis category axis
|
|
||||||
axisX = new QBarCategoryAxis();
|
|
||||||
chart->setAxisX(axisX, barSeries);
|
|
||||||
|
|
||||||
// Create category labels for the bins
|
|
||||||
QStringList categories;
|
|
||||||
for (int i = 0; i < numBins; ++i) {
|
|
||||||
double binStart = xMin + i * binSize;
|
|
||||||
double binEnd = binStart + binSize;
|
|
||||||
QString binLabel = QString("%1-%2").arg(binStart).arg(binEnd);
|
|
||||||
categories.append(binLabel);
|
|
||||||
axisX->append(binLabel);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create a chart view and set the chart
|
|
||||||
chartView = new QChartView(chart);
|
|
||||||
chartView->setRenderHint(QPainter::Antialiasing);
|
|
||||||
|
|
||||||
// Set the chart view as the main widget
|
|
||||||
setCentralWidget(chartView);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Canvas::~Canvas(){
|
Canvas::~Canvas(){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void Canvas::UpdateCanvas(){
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -23,34 +23,23 @@
|
||||||
#include "CustomWidgets.h"
|
#include "CustomWidgets.h"
|
||||||
|
|
||||||
|
|
||||||
#include <QWidget>
|
|
||||||
#include <QChart>
|
|
||||||
#include <QChartView>
|
|
||||||
#include <QBarSeries>
|
|
||||||
#include <QBarSet>
|
|
||||||
#include <QBarCategoryAxis>
|
|
||||||
|
|
||||||
|
|
||||||
//^====================================================
|
//^====================================================
|
||||||
//^====================================================
|
//^====================================================
|
||||||
class Canvas : public QMainWindow{
|
class Canvas : public QMainWindow{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Canvas(Digitizer ** digi, unsigned int nDigi, ReadDataThread ** readDataThread, QMainWindow * parent = nullptr);
|
Canvas(Digitizer ** digi, unsigned int nDigi, QMainWindow * parent = nullptr);
|
||||||
~Canvas();
|
~Canvas();
|
||||||
|
|
||||||
|
public slots:
|
||||||
|
void UpdateCanvas();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
Digitizer ** digi;
|
Digitizer ** digi;
|
||||||
unsigned short nDigi;
|
unsigned short nDigi;
|
||||||
ReadDataThread ** readDataThread;
|
|
||||||
|
|
||||||
QChartView *chartView;
|
|
||||||
QChart *chart;
|
|
||||||
QBarSeries *barSeries;
|
|
||||||
QBarCategoryAxis *axisX;
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -13,6 +13,9 @@
|
||||||
#include <QRubberBand>
|
#include <QRubberBand>
|
||||||
#include <QMouseEvent>
|
#include <QMouseEvent>
|
||||||
#include <QGestureEvent>
|
#include <QGestureEvent>
|
||||||
|
#include <QLineSeries>
|
||||||
|
#include <QAreaSeries>
|
||||||
|
#include <QValueAxis>
|
||||||
|
|
||||||
//^====================================================
|
//^====================================================
|
||||||
class RSpinBox : public QDoubleSpinBox{
|
class RSpinBox : public QDoubleSpinBox{
|
||||||
|
@ -90,6 +93,7 @@ private:
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//^====================================================
|
||||||
class TraceView : public QChartView{
|
class TraceView : public QChartView{
|
||||||
public:
|
public:
|
||||||
TraceView(QChart * chart, QWidget * parent = nullptr): QChartView(chart, parent){
|
TraceView(QChart * chart, QWidget * parent = nullptr): QChartView(chart, parent){
|
||||||
|
@ -101,6 +105,8 @@ public:
|
||||||
m_coordinateLabel->setVisible(false);
|
m_coordinateLabel->setVisible(false);
|
||||||
m_coordinateLabel->setAlignment(Qt::AlignTop | Qt::AlignLeft);
|
m_coordinateLabel->setAlignment(Qt::AlignTop | Qt::AlignLeft);
|
||||||
setMouseTracking(true);
|
setMouseTracking(true);
|
||||||
|
|
||||||
|
setRenderHints(QPainter::Antialiasing);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SetHRange(int min, int max) {
|
void SetHRange(int min, int max) {
|
||||||
|
@ -164,7 +170,97 @@ private:
|
||||||
};
|
};
|
||||||
|
|
||||||
//^====================================================
|
//^====================================================
|
||||||
|
class Histogram {
|
||||||
|
public:
|
||||||
|
Histogram(QString title, double xMin, double xMax, int nBin){
|
||||||
|
|
||||||
|
plot = new Trace();
|
||||||
|
dataSeries = new QLineSeries();
|
||||||
|
|
||||||
|
this->xMin = xMin;
|
||||||
|
this->xMax = xMax;
|
||||||
|
this->nBin = nBin;
|
||||||
|
dX = (xMax-xMin)/nBin;
|
||||||
|
Clear();
|
||||||
|
|
||||||
|
maxBin = -1;
|
||||||
|
maxBinValue = 0;
|
||||||
|
|
||||||
|
//dataSeries->setPen(QPen(Qt::blue, 1));
|
||||||
|
areaSeries = new QAreaSeries(dataSeries);
|
||||||
|
areaSeries->setName(title);
|
||||||
|
areaSeries->setBrush(Qt::blue);
|
||||||
|
|
||||||
|
plot->addSeries(areaSeries);
|
||||||
|
|
||||||
|
plot->setAnimationDuration(1); // msec
|
||||||
|
plot->setAnimationOptions(QChart::NoAnimation);
|
||||||
|
plot->createDefaultAxes();
|
||||||
|
|
||||||
|
QValueAxis * xaxis = qobject_cast<QValueAxis*> (plot->axes(Qt::Horizontal).first());
|
||||||
|
xaxis->setRange(xMin, xMax);
|
||||||
|
xaxis->setTickCount( nBin + 1 > 11 ? 11 : nBin + 1);
|
||||||
|
//xaxis->setLabelFormat("%.1f");
|
||||||
|
//xaxis->setTitleText("Time [ns]");
|
||||||
|
|
||||||
|
}
|
||||||
|
~Histogram(){
|
||||||
|
delete areaSeries;
|
||||||
|
delete dataSeries;
|
||||||
|
delete plot;
|
||||||
|
}
|
||||||
|
|
||||||
|
Trace * GetTrace() { return plot;}
|
||||||
|
|
||||||
|
void Clear(){
|
||||||
|
for( int i = 0; i <= nBin; i++) {
|
||||||
|
dataSeries->append(xMin + i * dX, 0 );
|
||||||
|
dataSeries->append(xMin + i * dX, 0 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetColor(Qt::GlobalColor color){ areaSeries->setBrush(color);}
|
||||||
|
|
||||||
|
void Fill(double value){
|
||||||
|
|
||||||
|
double bin = (value - xMin)/dX;
|
||||||
|
if( bin < 0 || bin >= nBin ) return;
|
||||||
|
|
||||||
|
int index1 = 2*qFloor(bin) + 1;
|
||||||
|
int index2 = index1 + 1;
|
||||||
|
|
||||||
|
QPointF point1 = dataSeries->at(index1);
|
||||||
|
dataSeries->replace(index1, point1.x(), point1.y() + 1);
|
||||||
|
|
||||||
|
QPointF point2 = dataSeries->at(index2);
|
||||||
|
dataSeries->replace(index2, point2.x(), point2.y() + 1);
|
||||||
|
|
||||||
|
if( point2.y() + 1 > maxBinValue ){
|
||||||
|
maxBinValue = point2.y() + 1;
|
||||||
|
maxBin = index2/2;
|
||||||
|
}
|
||||||
|
|
||||||
|
QValueAxis * yaxis = qobject_cast<QValueAxis*> (plot->axes(Qt::Vertical).first());
|
||||||
|
//yaxis->setTickInterval(1);
|
||||||
|
yaxis->setRange(0, ((double)maxBinValue) * 1.2 );
|
||||||
|
//yaxis->setTickCount(10);
|
||||||
|
//yaxis->setLabelFormat("%.0f");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
Trace * plot;
|
||||||
|
QLineSeries * dataSeries;
|
||||||
|
QAreaSeries * areaSeries;
|
||||||
|
|
||||||
|
double dX, xMin, xMax;
|
||||||
|
int nBin;
|
||||||
|
|
||||||
|
int maxBin;
|
||||||
|
int maxBinValue;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
//^====================================================
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -12,8 +12,6 @@
|
||||||
#include <QFileDialog>
|
#include <QFileDialog>
|
||||||
#include <QScrollArea>
|
#include <QScrollArea>
|
||||||
|
|
||||||
#include "CustomWidgets.h"
|
|
||||||
|
|
||||||
MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent){
|
MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent){
|
||||||
|
|
||||||
setWindowTitle("FSU DAQ");
|
setWindowTitle("FSU DAQ");
|
||||||
|
@ -91,7 +89,7 @@ MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent){
|
||||||
leRunID->setAlignment(Qt::AlignHCenter);
|
leRunID->setAlignment(Qt::AlignHCenter);
|
||||||
|
|
||||||
chkSaveData = new QCheckBox("Save Data", this);
|
chkSaveData = new QCheckBox("Save Data", this);
|
||||||
cbAutoRun = new QComboBox(this);
|
cbAutoRun = new RComboBox(this);
|
||||||
cbAutoRun->addItem("Single Infinite", 0);
|
cbAutoRun->addItem("Single Infinite", 0);
|
||||||
cbAutoRun->addItem("Single 30 mins", 30);
|
cbAutoRun->addItem("Single 30 mins", 30);
|
||||||
cbAutoRun->addItem("Single 60 mins", 60);
|
cbAutoRun->addItem("Single 60 mins", 60);
|
||||||
|
@ -828,7 +826,7 @@ void MainWindow::OpenDigiSettings(){
|
||||||
void MainWindow::OpenCanvas(){
|
void MainWindow::OpenCanvas(){
|
||||||
|
|
||||||
if( canvas == nullptr ) {
|
if( canvas == nullptr ) {
|
||||||
canvas = new Canvas(digi, nDigi, readDataThread);
|
canvas = new Canvas(digi, nDigi);
|
||||||
canvas->show();
|
canvas->show();
|
||||||
}else{
|
}else{
|
||||||
canvas->show();
|
canvas->show();
|
||||||
|
|
3
FSUDAQ.h
3
FSUDAQ.h
|
@ -13,6 +13,7 @@
|
||||||
|
|
||||||
#include "ClassDigitizer.h"
|
#include "ClassDigitizer.h"
|
||||||
#include "CustomThreads.h"
|
#include "CustomThreads.h"
|
||||||
|
#include "CustomWidgets.h"
|
||||||
#include "Scope.h"
|
#include "Scope.h"
|
||||||
#include "DigiSettingsPanel.h"
|
#include "DigiSettingsPanel.h"
|
||||||
#include "CanvasClass.h"
|
#include "CanvasClass.h"
|
||||||
|
@ -94,7 +95,7 @@ private:
|
||||||
QLineEdit * leRunID;
|
QLineEdit * leRunID;
|
||||||
|
|
||||||
QCheckBox * chkSaveData;
|
QCheckBox * chkSaveData;
|
||||||
QComboBox * cbAutoRun;
|
RComboBox * cbAutoRun;
|
||||||
|
|
||||||
QString startComment;
|
QString startComment;
|
||||||
QString stopComment;
|
QString stopComment;
|
||||||
|
|
|
@ -150,7 +150,6 @@ Scope::Scope(Digitizer ** digi, unsigned int nDigi, ReadDataThread ** readDataTh
|
||||||
//================ Plot view
|
//================ Plot view
|
||||||
rowID ++;
|
rowID ++;
|
||||||
plotView = new TraceView(plot, this);
|
plotView = new TraceView(plot, this);
|
||||||
plotView->setRenderHints(QPainter::Antialiasing);
|
|
||||||
layout->addWidget(plotView, rowID, 0, 1, 6);
|
layout->addWidget(plotView, rowID, 0, 1, 6);
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user