Geo-Spatial Rest Backend Using GeoDjango
dj
data:image/s3,"s3://crabby-images/8871e/8871eb371644e9d69656c21ef69290566e76fb1d" alt=""
I am Nayan Das!
@_themadnerd
- Backend Developer by day, devops engineer by night
- Have experience in Nodejs, Django, Reactjs etc
- In my free time, I love to read books and manga
- Cooks tasty API’s and web services
@NayanJD
data:image/s3,"s3://crabby-images/2b526/2b52602f991e345dd9120a1b05897aae8d3bdafc" alt=""
data:image/s3,"s3://crabby-images/e6c16/e6c1627dad7447f12abdef584b416b2e05a1dfde" alt=""
What is Geographic Information System?
data:image/s3,"s3://crabby-images/cef98/cef9842895a572da672a56ecfbd0a67233f08e0f" alt=""
Geographic Map Data
+
data:image/s3,"s3://crabby-images/1cc93/1cc93413254321b58c93832385091f61bef62669" alt=""
Map Analysis and Queries
What is Geospatial?
-
If we summarise GIS and GeoSpatial, geo spatial is GIS - the whole map data.
Only Map Analysis and Queries
data:image/s3,"s3://crabby-images/1cc93/1cc93413254321b58c93832385091f61bef62669" alt=""
Spatial Reference System ID (SRID)
-
Measuring unit for geometry types.
-
It specifies which units (degrees/metres) are going to be used to represent the geometry types.
-
We are going to use SRID 4326
SRID 900913
(in metres)
SRID 4326
(in degrees)
Bengaluru/ Coordinates
8637791 m, 1456487 m
Bengaluru/ Coordinates
12.9716 °N, 77.5946 °E
...a small caveat
-
Longitude is x
-
Latitude is y
-
...not the other way around
(30°,15°)
(x, y)
(lat, long)
data:image/s3,"s3://crabby-images/373d1/373d1a556975860136db6a2d61a63a10b982aea2" alt=""
data:image/s3,"s3://crabby-images/9be61/9be61292d984e76e103a96461ee222f652c8426e" alt=""
data:image/s3,"s3://crabby-images/d4ef2/d4ef2161248a1d2be22d6cec43161cc8148e3495" alt=""
Geometries Representations
GeoJson
Geographic Mark-up Language
Well Known Text (WKT)
GeoJson
data:image/s3,"s3://crabby-images/c2a7a/c2a7a1cfad39a5166ac964a361d638019d7a5102" alt=""
Geographic Mark-up Language
data:image/s3,"s3://crabby-images/99439/99439333b8fbb2409fdd681b2518811cc5fc2605" alt=""
Well Known Text (WKT)
data:image/s3,"s3://crabby-images/d0967/d09674126787785ca04226a11bdc595a5d623c0c" alt=""
Geometry Types
-
Point
-
LineString
-
Polygon
Simple Types
Collection Types
-
MultiPoint
-
MultiLineString
-
MultiPolygon
-
GeometryCollection
Point as GeoJson
data:image/s3,"s3://crabby-images/88d22/88d22acb5243c1b9623ea1a55f392d8656444c66" alt=""
e.g. GeekyAnts On Maps
data:image/s3,"s3://crabby-images/c7498/c7498940c5fb055328ef4edd467c5683ac3e8307" alt=""
Linestring as GeoJson
data:image/s3,"s3://crabby-images/120c0/120c0534bdcca57e53e0642a2da2919aeb5f905d" alt=""
e.g. route along road between two points
data:image/s3,"s3://crabby-images/82031/820319933d07931c5ae756821b60dcc3784245df" alt=""
Polygon as GeoJson
data:image/s3,"s3://crabby-images/d66eb/d66eb30905b10ed90ec2000254b3e542bc1edb05" alt=""
e.g. an area of sub-locality of BTM
data:image/s3,"s3://crabby-images/f551e/f551e0cddf806bdeb7597555826388b2fb8a6ad2" alt=""
Tech stack used
Python
Django
Django Rest Framework
Postgres (with postgis extension)
data:image/s3,"s3://crabby-images/bbb0d/bbb0d836df5b2f6bfea73bf3a703863a21de8497" alt=""
Geos API
- Stands for Geometry Engine - Open Source
- Is an open source c++ library
- GeoDjango has its own implementation of the GEOS library.
data:image/s3,"s3://crabby-images/9159e/9159e3779966d429509a8cfa5ad9d60c08586d40" alt=""
GEOS Functions
1 .contains
- Checks if a geometry is inside another geometry.
data:image/s3,"s3://crabby-images/12421/12421bf166d724239df8b37d858794d2284236bd" alt=""
-
Invoked as polygon.contains(point)
data:image/s3,"s3://crabby-images/486ed/486ed17e335b9292bba4e821f18524feed1c44a3" alt=""
GEOS methods & properties
2 .distance
-
Returns the distance between the closest point in this geometry and the other geometry
data:image/s3,"s3://crabby-images/7ac0d/7ac0daec5d3bc1a382d7d0f6c868243ada3f1012" alt=""
- Invoked as polygon.distance(point)
data:image/s3,"s3://crabby-images/120e0/120e0772ab0a811b86e103e67930f17ed7f2391b" alt=""
GIS ORM
- Extends Django ORM
- Provides spatial lookup and queries
- Takes advantages of database procedures by postgis and others
Retrieve factories which covers a given point
Using GEOS API
Using ORM
GEOS API would have to collect all rows of database in memory
data:image/s3,"s3://crabby-images/21c4e/21c4eec96cb853c0a7d8e77ec31cf26e690fd9ac" alt=""
data:image/s3,"s3://crabby-images/8ec9a/8ec9a2d2f95660a6048f321f227f543eff2f4bcf" alt=""
GIS ORM would do the query right in database. Thus, efficient.
GIS ORM (QuerySet) API Ops
contains
data:image/s3,"s3://crabby-images/e8233/e8233ac340047a3ca77db4b64eb2c5d36f30a597" alt=""
intersects
data:image/s3,"s3://crabby-images/3cfe0/3cfe03ead9d86753a9b6565c2580e2ace3a39b55" alt=""
data:image/s3,"s3://crabby-images/35ee0/35ee0b39bca9f30f8a8ed4b2a891be15c0e64214" alt=""
data:image/s3,"s3://crabby-images/66a37/66a3770bcd9054b589d63eb468e1855282e6ea1c" alt=""
More GIS ORM Ops
-
overlaps
-
bboverlaps
-
bbcontains
-
etc.
PROS
1. Fully supports GIS Standards
2. Provides Spatial ORM
3. Low learning curve
4. Plug & Play nature
CONS
1. Is overkill if geometries do not have to be stored
2. Has limited support for MySQL
References
1. https://www.gislounge.com/what-is-gis/
2. https://www.django-rest-framework.org/api-guide/serializers/
3. https://docs.djangoproject.com/en/3.1/ref/contrib/
gis/geoquerysets/
4. https://docs.djangoproject.com/en/3.2/ref/contrib/gis/geos/
Thank You
Geo-Spatial REST Service using GeoDjango
By Nayan Jyoti Das
Geo-Spatial REST Service using GeoDjango
- 241