Pressure Flow Control
The model VanOsta2024 comes with the Pressure Flow Control (PFC) module.
import circadapt
import matplotlib.pyplot as plt
import numpy as np
from circadapt import VanOsta2024
model = VanOsta2024()
model.run(stable = True)
model['Solver']['store_beats'] = 10
model.run(10)
# plot
fig = plt.figure(figsize=(15,3))
plt.plot(model['Solver']['t']*1e3, model['Cavity']['p'][:, ['cLv', 'SyArt']]/133)
plt.xlabel('Time [ms]')
plt.ylabel('Pressure [mmHg]')
fig
data:image/s3,"s3://crabby-images/6ac4c/6ac4cc2b0271422ea41ac8fda0dcc2f43bdda7bf" alt="../../../_images/5330fa4e17e72835d6c92c40c9f49bec61eea8236ce918b1733f071c698e1763.png"
data:image/s3,"s3://crabby-images/6ac4c/6ac4cc2b0271422ea41ac8fda0dcc2f43bdda7bf" alt="../../../_images/5330fa4e17e72835d6c92c40c9f49bec61eea8236ce918b1733f071c698e1763.png"
By default, it is turned on to control cardiac output and mean arterial pressure.
model1 = VanOsta2024()
model1.run(stable = True)
model1['Solver']['store_beats'] = 10
model1['PFC']['p0'] = 15000
model1.run(10)
# plot
fig = plt.figure(figsize=(15,3))
plt.plot(model['Solver']['t']*1e3, model['Cavity']['p'][:, ['cLv', 'SyArt']]/133, c=[0.8, 0.8, 0.8])
plt.plot(model1['Solver']['t']*1e3, model1['Cavity']['p'][:, ['cLv', 'SyArt']]/133)
plt.xlabel('Time [ms]')
plt.ylabel('Pressure [mmHg]')
fig
data:image/s3,"s3://crabby-images/ef413/ef4134451eaba3a52773e9c655e5cf4decdc7ae5" alt="../../../_images/6c97a9a321984cf99bc6b0a9e4b9afce2d61563d26c647acab0b48ba2eea4ba1.png"
data:image/s3,"s3://crabby-images/ef413/ef4134451eaba3a52773e9c655e5cf4decdc7ae5" alt="../../../_images/6c97a9a321984cf99bc6b0a9e4b9afce2d61563d26c647acab0b48ba2eea4ba1.png"
Pressure Flow Control off
You can turn pressure flow control off.
model2 = VanOsta2024()
model2.run(stable = True)
model2['Solver']['store_beats'] = 10
model2['PFC']['is_active'] = False
model2['Patch']['Sf_act'] *= 0.5
model2['Patch']['k1'] *= 1.2
model2.run(9)
# plot
fig = plt.figure(figsize=(15,3))
plt.plot(model['Solver']['t']*1e3, model['Cavity']['p'][:, ['cLv', 'SyArt']]/133, c=[0.8, 0.8, 0.8])
plt.plot(model2['Solver']['t']*1e3, model2['Cavity']['p'][:, ['cLv', 'SyArt']]/133)
plt.xlabel('Time [ms]')
plt.ylabel('Pressure [mmHg]')
fig
data:image/s3,"s3://crabby-images/59788/59788ceb549a405f330924fbf67a176cbed6cee6" alt="../../../_images/7a9fdec75e3ad3649f887e5a7bf3bc56213d85c1bb77e09960b240bb75ed4687.png"
data:image/s3,"s3://crabby-images/59788/59788ceb549a405f330924fbf67a176cbed6cee6" alt="../../../_images/7a9fdec75e3ad3649f887e5a7bf3bc56213d85c1bb77e09960b240bb75ed4687.png"
Volume control
The total blood volume can be a model input parameter.
model3 = VanOsta2024()
model3.run(stable = True)
model3['Solver']['store_beats'] = 10
model3['PFC']['is_volume_control'] = True
model3['PFC']['target_volume'] = 0.001
model3.run(9)
# plot
fig = plt.figure(figsize=(15,3))
plt.plot(model['Solver']['t']*1e3, model['Cavity']['p'][:, ['cLv', 'SyArt']]/133, c=[0.8, 0.8, 0.8])
plt.plot(model3['Solver']['t']*1e3, model3['Cavity']['p'][:, ['cLv', 'SyArt']]/133)
plt.xlabel('Time [ms]')
plt.ylabel('Pressure [mmHg]')
fig
data:image/s3,"s3://crabby-images/aa38f/aa38f0f8ea70b4668de3e4a36369b3db0ea8c267" alt="../../../_images/e91c6611eed122f6410e375a68e342f86ff82ca09b4086b465968f3ab1c4892f.png"
data:image/s3,"s3://crabby-images/aa38f/aa38f0f8ea70b4668de3e4a36369b3db0ea8c267" alt="../../../_images/e91c6611eed122f6410e375a68e342f86ff82ca09b4086b465968f3ab1c4892f.png"