-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmodels.py
159 lines (132 loc) · 5.21 KB
/
models.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
import datetime
from flask_sqlalchemy import SQLAlchemy
from marshmallow_sqlalchemy import SQLAlchemySchema
from marshmallow import fields, post_load
from math import cos, asin, sqrt, pi
db = SQLAlchemy()
# WaterSource
class WaterSource(db.Model):
__tablename__ = 'WaterSources'
id = db.Column(db.Integer, primary_key=True)
latitude = db.Column(db.Float)
longitude = db.Column(db.Float)
name = db.Column(db.String(300))
country = db.Column(db.String(80))
measurements = db.relationship('WaterMeasurement', backref='Watersource')
def create(self):
db.session.add(self)
db.session.commit()
return self
def __init__(self, latitude, longitude, name, country):
self.latitude = latitude
self.longitude = longitude
self.name = name
self.country = country
def __repr__(self):
return "<WaterSource(name={self.name!r})>".format(self=self)
class WaterSourceSchema(SQLAlchemySchema):
class Meta(SQLAlchemySchema.Meta):
model = WaterSource
sqla_session = db.session
id = fields.Number(dump_only=True)
latitude = fields.Float(required=True)
longitude = fields.Float(required=True)
name = fields.String(required=True)
country = fields.String(required=True)
@post_load
def make_water_source(self, data, **kwargs):
return WaterSource(**data)
# WaterMeasurement
class WaterMeasurement(db.Model):
__tablename__ = 'WaterMeasurements'
id = db.Column(db.Integer, primary_key=True)
WaterSourceid = db.Column(db.Integer, db.ForeignKey("WaterSources.id"))
ph = db.Column(db.Float)
turbidity = db.Column(db.Float)
conductivity = db.Column(db.Float)
temperature = db.Column(db.Float)
flow = db.Column(db.Float)
DO = db.Column(db.Float) # dissolved oxygen
BOD = db.Column(db.Float) # Biochemical oxygen demand
datetime = db.Column(db.DateTime)
def create(self):
db.session.add(self)
db.session.commit()
return self
def __init__(self, WaterSourceid, ph, turbidity, conductivity, temperature, flow, DO, BOD):
self.WaterSourceid = WaterSourceid
self.ph = ph
self.turbidity = turbidity
self.conductivity = conductivity
self.temperature = temperature
self.flow = flow
self.DO = DO
self.BOD = BOD
self.datetime = datetime.datetime.utcnow()
def __repr__(self):
return "<WaterMeasurement(datetime={self.datetime!r})>".format(self=self)
class WaterMeasurementSchema(SQLAlchemySchema):
class Meta(SQLAlchemySchema.Meta):
model = WaterMeasurement
sqla_session = db.session
id = fields.Number(dump_only=True)
WaterSourceid = fields.Number(required=True)
ph = fields.Float(required=True)
turbidity = fields.Float(required=True)
conductivity = fields.Float(required=True)
temperature = fields.Float(required=True)
flow = fields.Float(required=True)
DO = fields.Float(required=True)
BOD = fields.Float(required=True)
datetime = fields.DateTime(dump_only=True)
@post_load
def make_water_measurement(self, data, **kwargs):
return WaterMeasurement(**data)
# WaterMeasurementApp
def distance(lat1, lon1, lat2, lon2):
r = 6371 # km
p = pi / 180
a = 0.5 - cos((lat2-lat1)*p)/2 + cos(lat1*p) * cos(lat2*p) * (1-cos((lon2-lon1)*p))/2
return 2 * r * asin(sqrt(a))
class WaterMeasurementApp(db.Model):
__tablename__ = 'WaterMeasurementApps'
id = db.Column(db.Integer, primary_key=True)
latitude = db.Column(db.Float)
longitude = db.Column(db.Float)
WaterSourceid = db.Column(db.Integer, db.ForeignKey("WaterSources.id"))
turbidity = db.Column(db.Float)
color = db.Column(db.String(20))
datetime = db.Column(db.DateTime)
def create(self):
db.session.add(self)
db.session.commit()
return self
def __init__(self, latitude, longitude, turbidity, color):
self.latitude = latitude
self.longitude = longitude
watersources = WaterSource.query.all()
closest_watersource = watersources[0]
for watersource in watersources:
if distance(latitude, longitude, closest_watersource.latitude, closest_watersource.longitude) \
> distance(latitude, longitude, watersource.latitude, watersource.longitude):
closest_watersource = watersource
self.WaterSourceid = closest_watersource.id
self.turbidity = turbidity
self.color = color
self.datetime = datetime.datetime.utcnow()
def __repr__(self):
return "<WaterMeasurementApp(datetime={self.datetime!r})>".format(self=self)
class WaterMeasurementAppSchema(SQLAlchemySchema):
class Meta(SQLAlchemySchema.Meta):
model = WaterMeasurementApp
sqla_session = db.session
id = fields.Number(dump_only=True)
latitude = fields.Float(required=True)
longitude = fields.Float(required=True)
WaterSourceid = fields.Number(dump_only=True)
turbidity = fields.Float(required=True)
color = fields.String(required=True)
datetime = fields.DateTime(dump_only=True)
@post_load
def make_water_measurement_app(self, data, **kwargs):
return WaterMeasurementApp(**data)