-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupdate-streets.sh
executable file
·47 lines (34 loc) · 1.41 KB
/
update-streets.sh
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
# UPDATE all data on all routable ways
cd ~/bike-map
# get new street data from the overpass API
wget -O data/streets.osm --post-file=overpass/ways.overpassql https://overpass-api.de/api/interpreter
# import way data into postGIS
osm2pgsql --slim --hstore-all --prefix street -d bikemap --style osm2pgsql/ways.style data/streets.osm
# process the data for OSRM-backend
mkdir ~/scripts/osrm-backend/osm-data
cp data/streets.osm ~/scripts/osrm-backend/osm-data/bike.osm
cd ~/scripts/osrm-backend
build/osrm-extract -p ~/scripts/bike-map/osrm-profiles/default-bicycle.lua osm-data/bike.osm
build/osrm-contract osm-data/bike.osrm
#this is not needed for routing
rm osm-data/bike.osm
# run the server in the background but be ready to kill it later
build/osrm-routed osm-data/bike.osrm > ~/bike-map/temp/osrm-output.txt &
OSRMserverPID=$!
# return to original folder
cd ~/bike-map
# activate the virtual environment
source venv/bin/activate
# synthesize travel demand
psql -d bikemap -f demand/generate-ODs.sql
python3 demand/generate-trips.py # needs OSRM to be running
psql -d bikemap -f demand/create-trips-table.sql
# create edges table
psql -d bikemap -f create-edge-table-from-osm2pgsql-data.sql
# generate betweenness measures and add counts to edges
python3 between.py
psql -d bikemap -f update-edge-bike-counts.sql
# we can now kill the server
kill $OSRMserverPID
# re-merge needlessly split edges
python3 merge-edges.py