system_description: |
  # RENAL POTASSIUM REGULATION SIMULATOR

  ## TASK OVERVIEW
  Starting from an established quantitative systems pharmacology model of plasma potassium
  regulation by the kidney and aldosterone, your task is implement a mechanistic equation
  for aldosterone secretion, which is currently represented as a constant.
  Do not modify any other equations or parameters of the base model.

  ## MODEL DESCRIPTION
  The base model mechanistically simulates:
  - Renal potassium handling (filtration, reabsorption, secretion) along the nephron
  - Systemic potassium balance between intracellular and extracellular compartments
  - Feedback regulation by aldosterone
  - Pharmacodynamic effects of mineralocorticoid receptor antagonists (MRAs)
  The model integrates potassium and sodium intake, glomerular filtration rate (GFR),
  and aldosterone secretion on potassium excretion.

  Currently, aldosterone is a fixed value.
  Your task is to implement a physiologically plausible dynamic aldosterone secretion equation.

  ## PHYSIOLOGICAL MODULES INCLUDED
  - **Renal Segments**: Proximal tubule (PT), loop of Henle (LoH), distal convoluted tubule (DCT), connecting tubule (CNT), cortical collecting duct (CCD), medullary collecting duct (MCD)
  - **Ion Transport**: ROMK (luminal), Kir (basolateral), Na⁺/K⁺-ATPase (active transport)
  - **Systemic Potassium**: Two-compartment exchange (ECF and ICF) with buffering
  - **Hormonal Regulation**: Aldosterone increases Na⁺/K⁺-ATPase activity and influences potassium secretion in distal segments
  - **Pharmacology**: Spironolactone and canrenone inhibit MR via a PK-PD model

  ## SIMULATION CHARACTERISTICS
  - The simulator runs under steady-state or dynamic perturbations (diet, drug, disease)
  - Differential equations govern fluxes of potassium and sodium at each nephron segment
  - Feedback loops include functions of plasma potassium and aldosterone (this is the missing mechanistic equation to be implemented)
  - MR inhibition modifies aldosterone effects via indirect response dynamics
  - All physiological variables must change smoothly over time; instantaneous changes are not biophysically plausible
  - The inputs and outputs to the model cannot be modified when updating the model.

  ## MISSING BIOPHYSICAL FEATURE
  - The equation governing aldosterone dynamics is unkown and currently a constant in the model. The model lacks a dynamic regulatory equation
  - Your task is to infer and implement a biophysically plausible equation for aldosterone secretion in response to plasma potassium and sodium intake without altering any other model equations.
  - The equation must ensure smooth, continuous changes in aldosterone levels. Instantaneous jumps or discontinuous changes are not physiologically realistic.

  ## OPTIMIZATION TARGETS
  Modifications will be evaluated against 40 summary statistics:
  Aldosterone (Aldo) and plasma potassium (Plasma_K) values at 0, 30, 90, 120, and 300 min (10 values per scenario).
  These are measured under 4 dietary load scenarios:
  1. High K + High Na (first 10 values)
  2. High K + Low Na (second 10 values)
  3. Low K + High Na (third 10 values)
  4. Low K + Low Na (fourth 10 values)

  ## DATASET INFORMATION
  Training and validation data include Plasma [K⁺] and Aldosterone [aldosterone] from
  infusion experiments (Dluhy et al. 1972). The data pionts follow the same as the 4
  dietary load scenarios described above.

signature_description: |
  ## FRAMEWORK DETAILS
  - **Framework**: rxode2 (R package for solving ordinary differential equations)
  - **Compilation**: Model string is compiled using `rxode2(model=ode_string)`
  - **Running**: Model is run with `model$run(parameters, event_table, initial_conditions)`
  - Note the inputs and outputs to the model cannot be modified when updating the model.

  ## INPUT DETAILS
  - **ode_string**: String containing ODE system with d/dt() equations and algebraic relations

  - **parameters**: Model optimization parameters dictionary/dataframe with 5 key parameters
    * **Aldo_KSec_scale**: Fitting constant for aldosterone effect on luminal potassium permeability (L/nmol) - range: 90-120
    * **m_K_ALDO**: Slope of plasma K+ effect on plasma aldosterone (mL/mEq) - range: 850-1050
    * **m_plasmaK_MCD**: Fitting constant for plasma K+ effect on MCD reabsorption (unitless) - range: 5e-7 to 1.2e-6
    * **m_Na_ALDO**: Fitting constant for Na intake effect on plasma aldosterone (min/mEq) - range: 10-20
    * **Q_K_intracellular**: Rate constant for interstitial and intracellular potassium exchange (mL/min) - range: 250-600

  - **inputs**: Model inputs dictionary/dataframe with 3 key inputs
    * **Kin**: Potassium intake rate (mEq/min)
    * **Nain**: Sodium intake rate (mEq/min)
    * **Kinfusion**: Potassium infusion rate (mEq/min)

  - **initial_conditions**: Named vector with initial state values for 9 state variables
    * K: Extracellular potassium amount (mEq)
    * intracellular_K: Intracellular potassium amount (mEq)
    * DCT_luminal_K_amount: DCT lumen potassium amount (mEq)
    * CNT_luminal_K_amount: CNT lumen potassium amount (mEq)
    * CCD_luminal_K_amount: CCD lumen potassium amount (mEq)
    * DCT_cell_K_conc: DCT cell potassium concentration (mEq/mL)
    * CNT_cell_K_conc: CNT cell potassium concentration (mEq/mL)
    * CCD_cell_K_conc: CCD cell potassium concentration (mEq/mL)
    * potassium_excretion_rate: Cumulative potassium excretion (mEq)

  - **event_table**: rxode2 eventTable object defining:
    * Sampling times (when to record outputs)
    * Interventions (parameter changes, infusions, etc.)
    * Time units (typically 'minutes')

  ## OUTPUT DETAILS
  - **results_dataframe**: Time series dataframe returned by model$run()
    * **State variables**: All 9 integrated state variables over time
    * **Key computed variables**:
      - plasma_K: Plasma potassium concentration (mEq/mL)
      - CD_K_out: Potassium excretion rate (mEq/min)
      - Aldo: Aldosterone concentration (nmol/L)
      - intracellular_K_conc: Intracellular potassium concentration (mEq/mL)
    * **Physiological fluxes**: ~30 additional computed variables including:
      - Tubular secretion rates (DCT_K_secretion_rate, CNT_K_secretion_rate, CCD_K_secretion_rate)
      - Membrane fluxes (active/passive across luminal/basolateral membranes)
      - Renal processing variables (filtered loads, reabsorption rates)
    * **time**: Time points (minutes)
    * Shape: (n_timepoints, n_variables) where n_variables ≈ 40

task_description: |
  Implement a mechanistic, physiologically plausible dynamic aldosterone secretion equation
  in the existing renal potassium simulator.

  Requirements:
  - Replace the constant aldosterone level with a simple algebraic equation (not a differential equation)
  - Base the equation on plasma potassium and/or sodium intake (and possibly other factors)
  - Use simple mathematical functions (exponential, sigmoid, polynomial, logarithmic, etc.)
  - Ensure aldosterone is always positive and changes smoothly (no discontinuities or instantaneous jumps)
  - Avoid introducing non-biologically inspired constants
  - Keep the equation simple and easy to understand
  - Only modify the aldosterone equation within the designated EDITABLE SECTION
  - Do not replace any other existing equations or parameters

  The goal of the final simulator is to simulate plasma potassium and aldosterone dynamics in response to changes in
  dietary intake, renal function, and drug treatment using mechanistic models of nephron transport
  and hormonal feedback.

  Ensure numerical stability, proper commenting, and correct integration with existing fluxes and compartments.

  Always output None for feedback. Feedback is only for past examples to get inspiration on how to improve the simulator.