-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathpsySI.py
364 lines (338 loc) · 10.1 KB
/
psySI.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
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
import math as m
# All functions expect base SI units for any arguments given
# DBT - Dry bulb temperature - Kelvins, K
# DPT - Dew point temperature - Kelvins, K
# H - Specific enthalpy - kiloJoules per kilogram, kJ/kg
# P - Atmospheric pressure - Pascals, Pa
# Pw - Water vapor partial pressure - Pascals, Pa
# RH - Relative humidity - Decimal (i.e. not a percentage)
# V - Specific volume - Cubic meters per kilogram, m^3/kg
# W - Humidity ratio - kilograms per kilograms, kg/kg
# WBT - Wet bulb temperature - Kelvins, K
# Minimum dry bulb temperature
Min_DBT=273.15
# Maximum dry bulb temperature
Max_DBT=473.15
# Convergence tolerance
TOL=0.0005
def __DBT_H_RH_P(H, RH, P):
[DBTa, DBTb]=[Min_DBT, Max_DBT]
DBT=(DBTa+DBTb)/2
while DBTb-DBTa>TOL:
ya=__W_DBT_RH_P(DBTa, RH, P)-__W_DBT_H(DBTa, H)
y=__W_DBT_RH_P(DBT, RH, P)-__W_DBT_H(DBT, H)
if __is_positive(y)==__is_positive(ya):
DBTa=DBT
else:
DBTb=DBT
DBT=(DBTa+DBTb)/2
return DBT
def __DBT_H_V_P(H, V, P):
[DBTa, DBTb]=[Min_DBT, Max_DBT]
DBT=(DBTa+DBTb)/2
while DBTb-DBTa>TOL:
ya=__W_DBT_V_P(DBTa, V, P)-__W_DBT_H(DBTa, H)
y=__W_DBT_V_P(DBT, V, P)-__W_DBT_H(DBT, H)
if __is_positive(y)==__is_positive(ya):
DBTa=DBT
else:
DBTb=DBT
DBT=(DBTa+DBTb)/2
return DBT
def __DBT_H_W(H, W):
[DBTa, DBTb]=[Min_DBT, Max_DBT]
DBT=(DBTa+DBTb)/2
while DBTb-DBTa>TOL:
ya=W-__W_DBT_H(DBTa, H)
y=W-__W_DBT_H(DBT, H)
if __is_positive(y)==__is_positive(ya):
DBTa=DBT
else:
DBTb=DBT
DBT=(DBTa+DBTb)/2
return DBT
def __DBT_H_WBT_P(H, WBT, P):
[DBTa, DBTb]=[Min_DBT, Max_DBT]
DBT=(DBTa+DBTb)/2
while DBTb-DBTa>TOL:
ya=__W_DBT_WBT_P(DBTa, WBT, P)-__W_DBT_H(DBTa, H)
y=__W_DBT_WBT_P(DBT, WBT, P)-__W_DBT_H(DBT, H)
if __is_positive(y)==__is_positive(ya):
DBTa=DBT
else:
DBTb=DBT
DBT=(DBTa+DBTb)/2
return DBT
def __DBT_RH_V_P(RH, V, P):
[DBTa, DBTb]=[Min_DBT, Max_DBT]
DBT=(DBTa+DBTb)/2
while DBTb-DBTa>TOL:
ya=__W_DBT_RH_P(DBTa, RH, P)-__W_DBT_V_P(DBTa, V, P)
y=__W_DBT_RH_P(DBT, RH, P)-__W_DBT_V_P(DBT, V, P)
if __is_positive(y)==__is_positive(ya):
DBTa=DBT
else:
DBTb=DBT
DBT=(DBTa+DBTb)/2
return DBT
def __DBT_RH_W_P(RH, W, P):
[DBTa, DBTb]=[Min_DBT, Max_DBT]
DBT=(DBTa+DBTb)/2
while DBTb-DBTa>TOL:
ya=__W_DBT_RH_P(DBTa, RH, P)-W
y=__W_DBT_RH_P(DBT, RH, P)-W
if __is_positive(y)==__is_positive(ya):
DBTa=DBT
else:
DBTb=DBT
DBT=(DBTa+DBTb)/2
return DBT
def __DBT_RH_WBT_P(RH, WBT, P):
[DBTa, DBTb]=[Min_DBT, Max_DBT]
DBT=(DBTa+DBTb)/2
while DBTb-DBTa>TOL:
ya=__W_DBT_WBT_P(DBTa, WBT, P)-__W_DBT_RH_P(DBTa, RH, P)
y=__W_DBT_WBT_P(DBT, WBT, P)-__W_DBT_RH_P(DBT, RH, P)
if __is_positive(y)==__is_positive(ya):
DBTa=DBT
else:
DBTb=DBT
DBT=(DBTa+DBTb)/2
return DBT
def __DBT_V_W_P(V, W, P):
[DBTa, DBTb]=[Min_DBT, Max_DBT]
DBT=(DBTa+DBTb)/2
while DBTb-DBTa>TOL:
ya=W-__W_DBT_V_P(DBTa, V, P)
y=W-__W_DBT_V_P(DBT, V, P)
if __is_positive(y)==__is_positive(ya):
DBTa=DBT
else:
DBTb=DBT
DBT=(DBTa+DBTb)/2
return DBT
def __DBT_V_WBT_P(V, WBT, P):
[DBTa, DBTb]=[Min_DBT, Max_DBT]
DBT=(DBTa+DBTb)/2
while DBTb-DBTa>TOL:
ya=__W_DBT_WBT_P(DBTa, WBT, P)-__W_DBT_V_P(DBTa, V, P)
y=__W_DBT_WBT_P(DBT, WBT, P)-__W_DBT_V_P(DBT, V, P)
if __is_positive(y)==__is_positive(ya):
DBTa=DBT
else:
DBTb=DBT
DBT=(DBTa+DBTb)/2
return DBT
def __DBT_W_WBT_P(W, WBT, P):
[DBTa, DBTb]=[Min_DBT, Max_DBT]
DBT=(DBTa+DBTb)/2
while DBTb-DBTa>TOL:
ya=__W_DBT_WBT_P(DBTa, WBT, P)-W
y=__W_DBT_WBT_P(DBT, WBT, P)-W
if __is_positive(y)==__is_positive(ya):
DBTa=DBT
else:
DBTb=DBT
DBT=(DBTa+DBTb)/2
return DBT
# ASHRAE 2009 Chapter 1 Equation 39
def __DPT_Pw(Pw):
Pw=Pw/1000
C14=6.54
C15=14.529
C16=0.7389
C17=0.09486
C18=0.4569
a=m.log(Pw)
return (C14+C15*a+C16*a**2+C17*a**3+C18*Pw**0.1984)+273.15
# ASHRAE 2009 Chapter 1 Equation 32
def __H_DBT_W(DBT, W):
if __valid_DBT(DBT):
DBT=DBT-273.15
return 1.006*DBT+W*(2501+1.86*DBT)
def __is_positive(x):
if x>0:
return True
else:
return False
# ASHRAE 2009 Chapter 1 Equation 22
def __Pw_W_P(W, P):
return W*P/(W+0.621945)
# ASHRAE 2009 Chapter 1 Equation 6
def __Pws(DBT):
if __valid_DBT(DBT):
C8=-5.8002206*10**3
C9=1.3914993
C10=-4.8640239*10**-2
C11=4.1764768*10**-5
C12=-1.4452093*10**-8
C13=6.5459673
return m.exp(C8/DBT+C9+C10*DBT+C11*DBT**2+C12*DBT**3+C13*m.log(DBT))
def state(prop1, prop1val, prop2, prop2val,P):
if prop1==prop2:
print("Properties must be independent.")
return
prop=["DBT","WBT","RH","W","V","H"]
if prop1 not in prop or prop2 not in prop:
print("Valid property must be given.")
return
prop1i=prop.index(prop1)
prop2i=prop.index(prop2)
if prop1i<prop2i:
cd1=prop1
cd1val=prop1val
cd2=prop2
cd2val=prop2val
else:
cd1=prop2
cd1val=prop2val
cd2=prop1
cd2val=prop1val
if cd1=="DBT":
DBT=cd1val
if cd2=="WBT":
WBT=cd2val
W=__W_DBT_WBT_P(DBT, WBT, P)
H=__H_DBT_W(DBT, W)
RH=__RH_DBT_W_P(DBT, W, P)
V=__V_DBT_W_P(DBT, W, P)
elif cd2=="RH":
RH=cd2val
W=__W_DBT_RH_P(DBT, RH, P)
H=__H_DBT_W(DBT, W)
V=__V_DBT_W_P(DBT, W, P)
WBT=__WBT_DBT_W_P(DBT, W, P)
elif cd2=="W":
W=cd2val
H=__H_DBT_W(DBT, W)
RH=__RH_DBT_W_P(DBT, W, P)
V=__V_DBT_W_P(DBT, W, P)
WBT=__WBT_DBT_W_P(DBT, W, P)
elif cd2=="V":
V=cd2val
W=__W_DBT_V_P(DBT, V, P)
H=__H_DBT_W(DBT, W)
RH=__RH_DBT_W_P(DBT, W, P)
WBT=__WBT_DBT_W_P(DBT, W, P)
elif cd2=="H":
H=cd2val
W=__W_DBT_H(DBT, H)
RH=__RH_DBT_W_P(DBT, W, P)
V=__V_DBT_W_P(DBT, W, P)
WBT=__WBT_DBT_W_P(DBT, W, P)
elif cd1=="WBT":
WBT=cd1val
if cd2=="RH":
RH=cd2val
DBT=__DBT_RH_WBT_P(RH, WBT, P)
W=__W_DBT_RH_P(DBT, RH, P)
H=__H_DBT_W(DBT, W)
V=__V_DBT_W_P(DBT, W, P)
elif cd2=="W":
W=cd2val
DBT=__DBT_W_WBT_P(W, WBT, P)
H=__H_DBT_W(DBT, W)
RH=__RH_DBT_W_P(DBT, W, P)
V=__V_DBT_W_P(DBT, W, P)
elif cd2=="V":
V=cd2val
DBT=__DBT_V_WBT_P(V, WBT, P)
W=__W_DBT_V_P(DBT, V, P)
H=__H_DBT_W(DBT, W)
RH=__RH_DBT_W_P(DBT, W, P)
elif cd2=="H":
H=cd2val
DBT=__DBT_H_WBT_P(H, WBT, P)
W=__W_DBT_H(DBT, H)
RH=__RH_DBT_W_P(DBT, W, P)
V=__V_DBT_W_P(DBT, W, P)
elif cd1=="RH":
RH=cd1val
if cd2=="W":
W=cd2val
DBT=__DBT_RH_W_P(RH, W, P)
H=__H_DBT_W(DBT, W)
V=__V_DBT_W_P(DBT, W, P)
WBT=__WBT_DBT_W_P(DBT, W, P)
elif cd2=="V":
V=cd2val
DBT=__DBT_RH_V_P(RH, V, P)
W=__W_DBT_RH_P(DBT, RH, P)
H=__H_DBT_W(DBT, W)
WBT=__WBT_DBT_W_P(DBT, W, P)
elif cd2=="H":
H=cd2val
DBT=__DBT_H_RH_P(H, RH, P)
W=__W_DBT_RH_P(DBT, RH, P)
V=__V_DBT_W_P(DBT, W, P)
WBT=__WBT_DBT_W_P(DBT, W, P)
elif cd1=="W":
W=cd1val
if cd2=="V":
V=cd2val
DBT=__DBT_V_W_P(V, W, P)
H=__H_DBT_W(DBT, W)
RH=__RH_DBT_W_P(DBT, W, P)
WBT=__WBT_DBT_W_P(DBT, W, P)
elif cd2=="H":
H=cd2val
DBT=__DBT_H_W(H, W)
RH=__RH_DBT_W_P(DBT, W, P)
V=__V_DBT_W_P(DBT, W, P)
WBT=__WBT_DBT_W_P(DBT, W, P)
elif cd1=="V":
V=cd1val
H=cd2val
DBT=__DBT_H_V_P(H, V, P)
W=__W_DBT_V_P(DBT, V, P)
RH=__RH_DBT_W_P(DBT, W, P)
WBT=__WBT_DBT_W_P(DBT, W, P)
return [DBT, H, RH, V, W, WBT]
# ASHRAE 2009 Chapter 1 Equation 22 and Equation 24
def __RH_DBT_W_P(DBT, W, P):
if __valid_DBT(DBT):
return W*P/((0.621945+W)*__Pws(DBT))
# ASHRAE 2009 Chapter 1 Equation 28
def __V_DBT_W_P(DBT, W, P):
if __valid_DBT(DBT):
return 287.042*DBT*(1+1.607858*W)/P
# ASHRAE 2009 Chapter 1 Equation 32
def __W_DBT_H(DBT, H):
if __valid_DBT(DBT):
DBT=DBT-273.15
return (H-1.006*DBT)/(2501+1.86*DBT)
# ASHRAE 2009 Chapter 1 Equation 22 and Equation 24
def __W_DBT_RH_P(DBT, RH, P):
if __valid_DBT(DBT):
Pw=RH*__Pws(DBT)
return 0.621945*Pw/(P-Pw)
# ASHRAE 2009 Chapter 1 Equation 28
def __W_DBT_V_P(DBT, V, P):
if __valid_DBT(DBT):
return (P*V-287.042*DBT)/(1.607858*287.042*DBT)
# ASHRAE 2009 Chapter 1 Equation 35
def __W_DBT_WBT_P(DBT, WBT, P):
if __valid_DBT(DBT):
DBT=DBT-273.15
WBT=WBT-273.15
return ((2501-2.326*WBT)*__W_DBT_RH_P(WBT+273.15,1,P)-1.006*(DBT-WBT))/\
(2501+1.86*DBT-4.186*WBT)
# ASHRAE 2009 Chapter 1 Equation 35
def __WBT_DBT_W_P(DBT, W, P):
if __valid_DBT(DBT):
WBTa=__DPT_Pw(__Pw_W_P(W, P))
WBTb=DBT
WBT=(WBTa+WBTb)/2
while WBTb-WBTa>TOL:
Ws=__W_DBT_WBT_P(DBT, WBT, P)
if W>Ws:
WBTa=WBT
else:
WBTb=WBT
WBT=(WBTa+WBTb)/2
return WBT
def __valid_DBT(DBT):
if Min_DBT<=DBT<=Max_DBT:
return True
else:
return False