mirror of
https://github.com/jkriege2/JKQtPlotter.git
synced 2025-01-25 06:59:28 +08:00
aa2fcb108d
NEW added multithreaded example to demonstrate using JKQTBasePlotter in several parallel threads
74 lines
2.6 KiB
C++
74 lines
2.6 KiB
C++
#ifndef MULTITHREADED_THREAD_H
|
|
#define MULTITHREADED_THREAD_H
|
|
|
|
#include <QThread>
|
|
#include "jkqtplotter/jkqtpbaseplotter.h"
|
|
#include "jkqtplotter/graphs/jkqtplines.h"
|
|
#include "jkqtcommon/jkqtpmathtools.h"
|
|
#include <QElapsedTimer>
|
|
#include <QRandomGenerator>
|
|
#include <QObject>
|
|
#include <QDir>
|
|
#include <QString>
|
|
|
|
class PlottingThread: public QThread {
|
|
Q_OBJECT
|
|
public:
|
|
inline PlottingThread(const QString& filenamepart, int plotindex, int NUM_GRAPHS, int NUM_DATAPOINTS, QObject* parent):
|
|
QThread(parent),
|
|
m_plotindex(plotindex),
|
|
m_runtimeNanoseconds(0),
|
|
m_filenamepart(filenamepart),
|
|
m_filename(),
|
|
m_NUM_GRAPHS(NUM_GRAPHS),
|
|
m_NUM_DATAPOINTS(NUM_DATAPOINTS)
|
|
{}
|
|
|
|
inline static QString plotAndSave(const QString& filenamepart, int plotIndex, int NUM_GRAPHS, int NUM_DATAPOINTS, double* runtimeNanoseconds=nullptr) {
|
|
QElapsedTimer timer;
|
|
timer.start();
|
|
const QString filename=QDir(QDir::tempPath()).absoluteFilePath(QString("testimg_%1_%2.png").arg(filenamepart).arg(plotIndex));
|
|
JKQTBasePlotter plot(true);
|
|
|
|
const size_t colX=plot.getDatastore()->addLinearColumn(NUM_DATAPOINTS, 0, 10, "x");
|
|
QRandomGenerator rng;
|
|
for (int i=0; i<NUM_GRAPHS; i++) {
|
|
JKQTPXYLineGraph* g;
|
|
plot.addGraph(g=new JKQTPXYLineGraph(&plot));
|
|
g->setXColumn(colX);
|
|
g->setYColumn(plot.getDatastore()->addColumnCalculatedFromColumn(colX, [&](double x) { return cos(x+double(i)/8.0*JKQTPSTATISTICS_PI)+rng.generateDouble()*0.2-0.1;}));
|
|
g->setTitle(QString("Plot %1: $f(x)=\\cos\\leftx+\\frac{%1\\pi}{8}\\right)").arg(i+1));
|
|
g->setDrawLine(true);
|
|
g->setSymbolType(JKQTPNoSymbol);
|
|
|
|
}
|
|
plot.setPlotLabel(QString("Test Plot %1").arg(plotIndex+1));
|
|
plot.getXAxis()->setAxisLabel("x-axis");
|
|
plot.getYAxis()->setAxisLabel("y-axis");
|
|
plot.zoomToFit();
|
|
plot.saveAsPixelImage(filename, false, "PNG");
|
|
|
|
if (runtimeNanoseconds) *runtimeNanoseconds=timer.nsecsElapsed();
|
|
return filename;
|
|
}
|
|
inline double getRuntimeNanosends() const {
|
|
return m_runtimeNanoseconds;
|
|
}
|
|
inline QString getFilename() const {
|
|
return m_filename;
|
|
}
|
|
protected:
|
|
inline virtual void run() {
|
|
m_filename=plotAndSave(m_filenamepart, m_plotindex, m_NUM_GRAPHS, m_NUM_DATAPOINTS, &m_runtimeNanoseconds);
|
|
}
|
|
|
|
int m_plotindex;
|
|
double m_runtimeNanoseconds;
|
|
QString m_filename;
|
|
QString m_filenamepart;
|
|
const int m_NUM_GRAPHS;
|
|
const int m_NUM_DATAPOINTS;
|
|
};
|
|
|
|
#endif // MULTITHREADED_THREAD_H
|