-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathSolver.m
58 lines (55 loc) · 2.72 KB
/
Solver.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
classdef Solver
properties
iteration
time_step
matrix_size
temperatures
matrix_coefficients
right_hand_side_vector
number_of_equations
end
methods
function obj = Solver(time_step, matrix_size, initial_temperature)
if nargin > 0
obj.time_step = time_step;
obj.matrix_size = matrix_size;
obj.temperatures = initial_temperature*ones(matrix_size,1);
obj.matrix_coefficients = zeros(matrix_size,matrix_size);
obj.right_hand_side_vector = zeros(matrix_size,1);
obj.iteration = 0;
end
end
function [obj, elements] = get_matrices(obj, elements)
for i=1:length(elements)
elements(i) = elements(i).create(obj);
for j=1:elements(i).number_of_equations
obj.number_of_equations = obj.number_of_equations + 1;
obj.matrix_coefficients(obj.number_of_equations, :) = elements(i).matrix_coefficients(j,:);
obj.right_hand_side_vector(obj.number_of_equations, 1) = elements(i).right_hand_side_vector(j,1);
end
end
end
function [obj, boilers, pipes, radiators, mixers, zones, sames, heatExchangers, chillers, fanCoils, constants, bridges] = iterate(obj, boilers, pipes, radiators, mixers, zones, sames, heatExchangers, chillers, fanCoils, constants, bridges)
obj.iteration = obj.iteration + 1;
obj.number_of_equations = 0;
[obj, boilers] = obj.get_matrices(boilers);
[obj, pipes] = obj.get_matrices(pipes);
[obj, radiators] = obj.get_matrices(radiators);
[obj, mixers] = obj.get_matrices(mixers);
[obj, zones] = obj.get_matrices(zones);
[obj, sames] = obj.get_matrices(sames);
[obj, heatExchangers] = obj.get_matrices(heatExchangers);
[obj, chillers] = obj.get_matrices(chillers);
[obj, fanCoils] = obj.get_matrices(fanCoils);
[obj, constants] = obj.get_matrices(constants);
[obj, bridges] = obj.get_matrices(bridges);
if(obj.number_of_equations~=obj.matrix_size)
disp('Error: The number of equations and variables should be same.');
fprintf('Number of Variables: %d - Number of Equations: %d', obj.matrix_size, obj.number_of_equations);
else
fprintf('Iteration: %d | Time: %d s\n', obj.iteration, obj.iteration*obj.time_step);
end
obj.temperatures = obj.matrix_coefficients\obj.right_hand_side_vector;
end
end
end