# Potassium Homeostasis Model

ode <- "
######## CONSTANTS ########
# keep these constants fixed; do not change them.

### PHYSICAL CONSTANTS ###
F = 97;                    # Faraday constant (C/mmol)
R = 8.3145;                # Universal gas constant (J/mol.K)
T = 310.6;                 # Normal body temperature (K)

### NORMAL INTAKE ###
# only used for constanst computations, external inputs will be used for the actual simulation
const_Nain = 100/24/60;     # constant sodium intake rate (mEq/min)
const_Kin = 0.08;           # constant potassium intake rate (mEq/min)
# will be used during simulation
norm_Na_intake = 100/24/60 # Normal sodium intake rate (mEq/min)

### COMPARTMENT VOLUMES ###
V_ecf = 15000;             # Extracellular fluid volume (mL)
V_ic = 25000;              # Intracellular fluid volume (mL)

### RENAL GEOMETRY AND FUNCTION ###
GFR = 105;                 # Glomerular filtration rate (mL/min)
number_of_nephrons = 2000000;  # Number of nephrons

# Tubular segment dimensions
CNT_diameter = 0.0024;     # Connecting tubule diameter (cm)
CNT_length = 0.4;          # Connecting tubule length (cm)
DCT_diameter = 0.0015;     # Distal convoluted tubule diameter (cm)
DCT_length = 0.5;          # Distal convoluted tubule length (cm)
CCD_diameter = 0.0025;     # Cortical collecting duct diameter (cm)
CCD_length = 0.2;          # Cortical collecting duct length (cm)

# Surface-to-volume ratios
SV_CNT = 6e-3;             # CNT surface-to-volume ratio (m^3/m^2)
SV_DCT = 7.5e-3;           # DCT surface-to-volume ratio (m^3/m^2)
SV_CCD = 4e-3;             # CCD surface-to-volume ratio (m^3/m^2)

# Principal cell fractions
principal_fraction_CNT = 0.6;   # Fraction of principal cells in CNT
principal_fraction_CCD = 0.75;  # Fraction of principal cells in CCD

# Tubular volumes (calculated from dimensions)
DCT_volume = pi * ((DCT_diameter/2)^2) * DCT_length;
CNT_volume = pi * ((CNT_diameter/2)^2) * CNT_length;
CCD_volume = pi * ((CCD_diameter/2)^2) * CCD_length;

### NORMAL CONCENTRATIONS ###
norm_Aldo = 0.49;                     # Normal aldosterone concentration (nmol/L)
norm_plasma_K = 0.0042;               # Normal plasma potassium concentration (mEq/mL)
nom_intracellular_K_conc = 0.15;      # Normal intracellular potassium concentration (mEq/mL)
norm_plasma_Na = 0.14;                # Normal plasma sodium concentration (mEq/mL)
principal_cell_intracellular_Na = 0.008;  # Principal cell intracellular sodium (mEq/mL)

### INITIAL TUBULAR LUMINAL CONCENTRATIONS ###
DCT_luminal_K_conc0 = 0.0055;         # Initial DCT luminal potassium concentration (mEq/mL)
CNT_luminal_K_conc0 = 0.0072;         # Initial CNT luminal potassium concentration (mEq/mL)
CCD_luminal_K_conc0 = 0.032;          # Initial CCD luminal potassium concentration (mEq/mL)

### SODIUM BALANCE PARAMETERS ###
# Calculate sodium that must be delivered to DCT for sodium balance
filtered_Na = GFR * norm_plasma_Na;                 # Filtered sodium load (mEq/min)
Na_out_loH0 = const_Nain/(1 - 0.95);            # Sodium out of LoH (assuming 95% reabsorbed in DCT/CNT/CD)
eta_PT_LoH = (filtered_Na - Na_out_loH0) / filtered_Na;  # Fractional PT/LoH sodium reabsorption

# MCD sodium reabsorption (assumes 50% reabsorption in DCT-CCD, before MCD)
norm_Na_reabsorption_MCD = (Na_out_loH0 * 0.5 - const_Nain);

### POTASSIUM BALANCE PARAMETERS ###
# Calculate potassium load delivered to MCD
filtered_K_load = norm_plasma_K * GFR;
potassium_in_MCD0 = filtered_K_load * ((1 - eta_PT_LoH) + 0.12);  # Net of reabsorbed and secreted

# MCD potassium reabsorption rate required for potassium balance
K_reabsorption_MCD_rate0 = (potassium_in_MCD0 - const_Kin) / number_of_nephrons;

### WATER REABSORPTION FRACTIONS ###
CNT_water_reabs_fraction = 0.7;       # CNT water reabsorption fraction
CCD_water_reabs_fraction = 0.75;      # CCD water reabsorption fraction

### POTASSIUM SECRETION PARAMETERS ###
baseline_K_luminal_permeability = 2.4935e-5;  # Baseline luminal potassium permeability (cm/s)
K_basolateral_permeability = 3.43e-5;         # Basolateral potassium permeability (cm/s)
J_Na_active_max = 14.66e-5;                   # Maximum active sodium transport (mmol/min/cm2)

### MEMBRANE POTENTIAL DIFFERENCES ###
luminal_potential_difference = -18.4;      # Luminal potential difference (mV)
basolateral_potential_difference = -78.2;  # Basolateral potential difference (mV)

### MCD REGULATION PARAMETERS ###
m_Na_MCD = 0.69775;        # Na+ effect on MCD potassium secretion (min/mEq)

### DISEASE EFFECTS ###
hyperaldo_effect = 0;      # Hyperaldosteronism effect (set to 0 for normal conditions)



######## Model equations ########


### Systemic Potassium ###
plasma_K = K / V_ecf;                                #(mEq/mL)
intracellular_K_conc = intracellular_K / V_ic;
intracellular_potassium_flux = Q_K_intracellular * (plasma_K - norm_plasma_K - (intracellular_K_conc - nom_intracellular_K_conc));


### Aldosterone Regulation ###
# Aldosterone, nmol/L
# ===== BEGIN EDITABLE SECTION: Aldosterone equation (only modify within this block) =====
# TODO: replace the Aldo equation from the constant norm_Aldo with actual equation for aldosterone level
# TODO: e.g. Aldo = norma_Aldo * (some function of plasma potassium and sodium intake)
# TODO: use a simple function that is easy to understand and implement, e.g. exponential, sigmoid, polynomial, logarithmic, etc.
# TODO: make sure the aldosterone level is always positive and smoothly increasing or decreasing. No near instantaneous jumps or discontinuities.
# TODO: avoid introducing non-biologically inspired constants
# TODO: do not formulate it as a differential equation d/dt(Aldo), it should be a simple algebraic equation.
# TODO: do not replace any other existing equations or parameters.
Aldo = norm_Aldo * 1;
# ===== END EDITABLE SECTION =====

# Effect of aldosterone on tubular potassium secretion
Aldo_effect_on_K_secretion = max(0, 1 + Aldo_KSec_scale * (Aldo - norm_Aldo));
J_Na_active_max_eff = J_Na_active_max * max(0, Aldo_effect_on_K_secretion);


### PT/LoH Na+ and K+ Reabsorption ###
# Glomerular Filtration of water, potassium, and sodium
SNGFR = GFR / number_of_nephrons;                    #(ml/min)
filtered_K = max(0, SNGFR * plasma_K);               #(mEq/min/nephron)
filtered_Na = SNGFR * norm_plasma_Na                #(mEq/min/nephron)


### PT Sodium Reabsorption ###
max_PT_LoH_reabsorption = filtered_Na * 0.96;
Na_out_LoH = max(Nain / (1 - 0.95) / number_of_nephrons,
                 filtered_Na - max_PT_LoH_reabsorption);
eta_PT_LoH = (filtered_Na - Na_out_LoH) / filtered_Na;


### PT Potassium Reabsorption ###
K_reabsorption_PT_LoH = eta_PT_LoH * filtered_K;      #(mEq/min)
PT_LoH_K_out = filtered_K - K_reabsorption_PT_LoH;    #(mEq/min)


### DCT K+ Secretion ###
DCT_luminal_K_conc = max(0, DCT_luminal_K_amount) / DCT_volume;
CNT_luminal_K_conc = max(0, CNT_luminal_K_amount) / CNT_volume;
CCD_luminal_K_conc = max(0, CCD_luminal_K_amount) / CCD_volume;

normalized_luminal_potential_difference = F * luminal_potential_difference / (R * T);
normalized_basolateral_potential_difference = F * basolateral_potential_difference / (R * T);

DCT_K_in = PT_LoH_K_out;
DCT_water_in = SNGFR * (1 - eta_PT_LoH);

DCT_K_passive_flux_lumenal = baseline_K_luminal_permeability * normalized_luminal_potential_difference *
  (-DCT_luminal_K_conc + DCT_cell_K_conc * exp(-normalized_luminal_potential_difference)) /
  (1 - exp(-normalized_luminal_potential_difference));

DCT_K_passive_flux_basolateral = -K_basolateral_permeability * normalized_basolateral_potential_difference *
  (-plasma_K + DCT_cell_K_conc * exp(-normalized_basolateral_potential_difference)) /
  (1 - exp(-normalized_basolateral_potential_difference));

K_K = (0.1 * (1 + 140 / 18.5)) / 1000;
K_Na_DCT = (0.2 * (1 + DCT_cell_K_conc * 1000 / 8.33)) / 1000;

DCT_K_active_flux_basolateral = (2/3) * J_Na_active_max_eff *
  ((principal_cell_intracellular_Na / (principal_cell_intracellular_Na + K_Na_DCT))^3) *
  ((plasma_K / (plasma_K + K_K))^2);

### CNT K+ Secretion ###
CNT_K_passive_flux_lumenal = baseline_K_luminal_permeability * normalized_luminal_potential_difference *
  (-CNT_luminal_K_conc + CNT_cell_K_conc * exp(-normalized_luminal_potential_difference)) /
  (1 - exp(-normalized_luminal_potential_difference));

CNT_K_passive_flux_basolateral = -K_basolateral_permeability * normalized_basolateral_potential_difference *
  (-plasma_K + CNT_cell_K_conc * exp(-normalized_basolateral_potential_difference)) /
  (1 - exp(-normalized_basolateral_potential_difference));

K_Na_CNT = (0.2 * (1 + CNT_cell_K_conc * 1000 / 8.33)) / 1000;

CNT_K_active_flux_basolateral = (2/3) * J_Na_active_max_eff *
  ((principal_cell_intracellular_Na / (principal_cell_intracellular_Na + K_Na_CNT))^3) *
  ((plasma_K / (plasma_K + K_K))^2);


### CCD K+ Secretion ###
CCD_K_passive_flux_lumenal = baseline_K_luminal_permeability * normalized_luminal_potential_difference *
  (-CCD_luminal_K_conc + CCD_cell_K_conc * exp(-normalized_luminal_potential_difference)) /
  (1 - exp(-normalized_luminal_potential_difference));

CCD_K_passive_flux_basolateral = -K_basolateral_permeability * normalized_basolateral_potential_difference *
  (-plasma_K + CCD_cell_K_conc * exp(-normalized_basolateral_potential_difference)) /
  (1 - exp(-normalized_basolateral_potential_difference));

K_Na_CCD = (0.2 * (1 + CCD_cell_K_conc * 1000 / 8.33)) / 1000;

CCD_K_active_flux_basolateral = (2/3) * J_Na_active_max_eff *
  ((principal_cell_intracellular_Na / (principal_cell_intracellular_Na + K_Na_CCD))^3) *
  ((plasma_K / (plasma_K + K_K))^2);


### Tubular Surface Areas ###
DCT_SA = pi * DCT_diameter * DCT_length;
CNT_SA = pi * CNT_diameter * CNT_length;
CCD_SA = pi * CCD_diameter * CCD_length;


### Tubular Potassium Secretion Rates ###
DCT_K_secretion_rate = DCT_K_passive_flux_lumenal * DCT_SA;
CNT_K_secretion_rate = CNT_K_passive_flux_lumenal * CNT_SA * principal_fraction_CNT;
CCD_K_secretion_rate = CCD_K_passive_flux_lumenal * CCD_SA * principal_fraction_CCD;


### Tubular Water Flows ###
DCT_water_out = DCT_water_in;
# CNT_water_out = DCT_water_out * (1 - CNT_water_reabs_fraction)
CCD_water_out = DCT_water_in * (1 - CCD_water_reabs_fraction);


### Potassium Outflows ###
DCT_K_out = DCT_luminal_K_conc * DCT_water_in;
CNT_K_out = CNT_luminal_K_conc * DCT_water_in;
CCD_K_out = CCD_luminal_K_conc * CCD_water_out;


### MCD K+ Reabsorption ###
K_MCD_effect = max(0, exp(m_plasmaK_MCD * ((norm_plasma_K - plasma_K) / norm_plasma_K)) - 1);
Na_reabsorption_MCD = max(0, (Na_out_LoH * 0.5 - Nain / number_of_nephrons));
K_secretion_MCD = max(0, (norm_Na_reabsorption_MCD / number_of_nephrons - Na_reabsorption_MCD) * m_Na_MCD);
K_reabsorption_MCD_rate = (K_reabsorption_MCD_rate0 + K_MCD_effect + K_secretion_MCD);
K_reabsorption_CD = min(K_reabsorption_MCD_rate, CCD_K_out);


### K+ Excretion ###
CD_K_out = number_of_nephrons * (CCD_K_out - K_reabsorption_CD);  #(mEq/min)


### Differential Equations ###
d/dt(K) = Kin + Kinfusion - CD_K_out - intracellular_potassium_flux;
d/dt(intracellular_K) = intracellular_potassium_flux;
d/dt(DCT_luminal_K_amount) = DCT_K_in + DCT_K_secretion_rate - DCT_K_out;
d/dt(CNT_luminal_K_amount) = DCT_K_out + CNT_K_secretion_rate - CNT_K_out;
d/dt(CCD_luminal_K_amount) = CNT_K_out + CCD_K_secretion_rate - CCD_K_out;
d/dt(DCT_cell_K_conc) = (-DCT_K_passive_flux_lumenal + DCT_K_passive_flux_basolateral + DCT_K_active_flux_basolateral) / SV_DCT;
d/dt(CNT_cell_K_conc) = (-CNT_K_passive_flux_lumenal + CNT_K_passive_flux_basolateral + CNT_K_active_flux_basolateral) / SV_CNT;
d/dt(CCD_cell_K_conc) = (-CCD_K_passive_flux_lumenal + CCD_K_passive_flux_basolateral + CCD_K_active_flux_basolateral) / SV_CCD;
d/dt(potassium_excretion_rate) = CD_K_out;  # mEq/min

"