From cd38837268d9df3de523be7d42d0ba358c95fbbb Mon Sep 17 00:00:00 2001 From: Eugene Crosser Date: Fri, 1 Apr 2022 00:07:27 +0200 Subject: [PATCH] drop unresolvable points in mkgpx --- gps303/mkgpx.py | 49 ++++++++++++++++++++++++++++++++++++++++++++ gps303/opencellid.py | 6 ++++-- gps303/qry.py | 18 ---------------- 3 files changed, 53 insertions(+), 20 deletions(-) create mode 100644 gps303/mkgpx.py delete mode 100644 gps303/qry.py diff --git a/gps303/mkgpx.py b/gps303/mkgpx.py new file mode 100644 index 0000000..e0084c3 --- /dev/null +++ b/gps303/mkgpx.py @@ -0,0 +1,49 @@ +from datetime import datetime, timezone +from sqlite3 import connect +import sys + +from .GT06mod import * +from .opencellid import qry_cell + +db = connect(sys.argv[1]) +c = db.cursor() +c.execute( + "select timestamp, imei, clntaddr, length, proto, payload from events" +) + +print(""" + + Location Data + + Location Data + +""") + +for timestamp, imei, clntaddr, length, proto, payload in c: + msg = make_object(length, proto, payload) + if isinstance(msg, (WIFI_POSITIONING, WIFI_OFFLINE_POSITIONING)): + lat, lon = qry_cell(sys.argv[2], msg.mcc, msg.gsm_cells) + if lat is None or lon is None: + continue + elif isinstance(msg, (GPS_POSITIONING, GPS_OFFLINE_POSITIONING)): + lat, lon = msg.latitude, msg.longitude + else: + continue + isotime = datetime.fromtimestamp(timestamp).astimezone(tz=timezone.utc).isoformat() + isotime = isotime[:isotime.rfind(".")] + "Z" + trkpt = """ + + """.format(lat, lon, isotime) + print(trkpt) + if False: + print( + datetime.fromtimestamp(timestamp) + .astimezone(tz=timezone.utc) + .isoformat(), + msg, + ) +print(""" + +""") diff --git a/gps303/opencellid.py b/gps303/opencellid.py index dc0daae..192409a 100644 --- a/gps303/opencellid.py +++ b/gps303/opencellid.py @@ -44,8 +44,10 @@ def qry_cell(dbname, mcc, gsm_cells): (mcc,), ) data = list(lc.fetchall()) - sumsig = sum([sig for _, _, sig in data]) - nsigs = [sig / sumsig for _, _, sig in data] + if not data: + return None, None + sumsig = sum([1 / sig for _, _, sig in data]) + nsigs = [1 / sig / sumsig for _, _, sig in data] avlat = sum([lat * nsig for (lat, _, _), nsig in zip(data, nsigs)]) avlon = sum([lon * nsig for (_, lon, _), nsig in zip(data, nsigs)]) # lc.execute("drop table mem.seen") diff --git a/gps303/qry.py b/gps303/qry.py deleted file mode 100644 index 2a8e266..0000000 --- a/gps303/qry.py +++ /dev/null @@ -1,18 +0,0 @@ -from datetime import datetime, timezone -from sqlite3 import connect -import sys - -from .GT06mod import * - -db = connect(sys.argv[1]) -c = db.cursor() -c.execute( - "select timestamp, imei, clntaddr, length, proto, payload from events" -) -for timestamp, imei, clntaddr, length, proto, payload in c: - print( - datetime.fromtimestamp(timestamp) - .astimezone(tz=timezone.utc) - .isoformat(), - make_object(length, proto, payload), - ) -- 2.43.0