-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathquake-csvtoczml.py
executable file
·60 lines (51 loc) · 2.31 KB
/
quake-csvtoczml.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
#!/usr/bin/env python
# convert USGS earthquake CSV to CZML
# zcml: https://github.com/AnalyticalGraphicsInc/cesium/wiki/CZML-Structure
# CSV: time,latitude,longitude,depth,mag,magType,nst,gap,dmin,rms,net,id,updated,place,type
# depth is Km, Cesium uses meters
# Get CSV (or GeoJson or KML) from:
# http://earthquake.usgs.gov/earthquakes/feed/v1.0/summary/2.5_month.geojson
# Plot lat/lon on surface sized and colored by magnitude,
# and draw line down to depth.
# Drag resulting ZCML file to Cesium:
# http://cesiumjs.org/Cesium/Build/Apps/CesiumViewer/index.html
# TODO:
# - Use the Python CZML library (no usage docs) https://github.com/cleder/czml
# - Pull CSV (or GeoJSON) live from USGS http://earthquake.usgs.gov/earthquakes/feed/
import csv
import datetime
import json
import logging
CSVFILE = '2.5_month.csv'
MIN_MAG = 2.5
MAX_MAG = 6.0
now = datetime.datetime.utcnow().isoformat().replace('-', '').replace(':', '')[:15] + 'Z'
quakes = [{'id': 'document', 'version': '1.0'}]
with open(CSVFILE, 'r') as csvfile:
for row in csv.DictReader(csvfile):
time = row['time'].replace('-', '').replace(':', '').replace('.000', '')
lon = float(row['longitude'])
lat = float(row['latitude'])
mag = float(row['mag'])
depth = float(row['depth']) * 1000.0 # Km to meters
name_text = "M%.1f d%d %s" % (mag, int(depth/1000.0), row['place'])
# scale our min/max mag to 0...255
mag_color = min(255, 255 * max(0, mag - MIN_MAG) / (MAX_MAG - MIN_MAG))
quake = {'id': row['id'],
'availability': time + '/' + now,
'name': name_text,
'position': {'cartographicDegrees': [lon, lat, 0.0]},
'point': {
'color': {'rgba': [255, mag_color, 0, 255] },
'pixelSize': float(row['mag']) * 1.5,
},
}
if int(depth) > 1.0: # can't render a line with depth=0
quake['polyline'] = {
'positions': {'cartographicDegrees': [lon, lat, -1 * depth,
lon, lat, 0]},
"material": { "solidColor": { "color": { "rgba": [ 255, 255, 0, 153 ] } } },
'show': True,
}
quakes.append(quake)
print json.dumps(quakes, indent=4, sort_keys=True)