Doxorubicin addition test#
using ProgressLogging
using OrdinaryDiffEq
using ModelingToolkit
using Plots
using DataFrames
using CSV
using ECMEDox
using ECMEDox: second, mM, Hz, μM
Plots.default(lw=2, size=(600, 600))
tend = 1000.0second
bcl = 1second
@named sys = build_model(; bcl, tend)
@unpack DOX, ρC4, ρC3 = sys
sts = unknowns(sys)
u0 = build_u0(sys)
62-element Vector{Pair{Symbolics.Num, Float64}}:
sox_i(t) => 0.0009551938366685581
h2o2_i(t) => 0.0007085981112491873
gssg_i(t) => 2.092347017623283
Q_n(t) => 1877.6012975036206
Qdot_n(t) => 151.15043772121842
QH2_n(t) => 35.91753587245618
QH2_p(t) => 35.86290819940413
Qdot_p(t) => 21.81190373831128
cytb_1(t) => 209.8354978086165
cytb_2(t) => 75.36600796391296
⋮
ca_jsr(t) => 1265.5645352477409
ca_ss(t) => 0.27469188451378845
ca_m(t) => 1.118702765625523
adp_i(t) => 152.965321024685
adp_m(t) => 60.81807906669693
nadh_m(t) => 1671.260518639995
dpsi(t) => 153.61961418650026
sox_m(t) => 5.188491782991169e-6
vm(t) => -84.60049598496542
The phase transition (of the Q cycle) is between 250uM to 260uM of DOX
prob = ODEProblem(sys, u0, tend, [DOX => 250μM])
alg = FBDF()
opts = (; reltol=1e-6, abstol=1e-6, progress=true, maxiters=1e8)
@time sol = solve(prob, alg; opts...)
idxs = (sys.t/1000, sys.vm)
plot(sol, idxs=idxs, tspan=(100second, 103second), lab=false, title="PM potential")
18.755678 seconds (31.58 M allocations: 1.843 GiB, 5.06% gc time, 44.77% compilation time)
data:image/s3,"s3://crabby-images/af99b/af99b36b426acf9a3a35beacc5c5b0e75ef28819" alt="_images/46c0fd516aa18c28970ca8cdb65407be7ba2e3f3ceb4e80251d4b01b76d61b42.png"
idxs = (sys.t/1000, [sys.atp_i / sys.adp_i])
plot(sol, idxs=idxs, tspan=(100second, 103second), lab="DOX=250", title="ATP:ADP")
data:image/s3,"s3://crabby-images/e71bb/e71bb7e32d095e334b9dc1e2b3c4f89b49ac020b" alt="_images/140b72a9a66b0cac5841a45c8d107aa74337ef13641eb2a01b4b12d477307555.png"
prob0 = ODEProblem(sys, u0, tend, [DOX => 260μM, ρC4 => 325μM])
prob1 = ODEProblem(sys, u0, tend, [DOX => 260μM, ρC4 => 500μM])
prob2 = ODEProblem(sys, u0, tend, [DOX => 260μM, ρC3 => 500μM])
@time sol0 = solve(prob0, alg; opts...)
@time sol1 = solve(prob1, alg; opts...)
@time sol2 = solve(prob2, alg; opts...)
idxs = (sys.t/1000, sys.vm)
11.968919 seconds (7.63 M allocations: 774.873 MiB, 2.19% gc time, 18.18% compilation time)
23.962989 seconds (10.28 M allocations: 1.267 GiB, 4.31% gc time, 8.59% compilation time)
13.945377 seconds (8.17 M allocations: 892.225 MiB, 1.99% gc time, 15.24% compilation time)
((1//1000)*t, vm(t))
plot(sol0, idxs=idxs, lab="DOX=260", title="PM potential")
data:image/s3,"s3://crabby-images/6380e/6380e8bef5964f7ef0f102250f1179a2ed785367" alt="_images/049c8bc944d20e31ec5ee3cff59961b51ec33f59d0cfbfd4d51eadb86792b089.png"
plot(sol1, idxs=idxs, lab="DOX=260, ρC4=500", title="PM potential")
data:image/s3,"s3://crabby-images/bba48/bba48007414f6f4439d5efb45ec000dbf32f1b16" alt="_images/03f60419c46c230e94231be9374991fcbe7b7348aeb13295570dd37506e39654.png"
plot(sol2, idxs=idxs, lab="DOX=260, ρC3=500", title="PM potential")
data:image/s3,"s3://crabby-images/8da30/8da308e1aae2b90020998e09b8f0018cc074e756" alt="_images/a59419ef975bb0423a5da5cfb3021c436ddb79896dc39d839423c0cec12f79ed.png"
idxs = (sys.t/1000, [sys.atp_i / sys.adp_i])
tspan=(100second, 200second)
plot(sol0, idxs=idxs, label="C4 325", title="ATP:ADP"; tspan)
plot!(sol1, idxs=idxs, label="C4 500", line=:dash; tspan)
plot!(sol2, idxs=idxs, label="C3 500", line=:dot; tspan)
data:image/s3,"s3://crabby-images/6def3/6def35d04238fb76c8b61b71df5168cb22808adb" alt="_images/30bf1302116127881574332eaf04ca0f9295fd1a2fc8fec1fe41212899beeb05.png"
@unpack Q_n, Qdot_n, QH2_n, QH2_p, Qdot_p, Q_p, fes_ox, fes_rd, cytc_ox, cytc_rd = sys
plot(sol0, idxs=[Q_n, Qdot_n, QH2_n, QH2_p, Qdot_p, Q_p], title="Q cycle", legend=:right)
data:image/s3,"s3://crabby-images/c44bb/c44bbd5d2843b90b1dcb53bd69f167fdb1a8321d" alt="_images/6f4ef4358d667b406d9140aa9a4d213d31e60dd36b948efdc1f08a4887e8cbff.png"
idxs = (sys.t/1000, sys.dpsi)
tspan=(100second, 200second)
plot(sol0, idxs=idxs, title="MMP", lab="C4 325" ; tspan)
plot!(sol1, idxs=idxs, label="C4 500"; tspan)
plot!(sol2, idxs=idxs, label="C3 500"; tspan, xlabel="Time (s)", ylabel="MMP (mV)")
data:image/s3,"s3://crabby-images/88cb7/88cb7d7db8c00cdfdaf4ccc6803bfe7c0d14e875" alt="_images/2a17805fbad17c53b854ed2b4203ab23e48bfa72b9a6eac6a563e2384a5532c4.png"
idxs = (sys.t/1000, sys.vO2)
plot(sol0, idxs=idxs, label="C4 325", title="Oxygen consumption")
plot!(sol1, idxs=idxs, label="C4 500", line=:dash)
plot!(sol2, idxs=idxs, label="C3 500", line=:dot, xlabel="Time (s)", ylabel="vO2 (μM/ms)")
data:image/s3,"s3://crabby-images/38b83/38b83fb6deecfc1cd6662a0a2db481c8b07db510" alt="_images/e66d0421299faad7c211cafd97da204947b3107b3951d3e10c49cb61e366cbc2.png"
idxs = (sys.t/1000, sys.vROS / (sys.vO2 + sys.vROS))
plot(sol0, idxs=idxs, label="C4 325", title="ROS vO2 fraction")
plot!(sol1, idxs=idxs, label="C4 500", line=:dash)
plot!(sol2, idxs=idxs, label="C3 500", line=:dot, xlabel="Time (s)")
data:image/s3,"s3://crabby-images/64f04/64f0429dc86dc27708aea1abfe8bb142633ab784" alt="_images/2436ba6d2e16994f9da9dff35793ca8753a65fbc5cb4bed1a687fb4f3df2c158.png"
idxs = (sys.t/1000, sys.nadh_m)
plot(sol0, idxs=idxs, label="C4 325", title="NADH")
plot!(sol1, idxs=idxs, label="C4 500", line=:dash)
plot!(sol2, idxs=idxs, label="C3 500", line=:dot, xlabel="Time (s)")
data:image/s3,"s3://crabby-images/4d311/4d3111f9c9646d4073f9311da6d66ae5218f908a" alt="_images/f49dcd01348de3a3266cd3d6a0061e3a6d9b56f6478e928d4617a97f5a84e65a.png"
This notebook was generated using Literate.jl.