Skip to content

CitySurfaces semantic segmentation of sidewalk surfaces

License

Notifications You must be signed in to change notification settings

djsegal/city-surfaces

 
 

Repository files navigation

CitySurfaces: City-scale Semantic Segmentation of Sidewalk Surfaces

CitySurfaces

CitySurfaces is a framework that combines active learning and semantic segmentation to locate, delineate, and classify sidewalk paving materials from street-level images. Our framework adopts a recent high-performing semantic segmentation model (Tao et al., 2020), which uses hierarchical multi-scale attention combined with object-contextual representations

The framework was presented in our paper published at the Sustainable Cities and Society journal:

CitySurfaces: City-scale semantic segmentation of sidewalk materials
Maryam Hosseini, Fabio Miranda, Jianzhe Lin, Claudio T. Silva, Sustainable Cities and Society, 2022

You can use our pre-trained model to make inference on your own street-level images. Our extended model can classify eight different classes of paving materials:

CitySurfaces paving materials

The team includes:

Table of contents

Installing prerequisites

The framework is based on NVIDIA Semantic Segmentation. Just like their original version, the code is tested with pytorch 1.3 and python 3.6. You can use ./Dockerfile to build an image.

Run inference on your own data

Follow the instructions below to be able to segment your own image data. Most of the steps are based on NVIDIA's original steps, with modifications regarding weights and dataset names.

Download Weights

  • Create a directory where you can keep large files.
  > mkdir <large_asset_dir>
  • Update __C.ASSETS_PATH in config.py to point at that directory

    __C.ASSETS_PATH=<large_asset_dir>

  • Download our pretrained weights from Google Drive. Weights should be under <large_asset_dir>/seg_weights.

Running the code

The instructions below make use of a tool called runx, which we find useful to help automate experiment running and summarization. For more information about this tool, please see runx. In general, you can either use the runx-style commandlines shown below. Or you can call python train.py <args ...> directly if you like.

Inference

Update the inference-citysurfaces.yml under scripts directory with the path to your image folder that you would like to make inference on.

Run

> python -m runx.runx scripts/inference-citysurfaces.yml -i

The results should look like the below examples, where you have your input image and segmentation mask, side by side.

CitySurfaces results

About

CitySurfaces semantic segmentation of sidewalk surfaces

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 99.8%
  • Dockerfile 0.2%