-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathVessel.py
179 lines (131 loc) · 5.26 KB
/
Vessel.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
#------------------------------------------------------------------------------
# The Vessel class represents a segment of blood vessel, componsed of endothelial
# cells, and perfused with blood flow (Newtonian fluid, Poiseuille flow)
#
# Lowell Taylor Edgar
# University of Edinburgh
# 2019
from math import sqrt
from math import pi
from math import exp
import numpy as np
#import random as rand
from Input import *
from LTETools import *
from ECell import *
#------------------------------------------------------------------------------
class Vessel:
# Vessel constructor
def __init__(self, ID=0, node1=0, node2=0, cell_num =0, mu = 1.):
# Vessel number identifier
ID : int
self.ID = ID
# Vessel type identifier
type : str
self.type = "capillary"
# Node number identifiers (from master node list)
n0 : int
n1 : int
self.n0 = node1
self.n1 = node2
# Vessel length
L : float
self.L = 1.
# Vessel unit vector
unit : Vect
self.unit = Vect()
# Number of cells residing in the vessel
num_cells : int
self.num_cells = cell_num
self.old_num_cells = cell_num
# Vessel diameter
D : float
self.D = cell_num*i_cell_size/pi
self.Dold = 0.
# Dynamic viscosity of the fluid
mu : float
self.mu = mu
# Vessel conductance
G : float
self.G = 0.
# Pressure at first node
P0 : float
self.P0 = 0.
# Pressure at the second node
P1 : float
self.P1 = 0.
# Flow through the vessel
Q : float
self.Q = 0.
# List of resident endothelial cells
cells : list[ECell]
self.cells = []
for i in range(self.num_cells):
# Seed initial agent positions
if (i_rand_init == True):
xi_init = rand.uniform(0,1)
zeta_init = rand.uniform(0,1)
else:
xi_init = 0.5
zeta_init = (1/self.num_cells/2) + i*(1/self.num_cells)
pol_vect = Vect(1., 0., 0.)
self.cells.append(ECell(0, self.ID, xi_init, zeta_init, pol_vect))
# for i in range(1,self.num_cells):
# self.cells[i].zeta = 0.5 + 1e-3 + (i-1)*(0.5/(self.num_cells-1))
# Vessel shearing parameter (equivalant of conductance but for shear stress)
H : float
self. H = 0.
# Wall Shear Stress within the vessel segment
tau : float
self.tau = 0.
# Information on upstream neighbours
neigh0 : list[int]
self.neigh0 = []
# Information on downstream neighbours
neigh1 : list[int]
self.neigh1 = []
# Indicator of a Dirichlet condition
dirichlet : int
self.dirichlet = 0
# Calculate the length of the vessel based on node positions
def calc_length(self, node_pos1, node_pos2):
x0 = node_pos1[0]
y0 = node_pos1[1]
x1 = node_pos2[0]
y1 = node_pos2[1]
self.L = sqrt((x1 - x0)**2 + (y1 - y0)**2)
self.unit.x = x1 - x0
self.unit.y = y1 - y0
self.unit.unit()
# Update diameter
def update_diameter(self):
self.Dold = self.D
D0 = self.num_cells*i_cell_size/pi
mean_rho = 0
for cell in self.cells:
mean_rho += cell.rho
try:
mean_rho /= self.num_cells
except:
mean_rho = 0.
mean_rho = 1.0
self.D = D0*mean_rho
# Update Vessel conductance based on diameter, length, and dynamic viscosity
def update_conductance(self):
if (self.D != 0.):
self.G = pi*(self.D**4.)/(128.*self.mu*self.L)
self.H = (32*self.mu)/(pi*self.D**3.)
else:
self.G = 1e-3
self.H = 0.
# Calculate flow through the vessel based off of the pressure difference across the vessel
def calc_flow(self):
self.Q = -self.G*(self.P1 - self.P0)
self.tau = self.H*abs(self.Q)
# String conversion function for printing
def __str__(self):
return "Vessel {0} is a {1}: node1 = {2}; node2 = {3}; L = {4:.2f} um; num_cells = {5}; D = {6:.2f} um; P0 = {7:.2f} Pa; P1 = {8:.2f} Pa; Q = {9:.2f} nL/hr; tau = {10:.2f} Pa".format(self.ID, self.type, self.n0, self.n1, round(self.L, 2), self.num_cells, round(self.D, 2), round(self.P0/12.96, 2), round(self.P1/12.96, 2), round(self.Q/1e6, 2), round(self.tau/12.96, 2))
#------------------------------------------------------------------------------
# main program
if __name__ == "__main__":
pass