Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Open source release of bike routes in Chicago.
R Ruby Python
branch: master

README.md

README

The City of Chicago is releasing selected datasets from the data portal under the MIT License (see below). This repository contains:

  1. Data in a GeoJSON format.
  2. Examples of importing data into R, Python, and Ruby.
  3. Instructions to transform data from the data portal to data in the repository.

Working with GeoJSON Data

The data was released as a GeoJSON file. Below are some simple instructions which will show you how to load GeoJSON in R, Python, and Ruby.

R

Find an example script here. This example will import the data in R and create a couple of maps.

Instructions:

  1. Set the working directory to the location of the downloaded repository.

    setwd("path\\to\\repository\\folder")
  2. Install the "rgdal" library to let R read and translate the data from GeoJSON to a Shapefile. We will use "ggplot2" library to transform the spatial data frame to a regular data frame--and to make a map.

    install.packages(c("rgdal","ggplot2"))
  3. Load the libraries:

    library(rgdal)
    library(ggplot2)
  4. Import data to a spatial dataframe. City data is typically created using the transverse Mercator projection.

    ogrInfo("data\\Bikeroutes.json", layer="OGRGeoJSON")
    bikeroutes.shapefile <- readOGR(dsn="data\\Bikeroutes.json", layer="OGRGeoJSON", p4s="+proj=tmerc +ellps=WGS84")
  5. Ensure the map works:

    plot(bikeroutes.shapefile)
  6. Lets convert the spatial dataframe to a typical dataframe.

    bikeroutes.table <- fortify(bikeroutes.shapefile)
  7. Review the new dataframe.

    head(bikeroutes.table)
  8. Plot the data.

    ggplot(bikeroutes.table, aes(x=long, y=lat, group=group)) + geom_path()

Here is the output you should expect from the plot() command: plot(bikeroutes.shapefile)

Here is the output you should expect from the ggplot() command: ggplot(bikeroutes.df, aes(x=long, y=lat, group=group))+geom_path()

Python

Find an example script here.

  1. Load the necessary json and pprint libraries.

    import json
  2. Open GeoJSON data file.

    bikeroutes_json = open('PATH/TO/osd-street-center-line/data/Bikeroutes.json', 'r')
  3. Check first few lines of data (repeat this command several times)

    bikeroutes.readline()
  4. Load GeoJSON file.

    bikeroutes = json.load(bikeroutes_json)
  5. Close the open GeoJSON file.

    json.close(bikeroutes_json)

Ruby

An example ruby script is provided to show loading GeoJSON and running spatial analysis using the RGeo suite. A simple Gemfile is provided to make getting the dependencies and using them easy.

    $ cd PATH/TO/osd-bike-routes/examples/ruby
    $ bundle
    $ ruby example.rb

This example script filters the Bikeroutes.json to street segments within a 500ft buffer of 50 W Washington.

Differences between data portal and this repository

Though the data in this repository is also available on Chicago's data portal, the data in this repository is different in several ways. First, the data within this repository is released under the MIT License. Second, this data has been edited to remove internal codes which do not provide useful information. Third, after changes were made to the dataset, the original shapefile was converted to GeoJSON using GDAL's ogr2ogr

The resulting shapefile is then translated to GeoJSON using the ogr2ogr from the GDAL application. The transformation is completed in the command prompt:

ogr2ogr -f "GeoJSON" Bikeroutes_ogr.json /path/to/portal/data/Bikeroutes3.shp

Unfortunately, ogr2ogr outputs in machine, but not human-readable files. We use Python's simplejson.tool to transform the data to the final JSON file.

type Bikeroutes_ogr.json | python -m simplejson.tool > Bikeroutes.json

The folder "Transformations" contains the necessary code to transform data on the portal to the release in this repository.

License

This data is released under the MIT License. See LICENSE.txt.

Something went wrong with that request. Please try again.