forked from ManelSoria/HGS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathHGSrebuild.m
85 lines (73 loc) · 2.27 KB
/
HGSrebuild.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
function [species,n0] = HGSrebuild(species,n0)
%**************************************************************************
%
% [species,n0] = HGSrebuild(species,n0)
%
%**************************************************************************
%
% HGSrebuild transform the mixtures in to their species. It also transforms
% the mols of the mixtures with the proportions assigned.
%
%**************************************************************************
% Inputs:
%--------------------------------------------------------------------------
% species --> String or numbers of species
% n0 --> [mols] Mols
%
% Outputs:
%--------------------------------------------------------------------------
% species --> String of species
% n0 --> [mols] Mols
%
%**************************************************************************
% *HGS 2.1
% *By Caleb Fuster, Manel Soria and Arnau Miró
% *ESEIAAT UPC
global HGSdata; HGSload;
if isnumeric(species)
for ii=1:length(species)
if species(ii)<=length(HGSdata.Mm)
nspec{ii} = HGSdata.name{species(ii)};
else
nspec{ii} = HGSdata.comb{species(ii)-length(HGSdata.Mm)};
end
end
species = nspec;
end
if ischar(species)
species = {species};
end
jj = 1;
while jj <= length(species)
id = HGSid(species{jj});
if id > length(HGSdata.Mm)
for ii=1:length(HGSdata.comb)
if strcmp(HGSdata.comb{ii},species{jj})
newspecies = species(1,1:jj-1);
newn = n0(1,1:jj-1);
for kk=1:length(HGSdata.cspec{ii})
newspecies(jj+(kk-1)) = HGSdata.cspec{ii}(kk);
newn(jj+(kk-1)) = n0(jj)/100*HGSdata.cper{ii}(kk);
end
species = [newspecies, species{1,jj+1:end}];
n0 = [newn, n0(1,jj+1:end)];
end
end
else
jj = jj+1;
end
end
Elem = unique(species);
if length(Elem) ~= length(species)
n = zeros(1,length(Elem));
for ii = 1:length(species)
for jj = 1:length(Elem)
if strcmp(Elem{jj},species{ii})
n(jj) = n(jj) + n0(ii);
end
end
end
n0 = n;
species = Elem;
end
end