optimize includes

main
Benjamin Kraft 1 year ago
parent e2bf29bf75
commit df169be295
  1. 3
      src/GLWidget.cpp
  2. 1
      src/MainWindow.cpp
  3. 5
      src/MainWindow.h
  4. 42
      src/Simulation.cpp
  5. 11
      src/Simulation.h
  6. 2
      src/Slider.h

@ -9,6 +9,7 @@
#include "Overlay.h" #include "Overlay.h"
#include <QOpenGLShaderProgram> #include <QOpenGLShaderProgram>
#include "FPS.h" #include "FPS.h"
#include "Pendulum.h"
GLWidget::GLWidget(Simulation * simulation) : simulation(simulation) { GLWidget::GLWidget(Simulation * simulation) : simulation(simulation) {
startTimer(1000 / 144); startTimer(1000 / 144);
@ -186,6 +187,7 @@ void GLWidget::uploadStaticDataToGPU() {
} }
void GLWidget::changePosition() { void GLWidget::changePosition() {
auto t1 = system_clock::now();
glBindBuffer(GL_ARRAY_BUFFER, positionVBO); glBindBuffer(GL_ARRAY_BUFFER, positionVBO);
auto positions = (GLfloat*) glMapBufferRange(GL_ARRAY_BUFFER, 0, GLsizeiptr(positionCount * sizeof(float)), GL_MAP_WRITE_BIT); auto positions = (GLfloat*) glMapBufferRange(GL_ARRAY_BUFFER, 0, GLsizeiptr(positionCount * sizeof(float)), GL_MAP_WRITE_BIT);
size_t index = 0; size_t index = 0;
@ -198,6 +200,7 @@ void GLWidget::changePosition() {
} }
} }
glUnmapBuffer(GL_ARRAY_BUFFER); glUnmapBuffer(GL_ARRAY_BUFFER);
// std::cout << duration_cast<microseconds>(system_clock::now() - t1).count() << std::endl;
simulation->semaphore.release(); simulation->semaphore.release();
} }

@ -17,6 +17,7 @@
#include <QCloseEvent> #include <QCloseEvent>
#include <QTimer> #include <QTimer>
#include "Overlay.h" #include "Overlay.h"
#include "Slider.h"
MainWindow::MainWindow() { MainWindow::MainWindow() {
simulationThread = new QThread(this); simulationThread = new QThread(this);

@ -1,11 +1,12 @@
#include <QWidget> #include <QWidget>
#include <vector> #include <vector>
#include "Slider.h"
#include "Pendulum.h" #include "Pendulum.h"
class Simulation; class Simulation;
class QGridLayout; class QGridLayout;
class GLWidget; class GLWidget;
template<typename T>
class Slider;
enum Property {Angle, Mass, Length}; enum Property {Angle, Mass, Length};
@ -38,7 +39,7 @@ private:
QGridLayout * segmentGrid {}; QGridLayout * segmentGrid {};
Slider<double> * gravitySlider = nullptr, * timescaleSlider = nullptr; Slider<double> * gravitySlider = nullptr, * timescaleSlider = nullptr;
Slider<> * substepsSlider = nullptr; Slider<int> * substepsSlider = nullptr;
signals: signals:
void pendulaCreated(const std::vector<Pendulum*> &add); void pendulaCreated(const std::vector<Pendulum*> &add);

@ -5,6 +5,7 @@
#include <omp.h> #include <omp.h>
#include <iostream> #include <iostream>
#include "FPS.h" #include "FPS.h"
#include "Pendulum.h"
#include <QOpenGLContext> #include <QOpenGLContext>
#include <QOpenGLShaderProgram> #include <QOpenGLShaderProgram>
#include <QOffscreenSurface> #include <QOffscreenSurface>
@ -12,7 +13,6 @@
Simulation::Simulation() { Simulation::Simulation() {
ups = new FPS; ups = new FPS;
ups->setUpdateInterval(100); ups->setUpdateInterval(100);
timer = new QTimer(this); timer = new QTimer(this);
QTimer::connect(timer, &QTimer::timeout, this, &Simulation::update); QTimer::connect(timer, &QTimer::timeout, this, &Simulation::update);
timer->setInterval(updateInterval); timer->setInterval(updateInterval);
@ -33,19 +33,23 @@ void Simulation::initialize() {
initializeOpenGLFunctions(); initializeOpenGLFunctions();
} }
int maxWorkGroupCount[3]; // Read GPU Limits
int maxWorkGroupSize[3]; {
int maxWorkGroupInvocations;
for (int i = 0; i < 3; i++){ for (int i = 0; i < 3; i++){
glGetIntegeri_v(GL_MAX_COMPUTE_WORK_GROUP_COUNT, i, maxWorkGroupCount + i); glGetIntegeri_v(GL_MAX_COMPUTE_WORK_GROUP_COUNT, i, gpuLimits.maxWGCount + i);
glGetIntegeri_v(GL_MAX_COMPUTE_WORK_GROUP_SIZE, i, maxWorkGroupSize + i); glGetIntegeri_v(GL_MAX_COMPUTE_WORK_GROUP_SIZE, i, gpuLimits.maxWGSize + i);
} }
glGetIntegerv(GL_MAX_COMPUTE_WORK_GROUP_INVOCATIONS, &maxWorkGroupInvocations); glGetIntegerv(GL_MAX_COMPUTE_WORK_GROUP_INVOCATIONS, &gpuLimits.maxWGInvocations);
printf("Max work group count: (%d, %d, %d)\n", gpuLimits.maxWGCount[0], gpuLimits.maxWGCount[1], gpuLimits.maxWGCount[2]);
printf("Max work group size: (%d, %d, %d)\n", gpuLimits.maxWGSize[0], gpuLimits.maxWGSize[1], gpuLimits.maxWGSize[2]);
printf("Max work group invocations (x * y * z): %d\n", gpuLimits.maxWGInvocations);
}
// Shader
{
printf("Max work group count: (%d, %d, %d)\n", maxWorkGroupCount[0], maxWorkGroupCount[1], maxWorkGroupCount[2]); }
printf("Max work group size: (%d, %d, %d)\n", maxWorkGroupSize[0], maxWorkGroupSize[1], maxWorkGroupSize[2]);
printf("Max work group invocations (x * y * z): %d\n", maxWorkGroupInvocations);
} }
@ -62,6 +66,11 @@ void Simulation::update() {
double newPotentialEnergy = 0; double newPotentialEnergy = 0;
double newKineticEnergy = 0; double newKineticEnergy = 0;
// OLD with CPUs
{
#pragma omp parallel for #pragma omp parallel for
for (int i = 0; i < pendula.size(); i++){ // NOLINT(*-loop-convert) // not ranged based for msvc for (int i = 0; i < pendula.size(); i++){ // NOLINT(*-loop-convert) // not ranged based for msvc
for (int k = 0; k < substeps; k++) for (int k = 0; k < substeps; k++)
@ -73,6 +82,13 @@ void Simulation::update() {
#pragma omp atomic #pragma omp atomic
newKineticEnergy += localKineticEnergy; newKineticEnergy += localKineticEnergy;
} }
}
// NEW with GPUs
{
}
potentialEnergy = newPotentialEnergy; potentialEnergy = newPotentialEnergy;
kineticEnergy = newKineticEnergy; kineticEnergy = newKineticEnergy;
@ -92,6 +108,7 @@ void Simulation::clearPendula() {
pendula.shrink_to_fit(); pendula.shrink_to_fit();
updateEnergy(); updateEnergy();
updateGPUData();
emit layoutChanged(); emit layoutChanged();
} }
@ -103,6 +120,7 @@ void Simulation::addPendula(const std::vector<Pendulum *> &add) {
pendula.push_back(p); pendula.push_back(p);
updateEnergy(); updateEnergy();
updateGPUData();
emit layoutChanged(); emit layoutChanged();
} }
@ -115,3 +133,7 @@ void Simulation::updateEnergy() {
} }
} }
void Simulation::updateGPUData() {
}

@ -2,12 +2,12 @@
#include <cstdint> #include <cstdint>
#include <QObject> #include <QObject>
#include <chrono> #include <chrono>
#include "Pendulum.h"
#include <semaphore> #include <semaphore>
#include <QOpenGLFunctions_4_3_Core> #include <QOpenGLFunctions_4_3_Core>
class QTimer;
class FPS; class FPS;
class Pendulum;
class QOpenGLShaderProgram;
class Simulation : public QObject, protected QOpenGLFunctions_4_3_Core { class Simulation : public QObject, protected QOpenGLFunctions_4_3_Core {
Q_OBJECT Q_OBJECT
@ -40,6 +40,13 @@ public slots:
private slots: private slots:
void update(); void update();
private: private:
void updateGPUData();
struct GPULimits {
int maxWGCount[3];
int maxWGSize[3];
int maxWGInvocations;
} gpuLimits;
QOpenGLShaderProgram * program;
QTimer * timer; QTimer * timer;
int updateInterval = 16; int updateInterval = 16;
}; };

@ -1,3 +1,5 @@
#pragma once
#include <QSlider> #include <QSlider>
#include <functional> #include <functional>
#include <QLabel> #include <QLabel>

Loading…
Cancel
Save