-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCRN_solve_sym_linear.m
37 lines (31 loc) · 1.15 KB
/
CRN_solve_sym_linear.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
function solutions = CRN_solve_sym_linear(basis, start_point, n_vector)
% basis: m * d matrix whose row vectors are basis of an augmented state space
% determined by Hermite normal form. i.e., zeta_i's
% 'augmented' means that we consider not only stoichiometric vector but
% also difference between any two source complexes.
% The descrepancy by this augmentation appears especially when there are
% multiple linkage classes.
% start_point: d*1 vector, start point that path from to an arbitrary state n.
% s: dimension of the augmented state space.
% d: the number of species
Z = null(basis, 'r');
d = size(basis,2);
s = rank(basis);
basis = basis(1:s, :);
% n_vector = sym('n', [1 d], 'integer');
assumeAlso((n_vector - start_point)' * Z == 0)
% this assumption forces n in the augmented state space.
% c_vector = sym('c', [1 s]);
syms c_vector
for i=1:s
eval(sprintf('syms c%d', i));
end
c_vector = c1;
for i=2:s
eval(sprintf('c_vector = [c_vector, c%d];', i));
end
% assumeAlso(c_vector >= 0);
% assumeAlso(c_vector >= 0)
% assumeAlso(c_vector, 'integer')
solutions = solve((c_vector * basis)' == n_vector - start_point, c_vector, 'ReturnConditions', false);
end