| line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
|
1
|
|
|
|
|
|
|
# Psychrometry.pm |
|
2
|
|
|
|
|
|
|
# Calculate psychrometric measures in moist air |
|
3
|
|
|
|
|
|
|
package Physics::Psychrometry; |
|
4
|
|
|
|
|
|
|
|
|
5
|
1
|
|
|
1
|
|
42744
|
use 5.008007; |
|
|
1
|
|
|
|
|
6
|
|
|
|
1
|
|
|
|
|
62
|
|
|
6
|
1
|
|
|
1
|
|
8
|
use strict; |
|
|
1
|
|
|
|
|
3
|
|
|
|
1
|
|
|
|
|
45
|
|
|
7
|
1
|
|
|
1
|
|
8
|
use warnings; |
|
|
1
|
|
|
|
|
7
|
|
|
|
1
|
|
|
|
|
1256
|
|
|
8
|
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
require Exporter; |
|
10
|
|
|
|
|
|
|
|
|
11
|
|
|
|
|
|
|
our @ISA = qw(Exporter); |
|
12
|
|
|
|
|
|
|
|
|
13
|
|
|
|
|
|
|
# Items to export into callers namespace by default. Note: do not export |
|
14
|
|
|
|
|
|
|
# names by default without a very good reason. Use EXPORT_OK instead. |
|
15
|
|
|
|
|
|
|
# Do not simply export all your public functions/methods/constants. |
|
16
|
|
|
|
|
|
|
|
|
17
|
|
|
|
|
|
|
# This allows declaration use Physics::Psychrometry ':all'; |
|
18
|
|
|
|
|
|
|
# If you do not need this, moving things directly into @EXPORT or @EXPORT_OK |
|
19
|
|
|
|
|
|
|
# will save memory. |
|
20
|
|
|
|
|
|
|
our %EXPORT_TAGS = ( 'all' => [ qw( |
|
21
|
|
|
|
|
|
|
|
|
22
|
|
|
|
|
|
|
) ] ); |
|
23
|
|
|
|
|
|
|
|
|
24
|
|
|
|
|
|
|
our @EXPORT_OK = ( @{ $EXPORT_TAGS{'all'} } ); |
|
25
|
|
|
|
|
|
|
|
|
26
|
|
|
|
|
|
|
our @EXPORT = qw( |
|
27
|
|
|
|
|
|
|
|
|
28
|
|
|
|
|
|
|
); |
|
29
|
|
|
|
|
|
|
|
|
30
|
|
|
|
|
|
|
our $VERSION = '1.2'; |
|
31
|
|
|
|
|
|
|
|
|
32
|
|
|
|
|
|
|
# based on http://www.bae.uky.edu/gates/psych/PTM/dbrh2al.c |
|
33
|
|
|
|
|
|
|
#The dry-bulb temperature (C) =? 24.6 |
|
34
|
|
|
|
|
|
|
#The relative humidity (%) =? 68 |
|
35
|
|
|
|
|
|
|
#The air pressure (kPa) =? 102 |
|
36
|
|
|
|
|
|
|
# e is 2.104209 |
|
37
|
|
|
|
|
|
|
#The dewpoint temperature (C) = 18.324036 |
|
38
|
|
|
|
|
|
|
#The wet-bulb temperature (C) = 20.326262 |
|
39
|
|
|
|
|
|
|
#The humidity ratio = 0.013101 |
|
40
|
|
|
|
|
|
|
#The enthalpy (kJ/kg) = 58.095979 |
|
41
|
|
|
|
|
|
|
#The vapor pressure (kPa) = 2.104209 |
|
42
|
|
|
|
|
|
|
#The degree of saturation (%) = 67.325951 |
|
43
|
|
|
|
|
|
|
#The saturated vapor pressure (kPa) = 3.094426 |
|
44
|
|
|
|
|
|
|
#The specific air volume (m3/kg) = 0.855627 |
|
45
|
|
|
|
|
|
|
#The density of moist air (kg/m^3) = 1.184046 |
|
46
|
|
|
|
|
|
|
#The saturated humidity ratio = 0.019460 |
|
47
|
|
|
|
|
|
|
#The specific humidity (ratio) = 0.012932 |
|
48
|
|
|
|
|
|
|
#The absolute humidity (kg/m3) = 0.015312 |
|
49
|
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
|
my $C14 = 6.54; |
|
51
|
|
|
|
|
|
|
my $C15 = 14.526; |
|
52
|
|
|
|
|
|
|
my $C16 = 0.7389; |
|
53
|
|
|
|
|
|
|
my $C17 = 0.09486; |
|
54
|
|
|
|
|
|
|
my $C18 = 0.4569; |
|
55
|
|
|
|
|
|
|
|
|
56
|
|
|
|
|
|
|
sub dbdp2wb |
|
57
|
|
|
|
|
|
|
{ |
|
58
|
1
|
|
|
1
|
1
|
632
|
my ($db, $dp, $p) = @_; |
|
59
|
|
|
|
|
|
|
|
|
60
|
1
|
|
|
|
|
2
|
my $i = 0; |
|
61
|
1
|
|
|
|
|
5
|
my $e = t2es($dp); |
|
62
|
1
|
|
|
|
|
4
|
my $w = e2w($e, $p); |
|
63
|
1
|
|
|
|
|
14
|
my $wb1 = $dp; |
|
64
|
1
|
|
|
|
|
2
|
my $wb2 = $db; |
|
65
|
1
|
|
|
|
|
4
|
my $twb = $wb1 + ($wb2 - $wb1) / 2; |
|
66
|
1
|
|
66
|
|
|
11
|
while ((($wb2 - $wb1) > 0.001) && ($i < 1000)) |
|
67
|
|
|
|
|
|
|
{ |
|
68
|
13
|
|
|
|
|
25
|
my $tw = dbwb2w($db, $twb, $p); |
|
69
|
13
|
100
|
|
|
|
27
|
if($tw > $w) |
|
70
|
|
|
|
|
|
|
{ # /* overestimate the wetblb temperature */ |
|
71
|
7
|
|
|
|
|
6
|
$wb2 = $twb; # /* the wb should be between wb1,twb */ |
|
72
|
7
|
|
|
|
|
33
|
$twb = $wb1 + ($wb2 - $wb1) / 2; |
|
73
|
|
|
|
|
|
|
} |
|
74
|
|
|
|
|
|
|
else |
|
75
|
|
|
|
|
|
|
{ # /* underestimate the wb */ |
|
76
|
6
|
|
|
|
|
8
|
$wb1 = $twb; |
|
77
|
6
|
|
|
|
|
26
|
$twb = $wb1 + ($wb2 - $wb1) / 2; |
|
78
|
|
|
|
|
|
|
} |
|
79
|
|
|
|
|
|
|
} |
|
80
|
1
|
|
|
|
|
2
|
my $wb = $twb; |
|
81
|
1
|
|
|
|
|
4
|
return $wb; |
|
82
|
|
|
|
|
|
|
} |
|
83
|
|
|
|
|
|
|
|
|
84
|
|
|
|
|
|
|
sub dbw2h |
|
85
|
|
|
|
|
|
|
{ |
|
86
|
1
|
|
|
1
|
1
|
519
|
my ($db, $w) = @_; |
|
87
|
1
|
|
|
|
|
7
|
return 1.006 * $db + $w * (2501.0 + 1.805 * $db); |
|
88
|
|
|
|
|
|
|
} |
|
89
|
|
|
|
|
|
|
|
|
90
|
|
|
|
|
|
|
sub e2w |
|
91
|
|
|
|
|
|
|
{ |
|
92
|
16
|
|
|
16
|
1
|
581
|
my ($e, $p) = @_; |
|
93
|
|
|
|
|
|
|
|
|
94
|
16
|
|
|
|
|
33
|
return 0.62198 * $e / ($p - $e); |
|
95
|
|
|
|
|
|
|
} |
|
96
|
|
|
|
|
|
|
|
|
97
|
|
|
|
|
|
|
sub dbwb2w |
|
98
|
|
|
|
|
|
|
{ |
|
99
|
13
|
|
|
13
|
0
|
15
|
my ($db, $wb, $p) = @_; |
|
100
|
|
|
|
|
|
|
|
|
101
|
|
|
|
|
|
|
|
|
102
|
13
|
|
|
|
|
66
|
my $estar = t2es($wb); |
|
103
|
13
|
|
|
|
|
24
|
my $wstar = e2w($estar, $p); |
|
104
|
13
|
|
|
|
|
23
|
my $t1 = (2501 - 2.381 * $wb) * $wstar -($db - $wb); |
|
105
|
13
|
|
|
|
|
19
|
my $t2 = 2501 + 1.805 * $db - 4.186 * $wb; |
|
106
|
13
|
|
|
|
|
20
|
return $t1 / $t2; |
|
107
|
|
|
|
|
|
|
} |
|
108
|
|
|
|
|
|
|
|
|
109
|
|
|
|
|
|
|
sub dbrh2e |
|
110
|
|
|
|
|
|
|
{ |
|
111
|
1
|
|
|
1
|
1
|
11
|
my ($db, $rh) = @_; |
|
112
|
|
|
|
|
|
|
|
|
113
|
1
|
|
|
|
|
6
|
return t2es($db) * $rh; |
|
114
|
|
|
|
|
|
|
} |
|
115
|
|
|
|
|
|
|
|
|
116
|
|
|
|
|
|
|
sub rhws2ds |
|
117
|
|
|
|
|
|
|
{ |
|
118
|
1
|
|
|
1
|
1
|
837
|
my ($rh, $ws) = @_; |
|
119
|
|
|
|
|
|
|
|
|
120
|
1
|
|
|
|
|
34
|
return $rh / (1 + (1 - $rh) * $ws / 0.62198); |
|
121
|
|
|
|
|
|
|
} |
|
122
|
|
|
|
|
|
|
|
|
123
|
|
|
|
|
|
|
sub t2es |
|
124
|
|
|
|
|
|
|
{ |
|
125
|
16
|
|
|
16
|
1
|
555
|
my ($t) = @_; |
|
126
|
|
|
|
|
|
|
|
|
127
|
16
|
|
|
|
|
19
|
$t += 273.15; |
|
128
|
16
|
50
|
|
|
|
30
|
if($t > 273.15) |
|
129
|
|
|
|
|
|
|
{ |
|
130
|
16
|
|
|
|
|
41
|
return exp(-5800.2206 / $t + 1.3914993 - .048640239 * $t + (.41764768e-4) * pow($t, 2.0) - (.14452093e-7) * pow($t, 3.0) + 6.5459673 * log($t)) / 1000.0; |
|
131
|
|
|
|
|
|
|
} |
|
132
|
|
|
|
|
|
|
else |
|
133
|
|
|
|
|
|
|
{ |
|
134
|
0
|
|
|
|
|
0
|
return exp(-5674.5359 / $t + 6.3925247 - (.9677843e-2) * $t + (.62215701e-6) * pow($t, 2.0) + (.20747825e-8) * pow($t, 3.0) - (.9484024e-12) * pow($t, 4.0) + 4.1635019 * log($t)) / 1000.0; |
|
135
|
|
|
|
|
|
|
} |
|
136
|
|
|
|
|
|
|
} |
|
137
|
|
|
|
|
|
|
|
|
138
|
|
|
|
|
|
|
sub e2dp |
|
139
|
|
|
|
|
|
|
{ |
|
140
|
1
|
|
|
1
|
1
|
1075
|
my ($e) = @_; |
|
141
|
|
|
|
|
|
|
|
|
142
|
1
|
|
|
|
|
4
|
my $af = log($e); |
|
143
|
1
|
|
|
|
|
4
|
my $s1 = pow($af, 2.0); |
|
144
|
1
|
|
|
|
|
4
|
my $s2 = pow($af, 3.0); |
|
145
|
1
|
|
|
|
|
4
|
my $s3 = pow($e, 0.1984); |
|
146
|
1
|
|
|
|
|
5
|
my $t1 = $C14 + $C15 * $af + $C16 * $s1 + $C17 * $s2 + $C18 * $s3; |
|
147
|
1
|
|
|
|
|
3
|
my $t2 = 6.09 + 12.608 * $af + 0.4959 * $s1; |
|
148
|
1
|
50
|
|
|
|
8
|
return $t1 > 0 ? $t1 : $t2; |
|
149
|
|
|
|
|
|
|
} |
|
150
|
|
|
|
|
|
|
|
|
151
|
|
|
|
|
|
|
sub pow |
|
152
|
|
|
|
|
|
|
{ |
|
153
|
35
|
|
|
35
|
0
|
40
|
my ($n, $p) = @_; |
|
154
|
|
|
|
|
|
|
|
|
155
|
35
|
|
|
|
|
171
|
return $n ** $p; |
|
156
|
|
|
|
|
|
|
} |
|
157
|
|
|
|
|
|
|
|
|
158
|
|
|
|
|
|
|
sub dbw2v |
|
159
|
|
|
|
|
|
|
{ |
|
160
|
1
|
|
|
1
|
1
|
537
|
my ($db, $w, $p) = @_; |
|
161
|
|
|
|
|
|
|
|
|
162
|
1
|
|
|
|
|
3
|
$db += 273.15; |
|
163
|
1
|
|
|
|
|
6
|
return (287.055 * $db * ( 1 + 1.6078 * $w)) / ($p * 1000.0); |
|
164
|
|
|
|
|
|
|
} |
|
165
|
|
|
|
|
|
|
|
|
166
|
|
|
|
|
|
|
sub wv2da |
|
167
|
|
|
|
|
|
|
{ |
|
168
|
1
|
|
|
1
|
1
|
605
|
my ($w, $v) = @_; |
|
169
|
|
|
|
|
|
|
|
|
170
|
1
|
|
|
|
|
5
|
return (1 + $w) / $v; |
|
171
|
|
|
|
|
|
|
} |
|
172
|
|
|
|
|
|
|
|
|
173
|
|
|
|
|
|
|
sub es2ws |
|
174
|
|
|
|
|
|
|
{ |
|
175
|
1
|
|
|
1
|
1
|
542
|
my ($es, $p) = @_; |
|
176
|
|
|
|
|
|
|
|
|
177
|
1
|
|
|
|
|
3
|
return e2w($es, $p); |
|
178
|
|
|
|
|
|
|
} |
|
179
|
|
|
|
|
|
|
|
|
180
|
|
|
|
|
|
|
sub w2q |
|
181
|
|
|
|
|
|
|
{ |
|
182
|
1
|
|
|
1
|
1
|
534
|
my ($w) = @_; |
|
183
|
|
|
|
|
|
|
|
|
184
|
1
|
|
|
|
|
4
|
return $w / (1 + $w); |
|
185
|
|
|
|
|
|
|
} |
|
186
|
|
|
|
|
|
|
|
|
187
|
|
|
|
|
|
|
sub wv2X |
|
188
|
|
|
|
|
|
|
{ |
|
189
|
1
|
|
|
1
|
1
|
527
|
my ($w, $v) = @_; |
|
190
|
|
|
|
|
|
|
|
|
191
|
1
|
|
|
|
|
4
|
return $w / $v; |
|
192
|
|
|
|
|
|
|
} |
|
193
|
|
|
|
|
|
|
|
|
194
|
|
|
|
|
|
|
1; |
|
195
|
|
|
|
|
|
|
__END__ |