Mercurial > personal > weather-server
annotate weather_server/types.py @ 41:4af79d69b12e v0.2.0
Use units better suited for science.
| author | Paul Fisher <paul@pfish.zone> |
|---|---|
| date | Tue, 01 Apr 2025 16:04:52 -0400 |
| parents | b77c8e7d2742 |
| children | 10bde12a9163 |
| rev | line source |
|---|---|
|
0
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
1 """Basic data types for the weather server.""" |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
2 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
3 import datetime |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
4 import math |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
5 import typing as t |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
6 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
7 import attr |
|
11
52ef21607b31
server: Create endpoint to get some recent readings.
Paul Fisher <paul@pfish.zone>
parents:
0
diff
changeset
|
8 |
|
21
beb42c835c52
Make weather server handle arbitrary data:
Paul Fisher <paul@pfish.zone>
parents:
11
diff
changeset
|
9 T = t.TypeVar('T') |
|
0
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
10 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
11 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
12 def c_to_f(c: float) -> float: |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
13 return c * 9 / 5 + 32 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
14 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
15 |
|
41
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
16 def c_to_k(c: float) -> float: |
|
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
17 return c + 273.15 |
|
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
18 |
|
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
19 |
|
0
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
20 # Values from Sontag1990 via Wikipedia: |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
21 # https://en.wikipedia.org/wiki/Dew_point |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
22 _MAGNUS_B = 17.62 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
23 _MAGNUS_C = 243.12 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
24 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
25 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
26 @attr.s(frozen=True, slots=True) |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
27 class Reading: |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
28 """A single reading from a weather thingy. |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
29 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
30 Field order is important, as it is used in CSV files. |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
31 """ |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
32 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
33 # The Unix timestamp of the reading. |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
34 sample_time = attr.ib(type=datetime.datetime) |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
35 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
36 # The temperature, in degrees Celsius. |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
37 temp_c = attr.ib(type=float) |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
38 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
39 # The relative humidity, in percent. |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
40 rh_pct = attr.ib(type=float) |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
41 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
42 # The Unix timestamp when the reading was received. |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
43 ingest_time = attr.ib(type=datetime.datetime) |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
44 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
45 @property |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
46 def temp_f(self) -> float: |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
47 return c_to_f(self.temp_c) |
|
41
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
48 |
|
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
49 @property |
|
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
50 def temp_k(self) -> float: |
|
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
51 return c_to_k(self.temp_k) |
|
0
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
52 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
53 @property |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
54 def dew_point_c(self) -> float: |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
55 gamma = self._gamma |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
56 return _MAGNUS_C * gamma / (_MAGNUS_B - gamma) |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
57 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
58 @property |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
59 def dew_point_f(self) -> float: |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
60 return c_to_f(self.dew_point_c) |
|
41
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
61 |
|
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
62 @property |
|
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
63 def dew_point_k(self) -> float: |
|
4af79d69b12e
Use units better suited for science.
Paul Fisher <paul@pfish.zone>
parents:
39
diff
changeset
|
64 return c_to_k(self.dew_point_c) |
|
0
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
65 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
66 @classmethod |
|
21
beb42c835c52
Make weather server handle arbitrary data:
Paul Fisher <paul@pfish.zone>
parents:
11
diff
changeset
|
67 def from_dict(cls: t.Type[T], d: t.Dict[str, t.Any]) -> T: |
|
beb42c835c52
Make weather server handle arbitrary data:
Paul Fisher <paul@pfish.zone>
parents:
11
diff
changeset
|
68 return cls(**{f.name: d[f.name] for f in attr.fields(cls)}) |
|
0
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
69 |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
70 @property |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
71 def _gamma(self) -> float: |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
72 return ( |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
73 math.log(self.rh_pct / 100) + |
|
efe7a1eff167
Create initial logger for weather server.
Paul Fisher <paul@pfish.zone>
parents:
diff
changeset
|
74 _MAGNUS_B * self.temp_c / (_MAGNUS_C + self.temp_c)) |
