2020-04-12 16:44:29 +02:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
import numpy as np
|
2020-04-13 15:59:34 +02:00
|
|
|
import zlib
|
2020-04-26 18:30:29 +02:00
|
|
|
import matplotlib.colors as mcol
|
2020-04-12 16:44:29 +02:00
|
|
|
import matplotlib.pyplot as plt
|
|
|
|
|
2020-11-10 13:19:20 +01:00
|
|
|
def view_map(dem, lakes, rivers, scale):
|
2020-04-26 18:30:29 +02:00
|
|
|
plt.subplot(1,3,1)
|
2020-11-10 13:19:20 +01:00
|
|
|
plt.pcolormesh(np.arange(dem.shape[0]+1)*scale, np.arange(dem.shape[1]+1)*scale, dem, cmap='viridis')
|
2020-04-26 18:30:29 +02:00
|
|
|
plt.gca().set_aspect('equal', 'box')
|
|
|
|
plt.colorbar(orientation='horizontal')
|
|
|
|
plt.title('Raw elevation')
|
|
|
|
|
|
|
|
plt.subplot(1,3,2)
|
2020-11-10 13:19:20 +01:00
|
|
|
plt.pcolormesh(np.arange(lakes.shape[0]+1)*scale, np.arange(lakes.shape[1]+1)*scale, lakes, cmap='viridis')
|
2020-04-26 18:30:29 +02:00
|
|
|
plt.gca().set_aspect('equal', 'box')
|
|
|
|
plt.colorbar(orientation='horizontal')
|
|
|
|
plt.title('Lake surface elevation')
|
|
|
|
|
|
|
|
plt.subplot(1,3,3)
|
2020-11-10 13:19:20 +01:00
|
|
|
plt.pcolormesh(np.arange(rivers.shape[0]+1)*scale, np.arange(rivers.shape[1]+1)*scale, rivers, cmap='Blues', norm=mcol.LogNorm())
|
2020-04-26 18:30:29 +02:00
|
|
|
plt.gca().set_aspect('equal', 'box')
|
|
|
|
plt.colorbar(orientation='horizontal')
|
|
|
|
plt.title('Rivers flux')
|
|
|
|
|
|
|
|
plt.show()
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2020-04-26 23:29:36 +02:00
|
|
|
import sys
|
|
|
|
import os
|
2020-11-10 13:19:20 +01:00
|
|
|
|
|
|
|
scale = 1
|
2020-04-26 23:29:36 +02:00
|
|
|
if len(sys.argv) > 1:
|
|
|
|
os.chdir(sys.argv[1])
|
2020-11-10 13:19:20 +01:00
|
|
|
if len(sys.argv) > 2:
|
|
|
|
scale = int(sys.argv[2])
|
2020-04-26 23:29:36 +02:00
|
|
|
|
2020-04-26 18:30:29 +02:00
|
|
|
def load_map(name, dtype, shape):
|
|
|
|
dtype = np.dtype(dtype)
|
|
|
|
with open(name, 'rb') as f:
|
|
|
|
data = f.read()
|
|
|
|
if len(data) < shape[0]*shape[1]*dtype.itemsize:
|
|
|
|
data = zlib.decompress(data)
|
|
|
|
return np.frombuffer(data, dtype=dtype).reshape(shape)
|
|
|
|
|
|
|
|
shape = np.loadtxt('size', dtype='u4')
|
|
|
|
dem = load_map('dem', '>i2', shape)
|
|
|
|
lakes = load_map('lakes', '>i2', shape)
|
|
|
|
rivers = load_map('rivers', '>u4', shape)
|
|
|
|
|
2020-11-10 13:19:20 +01:00
|
|
|
view_map(dem, lakes, rivers, scale)
|