Reistijd-analyse met Uber Movement (QGIS3)

Uber Movement deelt geanonimiseerde en samengevoegde gegevens voor reistijd voor veel steden in de gehele wereld. Uber Movement’s product Travel Times is een publieke gegevensset die reizen van zone-naar-zone meet in een stad. Deze tijden zijn gebaseerd op feitelijke ritten van Uber en is een nauwkeurige weergave van opstoppingen en verkeerspatronen in de stad. Dit is een grote openlijk toegankelijke gegevensset, samengesteld uit miljoenen feitelijke taxiritten. Deze handleiding laat de technieken zien om met dergelijke samengestelde gegevenssets voor verkeer te werken om analyses voor reistijd uit te voeren in QGIS.

Overzicht van de taak

We zullen een samengestelde gegevensset voor verkeer voor de stad Bangalore, India gebruiken om reistijden te zoeken naar een opgegeven locatie in de stad. We zullen ook een Isochrone kaart maken voor een drempel voor de reistijd van 30 minuten.

Andere vaardigheden die u zult leren

  • Een bestand van GeoJSON laden in QGIS

De gegevens ophalen

We zullen de gegevensset Travel Times downloaden voor de stad Bangalore, India.

  1. Ga naar de website van Uber Movement en klik op de Cities.

../../_images/data013.png
  1. Zoek naar Bangalore.

../../_images/data023.png
  1. Klik op Download data.

../../_images/data032.png
  1. In de pop-up van Download data, schakel naar GEO BOUNDARIES. Het zal het GeoJSON-bestand voor de wijken van Banglore bevatten. Accepteer de licentie-informatie en klik op BANGLORE_WARDS.JSON om het te downloaden.

../../_images/data042.png
  1. Then switch to ALL DATA. This data is available from 2016 to 2020, and each year is divided into 4 quarters. We will download the data for 2019 Quarter 3. Select it and click the Travel Times by Hour of Day (Weekdays Only). This file will contain all anonymous information about the weekday uber travel in Bangalore from July to September 2019.

../../_images/data051.png

Voor het gemak kunt u direct de gegevensset downloaden vanaf de links hieronder:

bangalore_wards.json

bangalore-wards-2019-3-OnlyWeekdays-HourlyAggregate.csv

Gegevensbron: [UBER]

Procedure

  1. Zoek naar het bestand bangalore_wards.json in het paneel Browser en sleep het naar het kaartvenster. Vervolgens zullen we een laag met een basiskaart laden vanaf OpenStreetMap. We zullen de plug-in QuickMapServices gebruiken om toegang te krijgen tot de basiskaart. Ga, als de plug-in eenmaal is geïnstalleerd, naar Web ‣ QuickMapServices ‣ OSM ‣ OSM Standard. Een basiskaart tegellaag van OpenStreetMap zal worden toegevoegd aan het project. Klik vervolgens op de knop Databronnen beheren openen.

../../_images/019.png
  1. Schakel naar de tab Tekengescheiden tekst. Blader naar het bestand bangalore-wards-2019-3-OnlyWeekdays-HourlyAggregate.csv` en selecteer dat. Selecteer de optie Geen geometrieën (alleen attributentabel), omdat het CSV-bestand slechts tabulaire gegevens bevat, en klik op Toevoegen.

../../_images/029.png
  1. De laag bangalore-wards-2019-3-OnlyWeekdays-HourlyAggregate zal worden toegevoegd aan het paneel Lagen. Deze laag bevat geanonimiseerde en samengestelde gegevens over reislocaties tussen verschillende zones van de stad. Elke rij van de tabel bevat kolommen voor de bronzone (sourceid), doelzone (dstid), uur van de dag (hod) en gemiddelde reistijd, samengesteld uit alle reizen met deze zone op dat uur (mean_travel_time). U kunt meer te weten komen over deze gegevensset in de Movement: Travel Times Calculation Methodology (pdf). Laten we, voordat we doorgaan, controleren hoeveel gegevensrecords aanwezig zijn in de laag. Klik met rechts op de laag bangalore-wards-2019-3-OnlyWeekdays-HourlyAggregate en selecteer Aantal objecten tonen. Het totale aantal rijen in de tabel zal ernaast worden weergegeven. Dit is een vrij grote tabel, maar we hebben niet alle rijen met gegevens nodig voor onze analyse. We zullen nu onze doellocatie identificeren en deze tabel filteren op de records daarvoor.

../../_images/039.png
  1. We willen alle gebieden berekenen die bereikbaar zijn binnen 30 minuten vanaf een specifieke locatie. Met de basiskaart OSM Standard kunt u de locatie zoeken. Selecteer dan de laag bangalore_wards, gebruik het gereedschap Objecten identificeren en klik erop. De resultaten zullen de attributen van de zone weergeven die de locatie bevat. Voor deze handleiding nemen we aan dat onze doellocatie ligt in de zone JP Nagar met de MOVEMENT_ID 193.

../../_images/049.png
  1. We kunnen de records voor de reistijd filteren to slechts die welke deze zone als doel hebben. We kunnen ook onze analyse beperken tot het spitsuur in de morgen van 9am - 10am. Klik met rechts op de laag bangalore-wards-2019-3-OnlyWeekdays-HourlyAggregate en selecteer Filteren.

../../_images/059.png
  1. Voer de volgende filterexpressie in en klik op OK.

"dstid" = 193 AND "hod" = 9
../../_images/069.png
  1. Back in the main QGIS window, you will see that the number of records in the filtered table are now down to just 197. Since there are a total of 198 zones in the city, we have records of travel times between the 1 destination ward and 197 source zones. Open the attribute table of both the layers using the Open Attribute Table button in the Attributes toolbar.

../../_images/079.png
  1. Nu hebben we de vorm van de wijk in de laag bangalore_wards en tabulaire informatie in de laag bangalore-wards-2019-3-OnlyWeekdays-HourlyAggregate. We kunnen de informatie voor de attributen samenvoegen met de vormen met een gezamenlijk attribuut. Hier zijn dat de kolom MOVEMENT_ID van de laag bangalore_wards en de kolom sourceid van de laag bangalore-wards-2019-3-OnlyWeekdays-HourlyAggregate die unieke identificatie zijn voor wijken, die kunnen worden samengevoegd. Deze bewerking wordt een Table Join genoemd.

../../_images/088.png
  1. Before we can join these two layers, we must ensure that the values in both columns match exactly. Thought they appear the same, they are of different type. Since GeoJSON format has no way of specifying property types, all values are assumed to be of the type String - i.e. Text. But when we import a CSV to QGIS, by default, QGIS tries to determines the types of the columns based on the values and assign appropriate field type. For the CSV file, the data type for the column sourceid was assigned as Integer. So we need to convert the column from the GeoJSON to an Integer type as well. Go to Processing ‣ Toolbox ‣ Vector Table ‣ Field Calculator algorithm. Double-click to launch it.

../../_images/098.png
  1. Choose bangalore_wards as the Input Layer. Name the Field Name as joinfield and select the Result field type as Integer. Enter MOVEMENT_ID as the Expression. Click the button next to the Calculated and select Save to File… then enter the name of the output file as bangalore_wards_fixed.gpkg. Click Run. Close the field calculator.

../../_images/1031.png
  1. Een nieuwe laag bangalore_wards_fixed zal worden toegevoegd aan het paneel Lagen. Nu zijn we klaar om het samenvoegen uit te voeren. Ga naar Processing ‣ Toolbox ‣ Vector algemeen‣ Attributen koppelen op veldwaarde. Dubbelklik erop om het te starten.

../../_images/1137.png
  1. Selecteer bangalore_wards_fixed als de Invoerlaag en joinfield als het Tabelveld. Selecteer bangalore-wards-2019-3-OnlyWeekdays-HourlyAggregate als de Invoerlaag 2 en sourceid als het Tabelveld 2. Noem de Samengevoegde laag als uber_travel_times.gpkg en klik op Uitvoeren.

../../_images/1234.png
  1. Een nieuwe laag uber_travel_times zal worden toegevoegd aan het paneel Lagen. Laten we die opmaken om het resultaat van het samenvoegen te visualiseren. Klik op Paneel Laag opmaken openen. Selecteer de renderer Gradueel en mean_travel_time als de Waarde. Selecteer een kleurverloop en klik op Classificeren. U zult zien dat de kaart oplopende reistijden weergeeft, hoe verder u van het doel afgaat.

../../_images/1332.png
  1. Maar we zoeken naar gebieden die binnen 30 minuten reistijd liggen om ze te analyseren en uit te nemen, dus we hebben nog wat werk te doen. Schakel voor de opmaak terug naar de renderer Enkel symbool. Klik met rechts op de laag uber_travel_times en selecteer Filteren.

../../_images/1429.png
  1. Voer de volgende expressie in om alle zones binnen 1800 seconden (30 minuten) van gemiddelde reistijd te selecteren. We dienen ook onze doelzone op te nemen die een reistijd heeft van 0.

"mean_travel_time" <= 1800 OR "MOVEMENT_ID" = 193
../../_images/1527.png
  1. De laag zal nu de cluster van polygonen weergeven die het door ons gewenste gebied omvat. We zullen ze nu allemaal samenvoegen tot één enkele polygoon. Ga naar Processing ‣ Toolbox ‣ Vector geometrie ‣ Samensmelten. Dubbelklik erop om het te starten.

../../_images/1625.png
  1. Selecteer uber_travel_times als de Invoerlaag. Geef de laag Ontbonden de naam 30min_isochrone.gpkg. Klik op Uitvoeren.

../../_images/1725.png
  1. Een nieuwe laag 30min_isochrone zal worden toegevoegd aan het paneel Lagen die het resultaat van onze analyse weergeeft.

../../_images/1822.png
comments powered by Disqus