Location: BG_Kr @ 73d6bc1016ed / BG_fit_parameters_CC / PSO_GHK_fitting_curve.m

Author:
Shelley Fong <s.fong@auckland.ac.nz>
Date:
2022-03-03 09:58:16+13:00
Desc:
Changing Xi to X_i, and adding python param finder code
Permanent Source URI:
https://models.physiomeproject.org/workspace/82c/rawfile/73d6bc1016edb1be3ceadf6cccc4aa05ef251e58/BG_fit_parameters_CC/PSO_GHK_fitting_curve.m

clear;
% clc;
% close all;

%% Options
run_optimisation = false;

%% Set up directories
current_dir = cd;
Idx_backlash = find(current_dir == filesep);
main_dir = current_dir; %(1:Idx_backlash(end));
data_dir = [main_dir '\data' filesep];
code_dir = [main_dir '\code' filesep];
output_dir = [main_dir '\output' filesep];
storage_dir = [main_dir '\storage' filesep];

%% Define constants
R = 8.314;
T = 310;
F = 96485;


%% Plot I-V curves
% UNITS:
%     I = G_GHK * K [=] mA
%     G_GHK = I/K [=] Amp.litre/mol
%     G_PMR [=] mS [=] mA/V
    
V = (-120:1:60)/1000;

cKo = 4.5;
cKi = 141.2;
Cm = 0.001; % Unit microF

G_pmr = Cm*0.0135*(cKo^ 0.59);

E_K = R*T/F*log(cKo/cKi);
E_K_st = R*T/F*log(cKo/cKi);

I_lin = G_pmr*(V-E_K); % Unit mA    don't consider gating variable: just finding conductance.

Vstart = 1;
Vend = 181;
error_func = @(G_GHK) square_error(I_lin(Vstart:Vend) - calc_IGHK(G_GHK,V(Vstart:Vend),cKi,cKo));

A = [];
b = [];
Aeq = [];
beq = [];
lb = [-Inf];
ub = [Inf];

options_ps = optimoptions('particleswarm','UseParallel',false,'HybridFcn',@fminunc,'SwarmSize',1000, ...
    'FunctionTolerance', 1e-9);

if run_optimisation
    [G_GHK,fval,exitflag,output] = particleswarm(error_func,1,lb,ub,options_ps);
    save([storage_dir 'kr_G_GHK.mat'],'G_GHK');
else
    load([storage_dir 'kr_G_GHK.mat']);
end

% G_GHK2 = 0.003;

I_GHK = calc_IGHK(G_GHK,V,cKi,cKo);
% I_GHK2 = calc_IGHK(G_GHK2,V,cKi,cKo);

h = figure;
plot(1000*V,1e6*I_lin,'k--',1000*V,1e6*I_GHK); %, 1000*V, 1e6*I_GHK2);
legend('LRd','BG','BG_test','Location','southeast');
ylabel('Current (nA)');
xlabel('Voltage (mV)');
set(gca,'FontSize',16);

print_figure(h,output_dir,'kr_IV_curve');