fix memory issues
This commit is contained in:
parent
821897bbaa
commit
93555ddac4
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
#include "camera.hpp"
|
#include "camera.hpp"
|
||||||
#include "input/keyboard.hpp"
|
#include "input/keyboard.hpp"
|
||||||
#include "../math.hpp"
|
#include "../util/math.hpp"
|
||||||
|
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
@ -75,7 +75,11 @@ void camera::update(const system& sys, double dt)
|
||||||
velocity.z += 3.5;
|
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;
|
pos += velocity2 * dt;
|
||||||
on_ground = ((velocity * dt / dt).z != velocity2.z);
|
on_ground = ((velocity * dt / dt).z != velocity2.z);
|
||||||
|
|
|
@ -89,6 +89,8 @@ void font::init()
|
||||||
|
|
||||||
chars[i] = c;
|
chars[i] = c;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FT_Done_FreeType(ft);
|
||||||
}
|
}
|
||||||
|
|
||||||
void mesh::load_text(const char* text, double size)
|
void mesh::load_text(const char* text, double size)
|
||||||
|
|
|
@ -73,6 +73,11 @@ void glmesh::set(const mesh& m, int mode)
|
||||||
|
|
||||||
void glmesh::render()
|
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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,6 +27,7 @@ struct glmesh
|
||||||
void bind();
|
void bind();
|
||||||
void uniform();
|
void uniform();
|
||||||
void set(const mesh& m, int mode);
|
void set(const mesh& m, int mode);
|
||||||
|
void render(int type);
|
||||||
void render();
|
void render();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
#include "arrays.hpp"
|
#include "arrays.hpp"
|
||||||
#include "../shader.hpp"
|
#include "../shader.hpp"
|
||||||
#include "../camera.hpp"
|
#include "../camera.hpp"
|
||||||
#include "../../math.hpp"
|
#include "../../util/math.hpp"
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
|
@ -95,19 +95,18 @@ bool ray_intersects_triangle(vec3 ray_origin,
|
||||||
return false;
|
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);
|
double l = glm::length(path);
|
||||||
|
|
||||||
if(l == 0)
|
if(l == 0)
|
||||||
{
|
{
|
||||||
return path;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
vec3 path_n = path / l;
|
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 v[3] = {
|
||||||
vec3(this->vertices[indices[i]].pos),
|
vec3(this->vertices[indices[i]].pos),
|
||||||
|
@ -117,7 +116,7 @@ vec3 mesh::check_intersect(vec3 pos, vec3 path) const
|
||||||
|
|
||||||
vec3 ipoint;
|
vec3 ipoint;
|
||||||
vec3 normal = glm::normalize(glm::cross(v[1] - v[0], v[2] - v[0]));
|
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)
|
if(d >= 0)
|
||||||
continue;
|
continue;
|
||||||
|
@ -126,12 +125,107 @@ vec3 mesh::check_intersect(vec3 pos, vec3 path) const
|
||||||
if(l < glm::length(ipoint - pos))
|
if(l < glm::length(ipoint - pos))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
intersects = true;
|
return true;
|
||||||
path -= normal * d;
|
|
||||||
l = glm::length(path);
|
|
||||||
path_n = path / l;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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;
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,10 @@ struct mesh
|
||||||
void load_text(const char* text, double size);
|
void load_text(const char* text, double size);
|
||||||
void add(const mesh& o, glm::mat4 mat);
|
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>
|
template <class T>
|
||||||
void load_text(const char* header, T& item, double size)
|
void load_text(const char* header, T& item, double size)
|
||||||
|
|
|
@ -28,7 +28,7 @@ using namespace sim::graphics;
|
||||||
static GLFWwindow* win;
|
static GLFWwindow* win;
|
||||||
static bool win_should_close = false;
|
static bool win_should_close = false;
|
||||||
|
|
||||||
static glmesh MeshScene;
|
static glmesh MeshScene, MeshCollisionScene;
|
||||||
static monitor::vessel MonitorVessel;
|
static monitor::vessel MonitorVessel;
|
||||||
static monitor::core MonitorCore;
|
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();
|
glfwInit();
|
||||||
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 4);
|
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 4);
|
||||||
|
@ -96,11 +96,14 @@ void window::create()
|
||||||
font::init();
|
font::init();
|
||||||
|
|
||||||
shader::init_program();
|
shader::init_program();
|
||||||
mesh rmesh;
|
|
||||||
|
|
||||||
rmesh.load_model("../assets", "scene-baked.glb");
|
sys.scene.load_model("../assets", "scene-baked.glb");
|
||||||
MeshScene.bind();
|
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();
|
MonitorCore.init();
|
||||||
MonitorVessel.init();
|
MonitorVessel.init();
|
||||||
|
@ -123,6 +126,10 @@ void window::loop(sim::system& sys)
|
||||||
MeshScene.uniform();
|
MeshScene.uniform();
|
||||||
MeshScene.render();
|
MeshScene.render();
|
||||||
|
|
||||||
|
MeshCollisionScene.bind();
|
||||||
|
MeshCollisionScene.uniform();
|
||||||
|
MeshCollisionScene.render(GL_LINES);
|
||||||
|
|
||||||
MonitorCore.render(sys);
|
MonitorCore.render(sys);
|
||||||
MonitorVessel.render();
|
MonitorVessel.render();
|
||||||
|
|
||||||
|
|
|
@ -8,8 +8,8 @@
|
||||||
namespace sim::graphics::window
|
namespace sim::graphics::window
|
||||||
{
|
{
|
||||||
|
|
||||||
void create();
|
|
||||||
bool should_close();
|
bool should_close();
|
||||||
|
void create(sim::system& sys);
|
||||||
void loop(sim::system& sys);
|
void loop(sim::system& sys);
|
||||||
void destroy();
|
void destroy();
|
||||||
void close();
|
void close();
|
||||||
|
|
|
@ -28,8 +28,8 @@ unsigned long get_now()
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
graphics::window::create();
|
|
||||||
sim::system sys;
|
sim::system sys;
|
||||||
|
graphics::window::create(sys);
|
||||||
|
|
||||||
long clock = get_now();
|
long clock = get_now();
|
||||||
|
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
|
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include <cstdlib>
|
||||||
|
|
||||||
using namespace sim::reactor;
|
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++)
|
for(int x = 0; x < W; x++)
|
||||||
{
|
{
|
||||||
char c = lines[y][x];
|
char c = lines[y][x];
|
||||||
rod* r;
|
std::unique_ptr<rod> r;
|
||||||
|
|
||||||
switch(c)
|
switch(c)
|
||||||
{
|
{
|
||||||
case 'F':
|
case 'F':
|
||||||
r = new fuel::fuel_rod(fr);
|
r = fr.clone();
|
||||||
break;
|
break;
|
||||||
case 'C':
|
case 'C':
|
||||||
r = new control::boron_rod(br);
|
r = br.clone();
|
||||||
break;
|
break;
|
||||||
case 'G':
|
case 'G':
|
||||||
r = new control::graphite_rod();
|
r = std::make_unique<control::graphite_rod>();
|
||||||
break;
|
break;
|
||||||
case 'H':
|
case 'H':
|
||||||
r = new coolant::heater();
|
r = std::make_unique<coolant::heater>();
|
||||||
break;
|
break;
|
||||||
case 'P':
|
case 'P':
|
||||||
r = new coolant::pipe(v);
|
r = std::make_unique<coolant::pipe>(v);
|
||||||
break;
|
break;
|
||||||
case ' ':
|
case ' ':
|
||||||
r = new rod();
|
r = std::make_unique<rod>();
|
||||||
break;
|
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);
|
return reactor(&arr[0], W, H, CW, CH);
|
||||||
|
|
|
@ -15,7 +15,6 @@ class boron_rod : public sim::reactor::coolant::pipe
|
||||||
|
|
||||||
virtual void display(std::ostream& o) const;
|
virtual void display(std::ostream& o) const;
|
||||||
virtual const char* get_name() const { return "Boron Control Rod"; }
|
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 glm::vec4 get_colour() const;
|
||||||
virtual int get_id() const { return 5; }
|
virtual int get_id() const { return 5; }
|
||||||
|
|
||||||
|
@ -30,6 +29,7 @@ public:
|
||||||
virtual bool should_display() const { return true; }
|
virtual bool should_display() const { return true; }
|
||||||
virtual bool should_select() const { return true; }
|
virtual bool should_select() const { return true; }
|
||||||
virtual void update_selected(double a);
|
virtual void update_selected(double a);
|
||||||
|
virtual std::unique_ptr<rod> clone() const { return std::make_unique<boron_rod>(*this); }
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,6 @@ class graphite_rod : public sim::reactor::rod
|
||||||
|
|
||||||
virtual void display(std::ostream& o) const;
|
virtual void display(std::ostream& o) const;
|
||||||
virtual const char* get_name() const { return "Graphite Rod"; }
|
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 double get_k(val_t type) const;
|
||||||
virtual glm::vec4 get_colour() const;
|
virtual glm::vec4 get_colour() const;
|
||||||
virtual int get_id() const { return 4; }
|
virtual int get_id() const { return 4; }
|
||||||
|
@ -27,6 +26,7 @@ public:
|
||||||
virtual bool should_display() const { return true; }
|
virtual bool should_display() const { return true; }
|
||||||
virtual bool should_select() const { return true; }
|
virtual bool should_select() const { return true; }
|
||||||
virtual void update_selected(double a);
|
virtual void update_selected(double a);
|
||||||
|
virtual std::unique_ptr<rod> clone() const { return std::make_unique<graphite_rod>(*this); }
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,7 +15,6 @@ class heater : public sim::reactor::rod
|
||||||
virtual bool has_sensors(val_t t) const { return true; }
|
virtual bool has_sensors(val_t t) const { return true; }
|
||||||
virtual const char* get_name() const { return "Heater"; }
|
virtual const char* get_name() const { return "Heater"; }
|
||||||
virtual double get_k(val_t type) const { return 0.5; }
|
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; }
|
virtual int get_id() const { return 3; }
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
@ -24,6 +23,7 @@ public:
|
||||||
virtual bool should_display() const { return true; }
|
virtual bool should_display() const { return true; }
|
||||||
virtual bool should_select() const { return true; }
|
virtual bool should_select() const { return true; }
|
||||||
virtual void update_selected(double a);
|
virtual void update_selected(double a);
|
||||||
|
virtual std::unique_ptr<rod> clone() const { return std::make_unique<heater>(*this); }
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -16,7 +16,6 @@ protected:
|
||||||
|
|
||||||
virtual double get_k(sim::reactor::rod::val_t type) const;
|
virtual double get_k(sim::reactor::rod::val_t type) const;
|
||||||
virtual const char* get_name() const { return "Coolant"; }
|
virtual const char* get_name() const { return "Coolant"; }
|
||||||
virtual rod* clone() const { return new pipe(*this); };
|
|
||||||
virtual int get_id() const { return 2; }
|
virtual int get_id() const { return 2; }
|
||||||
|
|
||||||
void update_pipe(double secs);
|
void update_pipe(double secs);
|
||||||
|
@ -25,6 +24,7 @@ public:
|
||||||
|
|
||||||
pipe(coolant::vessel& v);
|
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 bool should_display() const { return true; }
|
||||||
virtual void update(double secs);
|
virtual void update(double secs);
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,6 @@ class fuel_rod : public sim::reactor::rod
|
||||||
|
|
||||||
virtual bool has_sensors(val_t t) const { return true; }
|
virtual bool has_sensors(val_t t) const { return true; }
|
||||||
virtual const char* get_name() const { return "Fuel"; }
|
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 int get_id() const { return 1; }
|
||||||
virtual glm::vec4 get_colour() const;
|
virtual glm::vec4 get_colour() const;
|
||||||
|
|
||||||
|
@ -24,6 +23,7 @@ public:
|
||||||
|
|
||||||
fuel_rod(double fuel);
|
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 bool should_display() const { return true; }
|
||||||
virtual void update(double secs);
|
virtual void update(double secs);
|
||||||
};
|
};
|
||||||
|
|
|
@ -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)
|
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++)
|
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)
|
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;
|
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)
|
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++)
|
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)
|
void reactor::update(double secs)
|
||||||
{
|
{
|
||||||
int rods_lookup[size];
|
int rods_lookup[size];
|
||||||
|
|
|
@ -18,13 +18,12 @@ struct reactor
|
||||||
const int height;
|
const int height;
|
||||||
const int size;
|
const int size;
|
||||||
|
|
||||||
std::unique_ptr<rod>* rods;
|
std::unique_ptr<std::unique_ptr<rod>[]> rods;
|
||||||
int cursor = 0;
|
int cursor = 0;
|
||||||
|
|
||||||
reactor(std::unique_ptr<rod>* rods, int width, int height, double cell_width, double cell_height);
|
reactor(std::unique_ptr<rod>* rods, int width, int height, double cell_width, double cell_height);
|
||||||
reactor(const reactor& r);
|
reactor(const reactor& r);
|
||||||
reactor(reactor&& r);
|
reactor(reactor&& r);
|
||||||
~reactor();
|
|
||||||
|
|
||||||
void update(double secs);
|
void update(double secs);
|
||||||
void update_selected(int v);
|
void update_selected(int v);
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
|
|
||||||
#include <ostream>
|
#include <ostream>
|
||||||
#include <glm/vec4.hpp>
|
#include <glm/vec4.hpp>
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
namespace sim::reactor
|
namespace sim::reactor
|
||||||
{
|
{
|
||||||
|
@ -21,12 +22,13 @@ public:
|
||||||
N_FAST = 2
|
N_FAST = 2
|
||||||
};
|
};
|
||||||
|
|
||||||
|
virtual ~rod() {};
|
||||||
virtual void interact(rod* o, double secs);
|
virtual void interact(rod* o, double secs);
|
||||||
virtual void update(double secs) { }
|
virtual void update(double secs) { }
|
||||||
virtual void add(val_t type, double v);
|
virtual void add(val_t type, double v);
|
||||||
virtual double extract(val_t type, double s, double k, double o);
|
virtual double extract(val_t type, double s, double k, double o);
|
||||||
virtual double get(val_t type) const;
|
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 glm::vec4 get_colour() const { return {0, 0, 0, 0}; }
|
||||||
virtual int get_id() const { return 0; }
|
virtual int get_id() const { return 0; }
|
||||||
|
|
||||||
|
|
|
@ -33,37 +33,22 @@ system::system()
|
||||||
" C C C C "
|
" C C C C "
|
||||||
};
|
};
|
||||||
|
|
||||||
vessel = new reactor::coolant::vessel(8, 10, 300, sim::coolant::WATER);
|
vessel = std::make_unique<reactor::coolant::vessel>(8, 10, 300, sim::coolant::WATER);
|
||||||
reactor = new sim::reactor::reactor(sim::reactor::builder(19, 19, 0.25, 8,
|
reactor = std::make_unique<sim::reactor::reactor>(sim::reactor::builder(19, 19, 0.25, 8,
|
||||||
reactor::fuel::fuel_rod(0.5),
|
reactor::fuel::fuel_rod(0.5),
|
||||||
reactor::control::boron_rod(*vessel, 1),
|
reactor::control::boron_rod(*vessel.get(), 1),
|
||||||
*vessel, layout));
|
*vessel.get(), layout));
|
||||||
|
|
||||||
valve = new coolant::valve<reactor::coolant::vessel>(*vessel, 1, 500);
|
valve = std::make_unique<coolant::valve<reactor::coolant::vessel>>(*vessel.get(), 1, 500);
|
||||||
pump = new coolant::pump<reactor::coolant::vessel>(*vessel, 1e4, 15);
|
pump = std::make_unique<coolant::pump<reactor::coolant::vessel>>(*vessel.get(), 1e4, 15);
|
||||||
|
|
||||||
scene.load_model("../assets/model", "scene_collisions.stl");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
system::system(system&& o)
|
system::system(system&& o)
|
||||||
{
|
{
|
||||||
vessel = o.vessel;
|
vessel = std::move(o.vessel);
|
||||||
reactor = o.reactor;
|
reactor = std::move(o.reactor);
|
||||||
valve = o.valve;
|
valve = std::move(o.valve);
|
||||||
pump = o.pump;
|
pump = std::move(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;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void system::update(double dt)
|
void system::update(double dt)
|
||||||
|
|
|
@ -14,16 +14,15 @@ namespace sim
|
||||||
|
|
||||||
struct system
|
struct system
|
||||||
{
|
{
|
||||||
sim::reactor::reactor* reactor;
|
std::unique_ptr<sim::reactor::reactor> reactor;
|
||||||
sim::reactor::coolant::vessel* vessel;
|
std::unique_ptr<sim::reactor::coolant::vessel> vessel;
|
||||||
sim::coolant::valve<sim::reactor::coolant::vessel>* valve;
|
std::unique_ptr<sim::coolant::valve<sim::reactor::coolant::vessel>> valve;
|
||||||
sim::coolant::pump<sim::reactor::coolant::vessel>* pump;
|
std::unique_ptr<sim::coolant::pump<sim::reactor::coolant::vessel>> pump;
|
||||||
sim::graphics::mesh scene;
|
sim::graphics::mesh scene;
|
||||||
|
|
||||||
system();
|
system();
|
||||||
system(system&& o);
|
system(system&& o);
|
||||||
system(const system& o) = delete;
|
system(const system& o) = delete;
|
||||||
~system();
|
|
||||||
|
|
||||||
void update(double dt);
|
void update(double dt);
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue