fix memory issues

This commit is contained in:
Jay Robson 2024-01-30 16:09:43 +11:00
parent b0ebc29a29
commit a7ced6a773
21 changed files with 173 additions and 80 deletions

View File

@ -4,7 +4,7 @@
#include "camera.hpp"
#include "input/keyboard.hpp"
#include "../math.hpp"
#include "../util/math.hpp"
#include <cmath>
#include <iostream>
@ -75,7 +75,11 @@ void camera::update(const system& sys, double dt)
velocity.z += 3.5;
}
glm::vec<3, double> velocity2 = sys.scene.check_intersect(pos, velocity * dt) / dt;
glm::vec<3, double> normal_last(0);
glm::vec<3, double> velocity2;
velocity2 = sys.scene.calc_intersect(pos, velocity * dt, normal_last);
velocity2 = sys.scene.calc_intersect(pos + glm::vec<3, double>(0, 0, -1.5), velocity2, normal_last) / dt;
pos += velocity2 * dt;
on_ground = ((velocity * dt / dt).z != velocity2.z);

View File

@ -89,6 +89,8 @@ void font::init()
chars[i] = c;
}
FT_Done_FreeType(ft);
}
void mesh::load_text(const char* text, double size)

View File

@ -73,6 +73,11 @@ void glmesh::set(const mesh& m, int mode)
void glmesh::render()
{
glDrawElements(GL_TRIANGLES, size, GL_UNSIGNED_INT, 0);
render(GL_TRIANGLES);
}
void glmesh::render(int type)
{
glDrawElements(type, size, GL_UNSIGNED_INT, 0);
}

View File

@ -27,6 +27,7 @@ struct glmesh
void bind();
void uniform();
void set(const mesh& m, int mode);
void render(int type);
void render();
};

View File

@ -3,7 +3,7 @@
#include "arrays.hpp"
#include "../shader.hpp"
#include "../camera.hpp"
#include "../../math.hpp"
#include "../../util/math.hpp"
#include <iostream>
@ -95,19 +95,18 @@ bool ray_intersects_triangle(vec3 ray_origin,
return false;
}
vec3 mesh::check_intersect(vec3 pos, vec3 path) const
bool mesh::check_intersect(vec3 pos, vec3 path) const
{
double l = glm::length(path);
if(l == 0)
{
return path;
return false;
}
vec3 path_n = path / l;
bool intersects = false;
for(unsigned int i = 0; i < indices.size(); i += 3)
for(unsigned int i = 0; i < indices.size(); i++)
{
vec3 v[3] = {
vec3(this->vertices[indices[i]].pos),
@ -117,7 +116,7 @@ vec3 mesh::check_intersect(vec3 pos, vec3 path) const
vec3 ipoint;
vec3 normal = glm::normalize(glm::cross(v[1] - v[0], v[2] - v[0]));
double d = glm::dot(normal, path);
double d = glm::dot(normal, path_n);
if(d >= 0)
continue;
@ -126,12 +125,107 @@ vec3 mesh::check_intersect(vec3 pos, vec3 path) const
if(l < glm::length(ipoint - pos))
continue;
intersects = true;
path -= normal * d;
l = glm::length(path);
path_n = path / l;
return true;
}
return false;
}
vec3 mesh::calc_intersect(vec3 pos, vec3 path) const
{
vec3 normal_last(0);
return calc_intersect(pos, path, normal_last);
}
static bool calc_intercept_vert(vec3 v[3], vec3 pos, vec3& path, vec3& path_n, vec3& normal_last, double& l)
{
vec3 ipoint;
vec3 normal = glm::normalize(glm::cross(v[1] - v[0], v[2] - v[0]));
double d = glm::dot(normal, path);
if(d >= 0)
return false;
if(!ray_intersects_triangle(pos, path_n, v, ipoint))
return false;
if(l < glm::length(ipoint - pos))
return false;
if(normal_last != vec3(0))
{
vec3 n = glm::cross(normal_last, normal);
if(glm::length(n) > 0)
{
normal = glm::normalize(glm::cross(glm::cross(normal_last, normal), normal_last));
d = glm::dot(normal, path);
}
}
path -= normal * d;
normal_last = normal;
l = glm::length(path);
path_n = path / l;
return true;
}
vec3 mesh::calc_intersect(vec3 pos, vec3 path, vec3& normal_last) const
{
double l = glm::length(path);
if(l == 0)
{
return path;
}
vec3 path_n = path / l;
unsigned int i_found = 0;
for(unsigned int i = 0; i < indices.size(); i += 3)
{
vec3 v[3] = {
vec3(this->vertices[indices[i]].pos),
vec3(this->vertices[indices[i + 1]].pos),
vec3(this->vertices[indices[i + 2]].pos)
};
if(calc_intercept_vert(v, pos, path, path_n, normal_last, l))
{
i_found = i;
}
}
/*
for(unsigned int i = i_found - 1; i >= 0; i--)
{
vec3 v[3] = {
vec3(this->vertices[indices[i]].pos),
vec3(this->vertices[indices[i + 1]].pos),
vec3(this->vertices[indices[i + 2]].pos)
};
calc_intercept_vert(v, pos, path, path_n, normal_last, l);
}
*/
return path;
}
mesh mesh::to_lines() const
{
mesh m;
m.vertices = vertices;
for(int i = 0; i < indices.size(); i += 3)
{
m.indices.push_back(indices[i]);
m.indices.push_back(indices[i + 1]);
m.indices.push_back(indices[i + 1]);
m.indices.push_back(indices[i + 2]);
m.indices.push_back(indices[i]);
m.indices.push_back(indices[i + 2]);
}
std::cout << "indices.size() = " << m.indices.size() << ", vertices.size() = " << m.vertices.size() << "\n";
return m;
}

View File

@ -27,7 +27,10 @@ struct mesh
void load_text(const char* text, double size);
void add(const mesh& o, glm::mat4 mat);
glm::vec<3, double> check_intersect(glm::vec<3, double> pos, glm::vec<3, double> path) const;
mesh to_lines() const;
bool check_intersect(glm::vec<3, double> pos, glm::vec<3, double> path) const;
glm::vec<3, double> calc_intersect(glm::vec<3, double> pos, glm::vec<3, double> path) const;
glm::vec<3, double> calc_intersect(glm::vec<3, double> pos, glm::vec<3, double> path, glm::vec<3, double>& normal_last) const;
template <class T>
void load_text(const char* header, T& item, double size)

View File

@ -28,7 +28,7 @@ using namespace sim::graphics;
static GLFWwindow* win;
static bool win_should_close = false;
static glmesh MeshScene;
static glmesh MeshScene, MeshCollisionScene;
static monitor::vessel MonitorVessel;
static monitor::core MonitorCore;
@ -40,7 +40,7 @@ void GLAPIENTRY cb_debug_message(GLenum source, GLenum type, GLuint id, GLenum s
}
}
void window::create()
void window::create(system& sys)
{
glfwInit();
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 4);
@ -96,11 +96,14 @@ void window::create()
font::init();
shader::init_program();
mesh rmesh;
rmesh.load_model("../assets", "scene-baked.glb");
sys.scene.load_model("../assets", "scene-baked.glb");
MeshScene.bind();
MeshScene.set(rmesh, GL_STATIC_DRAW);
MeshScene.set(sys.scene, GL_STATIC_DRAW);
sys.scene.load_model("../assets/model", "scene_collisions.stl");
MeshCollisionScene.bind();
MeshCollisionScene.set(sys.scene.to_lines(), GL_STATIC_DRAW);
MonitorCore.init();
MonitorVessel.init();
@ -123,6 +126,10 @@ void window::loop(sim::system& sys)
MeshScene.uniform();
MeshScene.render();
MeshCollisionScene.bind();
MeshCollisionScene.uniform();
MeshCollisionScene.render(GL_LINES);
MonitorCore.render(sys);
MonitorVessel.render();

View File

@ -8,8 +8,8 @@
namespace sim::graphics::window
{
void create();
bool should_close();
void create(sim::system& sys);
void loop(sim::system& sys);
void destroy();
void close();

View File

@ -28,8 +28,8 @@ unsigned long get_now()
int main()
{
graphics::window::create();
sim::system sys;
graphics::window::create(sys);
long clock = get_now();

View File

@ -3,6 +3,7 @@
#include <cmath>
#include <vector>
#include <cstdlib>
using namespace sim::reactor;
@ -14,31 +15,31 @@ sim::reactor::reactor sim::reactor::builder(const int W, const int H, const doub
for(int x = 0; x < W; x++)
{
char c = lines[y][x];
rod* r;
std::unique_ptr<rod> r;
switch(c)
{
case 'F':
r = new fuel::fuel_rod(fr);
r = fr.clone();
break;
case 'C':
r = new control::boron_rod(br);
r = br.clone();
break;
case 'G':
r = new control::graphite_rod();
r = std::make_unique<control::graphite_rod>();
break;
case 'H':
r = new coolant::heater();
r = std::make_unique<coolant::heater>();
break;
case 'P':
r = new coolant::pipe(v);
r = std::make_unique<coolant::pipe>(v);
break;
case ' ':
r = new rod();
r = std::make_unique<rod>();
break;
}
arr[y * W + x] = std::unique_ptr<rod>(std::move(r));
arr[y * W + x] = std::move(r);
}
return reactor(&arr[0], W, H, CW, CH);

View File

@ -15,7 +15,6 @@ class boron_rod : public sim::reactor::coolant::pipe
virtual void display(std::ostream& o) const;
virtual const char* get_name() const { return "Boron Control Rod"; }
virtual rod* clone() const { return new boron_rod(*this); }
virtual glm::vec4 get_colour() const;
virtual int get_id() const { return 5; }
@ -30,6 +29,7 @@ public:
virtual bool should_display() const { return true; }
virtual bool should_select() const { return true; }
virtual void update_selected(double a);
virtual std::unique_ptr<rod> clone() const { return std::make_unique<boron_rod>(*this); }
};
}

View File

@ -12,7 +12,6 @@ class graphite_rod : public sim::reactor::rod
virtual void display(std::ostream& o) const;
virtual const char* get_name() const { return "Graphite Rod"; }
virtual rod* clone() const { return new graphite_rod(*this); };
virtual double get_k(val_t type) const;
virtual glm::vec4 get_colour() const;
virtual int get_id() const { return 4; }
@ -27,6 +26,7 @@ public:
virtual bool should_display() const { return true; }
virtual bool should_select() const { return true; }
virtual void update_selected(double a);
virtual std::unique_ptr<rod> clone() const { return std::make_unique<graphite_rod>(*this); }
};
}

View File

@ -15,7 +15,6 @@ class heater : public sim::reactor::rod
virtual bool has_sensors(val_t t) const { return true; }
virtual const char* get_name() const { return "Heater"; }
virtual double get_k(val_t type) const { return 0.5; }
virtual rod* clone() const { return new heater(*this); };
virtual int get_id() const { return 3; }
public:
@ -24,6 +23,7 @@ public:
virtual bool should_display() const { return true; }
virtual bool should_select() const { return true; }
virtual void update_selected(double a);
virtual std::unique_ptr<rod> clone() const { return std::make_unique<heater>(*this); }
};
};

View File

@ -16,7 +16,6 @@ protected:
virtual double get_k(sim::reactor::rod::val_t type) const;
virtual const char* get_name() const { return "Coolant"; }
virtual rod* clone() const { return new pipe(*this); };
virtual int get_id() const { return 2; }
void update_pipe(double secs);
@ -25,6 +24,7 @@ public:
pipe(coolant::vessel& v);
virtual std::unique_ptr<rod> clone() const { return std::make_unique<pipe>(*this); }
virtual bool should_display() const { return true; }
virtual void update(double secs);

View File

@ -16,7 +16,6 @@ class fuel_rod : public sim::reactor::rod
virtual bool has_sensors(val_t t) const { return true; }
virtual const char* get_name() const { return "Fuel"; }
virtual rod* clone() const { return new fuel_rod(*this); };
virtual int get_id() const { return 1; }
virtual glm::vec4 get_colour() const;
@ -24,6 +23,7 @@ public:
fuel_rod(double fuel);
virtual std::unique_ptr<rod> clone() const { return std::make_unique<fuel_rod>(*this); }
virtual bool should_display() const { return true; }
virtual void update(double secs);
};

View File

@ -8,7 +8,7 @@ using namespace sim::reactor;
reactor::reactor(std::unique_ptr<rod>* rods, int w, int h, double cw, double ch) : cell_width(cw), cell_height(ch), width(w), height(h), size(w * h)
{
this->rods = new std::unique_ptr<rod>[width * height];
this->rods = std::make_unique<std::unique_ptr<rod>[]>(width * height);
for(int i = 0; i < size; i++)
{
@ -19,14 +19,13 @@ reactor::reactor(std::unique_ptr<rod>* rods, int w, int h, double cw, double ch)
reactor::reactor(reactor&& o) : cell_width(o.cell_width), cell_height(o.cell_height), width(o.width), height(o.height), size(o.size)
{
rods = o.rods;
rods = std::move(o.rods);
cursor = o.cursor;
o.rods = nullptr;
}
reactor::reactor(const reactor& o) : cell_width(o.cell_width), cell_height(o.cell_height), width(o.width), height(o.height), size(o.size)
{
rods = new std::unique_ptr<rod>[width * height];
this->rods = std::make_unique<std::unique_ptr<rod>[]>(width * height);
for(int i = 0; i < size; i++)
{
@ -34,14 +33,6 @@ reactor::reactor(const reactor& o) : cell_width(o.cell_width), cell_height(o.cel
}
}
reactor::~reactor()
{
if(rods != nullptr)
{
delete[] rods;
}
}
void reactor::update(double secs)
{
int rods_lookup[size];

View File

@ -18,13 +18,12 @@ struct reactor
const int height;
const int size;
std::unique_ptr<rod>* rods;
std::unique_ptr<std::unique_ptr<rod>[]> rods;
int cursor = 0;
reactor(std::unique_ptr<rod>* rods, int width, int height, double cell_width, double cell_height);
reactor(const reactor& r);
reactor(reactor&& r);
~reactor();
void update(double secs);
void update_selected(int v);

View File

@ -3,6 +3,7 @@
#include <ostream>
#include <glm/vec4.hpp>
#include <memory>
namespace sim::reactor
{
@ -21,12 +22,13 @@ public:
N_FAST = 2
};
virtual ~rod() {};
virtual void interact(rod* o, double secs);
virtual void update(double secs) { }
virtual void add(val_t type, double v);
virtual double extract(val_t type, double s, double k, double o);
virtual double get(val_t type) const;
virtual rod* clone() const { return new rod(*this); }
virtual std::unique_ptr<rod> clone() const { return std::make_unique<rod>(*this); }
virtual glm::vec4 get_colour() const { return {0, 0, 0, 0}; }
virtual int get_id() const { return 0; }

View File

@ -33,37 +33,22 @@ system::system()
" C C C C "
};
vessel = new reactor::coolant::vessel(8, 10, 300, sim::coolant::WATER);
reactor = new sim::reactor::reactor(sim::reactor::builder(19, 19, 0.25, 8,
vessel = std::make_unique<reactor::coolant::vessel>(8, 10, 300, sim::coolant::WATER);
reactor = std::make_unique<sim::reactor::reactor>(sim::reactor::builder(19, 19, 0.25, 8,
reactor::fuel::fuel_rod(0.5),
reactor::control::boron_rod(*vessel, 1),
*vessel, layout));
reactor::control::boron_rod(*vessel.get(), 1),
*vessel.get(), layout));
valve = new coolant::valve<reactor::coolant::vessel>(*vessel, 1, 500);
pump = new coolant::pump<reactor::coolant::vessel>(*vessel, 1e4, 15);
scene.load_model("../assets/model", "scene_collisions.stl");
valve = std::make_unique<coolant::valve<reactor::coolant::vessel>>(*vessel.get(), 1, 500);
pump = std::make_unique<coolant::pump<reactor::coolant::vessel>>(*vessel.get(), 1e4, 15);
}
system::system(system&& o)
{
vessel = o.vessel;
reactor = o.reactor;
valve = o.valve;
pump = o.pump;
o.vessel = nullptr;
o.reactor = nullptr;
o.valve = nullptr;
o.pump = nullptr;
}
system::~system()
{
if(vessel != nullptr) delete vessel;
if(reactor != nullptr) delete reactor;
if(valve != nullptr) delete valve;
if(pump != nullptr) delete pump;
vessel = std::move(o.vessel);
reactor = std::move(o.reactor);
valve = std::move(o.valve);
pump = std::move(o.pump);
}
void system::update(double dt)

View File

@ -14,16 +14,15 @@ namespace sim
struct system
{
sim::reactor::reactor* reactor;
sim::reactor::coolant::vessel* vessel;
sim::coolant::valve<sim::reactor::coolant::vessel>* valve;
sim::coolant::pump<sim::reactor::coolant::vessel>* pump;
std::unique_ptr<sim::reactor::reactor> reactor;
std::unique_ptr<sim::reactor::coolant::vessel> vessel;
std::unique_ptr<sim::coolant::valve<sim::reactor::coolant::vessel>> valve;
std::unique_ptr<sim::coolant::pump<sim::reactor::coolant::vessel>> pump;
sim::graphics::mesh scene;
system();
system(system&& o);
system(const system& o) = delete;
~system();
void update(double dt);
};