Geographical plotting with matplotlib
¶
To get the features, install the basemap
package using
conda install basemap
and the high res dataset withconda install -c conda-forge basemap-data-hires
.
I ran into multiple conflicts trying to install basemap
in an environment with geopandas
. I was successful in creating a new Python env and installing basemap first.
Thanks to https://jakevdp.github.io/PythonDataScienceHandbook/04.13-geographic-data-with-basemap.html for this tutorial.
In [1]:
Copied!
%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.basemap import Basemap
%matplotlib inline
import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.basemap import Basemap
Common steps in plotting with basemap
package¶
- First you set the figure size and other properties of the matplotlib figure
- Next you set the projection using the
Basemap
constructor. You pass the name of the projection from the choice list, a resolution of the built-in dataset to use. Higher res is slower to draw. You pass either the coordinates of lower left & upper right, or coordinates of center. This gives you aBasemap
object which is like an axis. If you are doing a subplot, you can bind it to an existing axes. - On the
Basemap
object, you call the appropriate basemap type - such asetopo()
,bluemarble()
,shadedrelief
etc. and pass appropriate parameters like scale, alpha etc. Scale is not map scale or tiling level, instead it is the factor to scale up or down the rendered image. The default resolution is5400x2700
which is computational intensive. You can pass any additionalimshow
parameters to this call. - If you want to overlay any vectors, you call the
basemap
object like a function and pass the coordinates in lat, lon. The function will return in the appropriate projection system you used to create the object. - Then you use the regular
plt.plot(x,y, symbol_spec)
syntax to plot those points on the map andplt.text(x,y, text_spec)
for labels.
Plot a sphere¶
In [2]:
Copied!
plt.figure(figsize=(8,8))
m = Basemap(projection='ortho', resolution=None, lat_0=35, lon_0=-100)
m.bluemarble(scale=0.6);
plt.figure(figsize=(8,8))
m = Basemap(projection='ortho', resolution=None, lat_0=35, lon_0=-100)
m.bluemarble(scale=0.6);
Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).
In [10]:
Copied!
type(m)
type(m)
Out[10]:
mpl_toolkits.basemap.Basemap
Let us set the view to India, change figure size and the resolution..
In [11]:
Copied!
plt.figure(figsize=(6,10))
m = Basemap(projection='ortho', resolution=None, lat_0=20.59, lon_0=78.96)
m.bluemarble(scale=0.5);
plt.figure(figsize=(6,10))
m = Basemap(projection='ortho', resolution=None, lat_0=20.59, lon_0=78.96)
m.bluemarble(scale=0.5);
Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).