-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCRN_propensity_factorization.m
55 lines (45 loc) · 1.84 KB
/
CRN_propensity_factorization.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
%% Flexible dimension version. % Final version !
% Only need to edit this part.
clear; clc;
% source complexes of the reactions. (each complex could be repeated.)
% K and d could be determined by [K, d] = size(complexes) after determining
% complexes but for the simplicity user would enter them here, manually.
K = 4;
d = 2;
% d: the number of species
% K: the number of reactions.
syms n [1 d] integer
% syms gg positive
ncell = sym2cell(n);
lambda(n) = sym(zeros(K,1));
lambda_cell = sym2cell(formula(lambda));
% initialization of the propensity functions
% complexes = [0 0;2 0;1 1;0 1];
% alpha = sym([3,1,2,0.5]);
% lambda_cell{1}(n) = alpha(1);
% lambda_cell{2}(n) = alpha(2) * n(1) * (n(1) - 1);
% lambda_cell{3}(n) = alpha(3) * n(1) * n(2);
% lambda_cell{4}(n) = alpha(4) * n(2);
% test set 2
% complexes = [0 0;1 0;0 1];
% alpha = sym([3,1,2]);
% syms alpha [1 K] positive
% lambda_cell{1}(n) = alpha(1) * (n(1) + gg);
% lambda_cell{2}(n) = alpha(2) * n(1) * (n(1) + gg);
% lambda_cell{3}(n) = alpha(3) * n(2) * (n(1) + gg);
% test set 3 - Fig. 2A
% alpha = sym([3,1,2]);
complexes = [0 0;1 0;0 1;0 1];
syms alpha [1 K] positive
lambda_cell{1}(n) = alpha(1);
lambda_cell{2}(n) = alpha(2) * n(1) * (n(1) - 1);
lambda_cell{3}(n) = alpha(3) * n(2);
lambda_cell{4}(n) = alpha(4) * n(2);
[a_list_tmp, b_list_tmp, elementary_basis] = CRN_find_elemtary_path(complexes); % the row vectors of H form a basis.
F = CRN_find_elementary_function(complexes, lambda_cell, alpha);
start_point = ones(1,d);
elementary_coordinates = CRN_solve_sym_linear(elementary_basis, start_point);
coord_struct = struct2cell(elementary_coordinates);
theta(ncell{:}) = simplify(CRN_theta_construction(start_point, coord_struct, elementary_basis, F));
factorization_TF = CRN_check_factorization_condition(complexes, lambda_cell, theta, alpha);
cbe = CRN_compute_cbe(complexes_for_cbe, M_kappa);