-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathA_ComparisonRadiosityDiffusionAfterOpt.m
213 lines (201 loc) · 8.63 KB
/
A_ComparisonRadiosityDiffusionAfterOpt.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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
close all;
clear;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%Comparison OVER AXIS
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
current_path = fileparts(mfilename('fullpath'));
results_diff_imp = fullfile(current_path, 'results_diff_imp');
results_rad_imp = fullfile(current_path, 'results_rad_imp');
results_diff_opt = fullfile(current_path, 'results_diff_opt');
%Graphs before optimization of room 10x10x10
x_source = readNPY(fullfile(results_diff_imp,'x_source.npy'));
if x_source == 5
load(fullfile(results_rad_imp,"SPL_t0_R.mat"))
load(fullfile(results_rad_imp,"T30_x.mat"))
load(fullfile(results_rad_imp,"x_axis_R.mat"))
SPL_t0_PY = readNPY(fullfile(results_diff_imp,'spl_rec_x_t0_correction.npy'));
T30_x_PY = readNPY(fullfile(results_diff_imp,'t30_x.npy'));
x_axis_PY = readNPY(fullfile(results_diff_imp,'x_axis.npy'));
f1 = figure(1);
plot(x_axis_PY, SPL_t0_R,"Color", "#000000",'LineWidth',0.5)
hold on
plot(x_axis_PY, SPL_t0_PY, "Color", "#000000", 'LineWidth',2)
set(gca,'fontsize',14)
%title('Radiosity and Diffusion SPL at t = 0*lambda','fontsize',12,'Interpreter','latex')
xlabel('x-axis (m)')%,'Interpreter','latex')
ylabel('SPL (dB)')%,'Interpreter','latex')
%legend('SPL_{rad}','SPL_{diff}')
%axis([0 x_axis(end) 95 105])
f1.Position = [500 500 340 250]; % Position (first two-values) and Size (last two-values)
xticks([x_axis_PY(1) 2 4 6 8 10])
yticks(87.4:0.1:88)
ylim([87.4 88])
hold off
f2 = figure(2);
plot(x_axis, T30_x, "Color", "#000000",'LineWidth',0.5)
hold on
plot(x_axis, T30_x_PY,"Color", "#000000",'LineWidth',2)
set(gca,'fontsize',14)
%title('Radiosity and Diffusion t30','fontsize',12,'Interpreter','latex')
xlabel('x-axis (m)')%,'Interpreter','latex')
ylabel('Reverberation time (s)')%,'Interpreter','latex')
%legend('t30_{rad}','t30_{diff}')
xticks([x_axis_PY(1) 2 4 6 8 10])
yticks(2.6:0.003:2.615)
ylim([2.6 2.615])
f2.Position = [500 500 340 250]; % Position (first two-values) and Size (last two-values)
hold off
else
%Graphs before and after optimization of all other rooms
%Load Matlab
load(fullfile(results_rad_imp,"SPL_t0_R"))
load(fullfile(results_rad_imp,"T30_x"))
%Load Python BEFORE
SPL_t0_PY_before = readNPY(fullfile(results_diff_imp,'spl_rec_x_t0.npy'));
x_source = readNPY(fullfile(results_diff_imp,'x_source.npy'));
mean_free_path = readNPY(fullfile(results_diff_imp,'mean_free_path.npy'));
T30_x_PY = readNPY(fullfile(results_diff_imp,'t30_x.npy'));
%Load Python AFTER
x_axis = readNPY(fullfile(results_diff_opt,'x_axis.npy'));
SPL_t0_PY_after = readNPY(fullfile(results_diff_opt,'spl_rec_x_t0.npy'));
Dx = readNPY(fullfile(results_diff_opt,'Dx.npy'));
acc = 0.5;
mean_free_path_rounded = round(mean_free_path/acc)*acc;
if x_source <= mean_free_path_rounded
pos_from = x_source + mean_free_path_rounded;
temp = abs(pos_from - x_axis);
x_from = x_axis(temp == min(abs(pos_from - x_axis)));
idx_dist = find(x_axis == x_from);
dist_from = x_axis(idx_dist:end)-x_source;
SPL_t0_R_nosource = SPL_t0_R(idx_dist:end);
SPL_t0_PY_before_nosource = SPL_t0_PY_before(idx_dist:end);
SPL_t0_PY_after_nosource = SPL_t0_PY_after(idx_dist:end);
Dx_nosource = Dx(idx_dist:end);
T30_x_nosource= T30_x(idx_dist:end);
T30_x_PY_nosource= T30_x_PY(idx_dist:end);
else
pos_source = find(x_axis == x_source);
pos_source_before = find(x_axis == x_source-mean_free_path_rounded);
pos_source_after = find(x_axis == x_source+mean_free_path_rounded);
SPL_t0_R_nosource = SPL_t0_R;
SPL_t0_R_nosource(pos_source_before+1:pos_source_after-1) = inf;
SPL_t0_PY_before_nosource = SPL_t0_PY_before;
SPL_t0_PY_before_nosource(pos_source_before+1:pos_source_after-1) = inf;
SPL_t0_PY_after_nosource = SPL_t0_PY_after;
SPL_t0_PY_after_nosource(pos_source_before+1:pos_source_after-1) = inf;
T30_x_nosource = T30_x;
T30_x_nosource(pos_source_before+1:pos_source_after-1) = inf;
T30_x_PY_nosource = T30_x_PY;
T30_x_PY_nosource(pos_source_before+1:pos_source_after-1) = inf;
Dx_nosource = Dx;
Dx_nosource(pos_source_before+1:pos_source_after-1) = inf;
end
%Comparison BEFORE
%Figure 1 SPL
if x_source <= mean_free_path_rounded
f1 = figure(1);
plot(dist_from, SPL_t0_R_nosource,"Color", "#000000",'LineWidth',0.5)
hold on
plot(dist_from, SPL_t0_PY_before_nosource,"Color", "#000000",'LineWidth',2)
set(gca,'fontsize',14)
xlabel('distance from source (m)')
ylabel('SPL (dB)')
xlim([dist_from(1) dist_from(end)])
f1.Position = [500 500 340 250]; % Position (first two-values) and Size (last two-values)
xticks([dist_from(1) 5 10 15 20 25 30 35])
hold off
else
f1 = figure(1);
plot(x_axis, SPL_t0_R_nosource,"Color", "#000000",'LineWidth',0.5)
hold on
plot(x_axis, SPL_t0_PY_before_nosource,"Color", "#000000",'LineWidth',2)
set(gca,'fontsize',14)
xlabel('x-axis (m)')
ylabel('SPL (dB)')
xlim([x_axis(1) x_axis(end)])
f1.Position = [500 500 340 250]; % Position (first two-values) and Size (last two-values)
xticks([x_axis(1) 5 10 15 20 25 30 35])
hold off
end
%Figure 2 RT
if x_source <= mean_free_path_rounded
f2 = figure(2);
plot(dist_from, T30_x_nosource,"Color", "#000000",'LineWidth',0.5)
hold on
plot(dist_from, T30_x_PY_nosource,"Color", "#000000",'LineWidth',2)
set(gca,'fontsize',14)
xlabel('distance from source (m)')
ylabel('RT (s)')
xlim([dist_from(1) dist_from(end)])
f2.Position = [500 500 340 250]; % Position (first two-values) and Size (last two-values)
xticks([dist_from(1) 5 10 15 20 25 30 35])
hold off
else
f2 = figure(2);
plot(x_axis, T30_x_nosource,"Color", "#000000",'LineWidth',0.5)
hold on
plot(x_axis, T30_x_PY_nosource,"Color", "#000000",'LineWidth',2)
set(gca,'fontsize',14)
xlabel('x-axis (m)')
ylabel('RT (s)')
xlim([x_axis(1) x_axis(end)])
f2.Position = [500 500 340 250]; % Position (first two-values) and Size (last two-values)
xticks([x_axis(1) 5 10 15 20 25 30 35])
hold off
end
%Comparison AFTER
if x_source <= mean_free_path_rounded
f3 = figure(3);
plot(dist_from, SPL_t0_R_nosource,"Color", "#000000",'LineWidth',0.5)
hold on
plot(dist_from, SPL_t0_PY_after_nosource,"Color", "#000000",'LineWidth',2)
set(gca,'fontsize',14)
%title('Radiosity and Diffusion SPL at t = 0*lambda','fontsize',12,'Interpreter','latex')
xlabel('distance from source (m)')%,'Interpreter','latex')
ylabel('SPL (dB)')%,'Interpreter','latex')
xlim([dist_from(1) dist_from(end)])
%ylim([75 95])
%axis([dist_from(1) dist_from(end) 95 105])
f3.Position = [500 500 340 250]; % Position (first two-values) and Size (last two-values)
xticks([dist_from(1) 5 10 15 20 25 30 35])
hold off
else
f3 = figure(3);
plot(x_axis, SPL_t0_R_nosource,"Color", "#000000",'LineWidth',0.5)
hold on
plot(x_axis, SPL_t0_PY_after_nosource,"Color", "#000000",'LineWidth',2)
set(gca,'fontsize',14)
%title('Radiosity and Diffusion SPL at t = 0*lambda','fontsize',12,'Interpreter','latex')
xlabel('x-axis (m)')%,'Interpreter','latex')
ylabel('SPL (dB)')%,'Interpreter','latex')
xlim([x_axis(1) x_axis(end)])
%ylim([75 95])
%axis([dist_from(1) dist_from(end) 95 105])
f3.Position = [500 500 340 250]; % Position (first two-values) and Size (last two-values)
xticks([x_axis(1) 5 10 15 20 25 30 35])
hold off
end
if x_source <= mean_free_path_rounded
f4 = figure(4);
plot(dist_from, Dx_nosource,"Color", "#000000",'LineWidth',2)
set(gca,'fontsize',14)
%title('Diffusion Coefficient Dx considering direct sound and no source','fontsize',12,'Interpreter','latex')
xlabel('distance from source (m)')%,'Interpreter','latex')
ylabel('D_{opt} (m^2/s)')%,'Interpreter','latex')
f4.Position = [500 500 340 250]; % Position (first two-values) and Size (last two-values)
xlim([dist_from(1) dist_from(end)])
xticks([dist_from(1) 5 10 15 20 25 30 35])
else
f4 = figure(4);
plot(x_axis, Dx_nosource,"Color", "#000000",'LineWidth',2)
set(gca,'fontsize',14)
%title('Diffusion Coefficient Dx considering direct sound and no source','fontsize',12,'Interpreter','latex')
xlabel('x-axis (m)')%,'Interpreter','latex')
ylabel('D_{opt} (m^2/s)')%,'Interpreter','latex')
f4.Position = [500 500 340 250]; % Position (first two-values) and Size (last two-values)
xlim([x_axis(1) x_axis(end)])
xticks([x_axis(1) 5 10 15 20 25 30 35])
end
end