Mercurial > repos > ecology > xarray_coords_info
comparison xarray_mapplot.py @ 2:3e73f657a998 draft
"planemo upload for repository https://github.com/galaxyecology/tools-ecology/tree/master/tools/data_manipulation/xarray/ commit 2166974df82f97557b082a9e55135098e61640c4"
author | ecology |
---|---|
date | Thu, 20 Jan 2022 17:07:54 +0000 |
parents | fea8a53f8099 |
children |
comparison
equal
deleted
inserted
replaced
1:6015f30a7258 | 2:3e73f657a998 |
---|---|
17 # [--xlim "x1,x2"] | 17 # [--xlim "x1,x2"] |
18 # [--ylim "y1,y2"] | 18 # [--ylim "y1,y2"] |
19 # [--range "valmin,valmax"] | 19 # [--range "valmin,valmax"] |
20 # [--threshold VAL] | 20 # [--threshold VAL] |
21 # [--label label-colorbar] | 21 # [--label label-colorbar] |
22 # [--config config-file] | |
22 # [--shift] | 23 # [--shift] |
23 # [-v] | 24 # [-v] |
24 # input varname | 25 # input varname |
25 # | 26 # |
26 # positional arguments: | 27 # positional arguments: |
44 # --xlim limited geographical area longitudes "x1,x2" | 45 # --xlim limited geographical area longitudes "x1,x2" |
45 # --ylim limited geographical area latitudes "y1,y2" | 46 # --ylim limited geographical area latitudes "y1,y2" |
46 # --range "valmin,valmax" for plotting | 47 # --range "valmin,valmax" for plotting |
47 # --threshold do not plot values below threshold | 48 # --threshold do not plot values below threshold |
48 # --label set a label for colormap | 49 # --label set a label for colormap |
50 # --config plotting parameters are passed via a config file | |
51 # (overwrite other plotting options) | |
49 # --shift shift longitudes if specified | 52 # --shift shift longitudes if specified |
50 # -v, --verbose switch on verbose mode | 53 # -v, --verbose switch on verbose mode |
51 # | 54 # |
52 | 55 |
53 import argparse | 56 import argparse |
66 | 69 |
67 import xarray as xr # noqa: E402 | 70 import xarray as xr # noqa: E402 |
68 | 71 |
69 | 72 |
70 class MapPlotXr (): | 73 class MapPlotXr (): |
71 def __init__(self, input, proj, varname, cmap, output, verbose=False, | 74 def __init__(self, input, varname, output, verbose=False, |
72 time=[], title="", latitude="latitude", | 75 config_file="", proj="", shift=False): |
73 longitude="longitude", land=0, ocean=0, | 76 |
74 coastline=0, borders=0, xlim=[], ylim=[], | 77 li = list(input.split(",")) |
75 threshold="", label="", shift=False, | 78 if len(li) > 1: |
76 range_values=[]): | 79 self.input = li |
77 self.input = input | 80 else: |
78 print("PROJ", proj) | 81 self.input = input |
79 if proj != "" and proj is not None: | 82 |
80 self.proj = proj.replace('X', ':') | 83 if proj != "" and proj is not None and Path(proj).exists(): |
81 else: | 84 f = open(proj) |
82 self.proj = proj | 85 sdict = ''.join( |
86 f.read().replace("\n", "").split('{')[1].split('}')[0] | |
87 ) | |
88 self.proj = '{' + sdict.strip() + '}' | |
89 else: | |
90 self.proj = None | |
83 self.varname = varname | 91 self.varname = varname |
84 self.get_cmap(cmap) | |
85 self.time = time | |
86 self.latitude = latitude | |
87 self.longitude = longitude | |
88 self.land = land | |
89 self.ocean = ocean | |
90 self.coastline = coastline | |
91 self.borders = borders | |
92 self.xlim = xlim | |
93 self.ylim = ylim | |
94 self.range = range_values | |
95 self.threshold = threshold | |
96 self.shift = shift | 92 self.shift = shift |
97 self.xylim_supported = False | 93 self.xylim_supported = False |
98 self.colorbar = True | 94 self.colorbar = True |
99 self.title = title | |
100 if output is None: | 95 if output is None: |
101 self.output = Path(input).stem + '.png' | 96 if type(self.input) is list: |
97 self.output = Path(self.input[0]).stem + '.png' | |
98 else: | |
99 self.output = Path(self.input).stem + '.png' | |
102 else: | 100 else: |
103 self.output = output | 101 self.output = output |
104 self.verbose = verbose | 102 self.verbose = verbose |
105 self.dset = xr.open_dataset(self.input, use_cftime=True) | |
106 | |
107 self.label = {} | 103 self.label = {} |
108 if label != "" and label is not None: | 104 self.time = [] |
109 self.label['label'] = label | 105 self.xlim = [] |
106 self.ylim = [] | |
107 self.range = [] | |
108 self.latitude = "latitude" | |
109 self.longitude = "longitude" | |
110 self.land = 0 | |
111 self.ocean = 0 | |
112 self.coastline = 0 | |
113 self.borders = 0 | |
114 self.cmap = "coolwarm" | |
115 self.threshold = "" | |
116 self.title = "" | |
117 | |
118 if config_file != "" and config_file is not None: | |
119 with open(config_file) as f: | |
120 sdict = ''.join( | |
121 f.read().replace("\n", "").split('{')[1].split('}')[0] | |
122 ) | |
123 tmp = ast.literal_eval('{' + sdict.strip() + '}') | |
124 for key in tmp: | |
125 if key == 'time': | |
126 time = tmp[key] | |
127 self.time = list(map(int, time.split(","))) | |
128 if key == 'cmap': | |
129 self.get_cmap(tmp[key]) | |
130 if key == 'latitude': | |
131 self.latitude = tmp[key] | |
132 if key == 'longitude': | |
133 self.longitude = tmp[key] | |
134 if key == 'land': | |
135 self.land = float(tmp[key]) | |
136 if key == 'ocean': | |
137 self.ocean = float(tmp[key]) | |
138 if key == 'coastline': | |
139 self.coastline = float(tmp[key]) | |
140 if key == 'borders': | |
141 self.borders = float(tmp[key]) | |
142 if key == 'xlim': | |
143 xlim = tmp[key] | |
144 self.xlim = list(map(float, xlim.split(","))) | |
145 if key == 'ylim': | |
146 ylim = tmp[key] | |
147 self.ylim = list(map(float, ylim.split(","))) | |
148 if key == 'range': | |
149 range_values = tmp[key] | |
150 self.range = list(map(float, range_values.split(","))) | |
151 if key == 'threshold': | |
152 self.threshold = float(tmp[key]) | |
153 if key == 'label': | |
154 self.label['label'] = tmp[key] | |
155 if key == 'title': | |
156 self.title = tmp[key] | |
157 | |
158 if type(self.input) is list: | |
159 self.dset = xr.open_mfdataset(self.input, use_cftime=True) | |
160 else: | |
161 self.dset = xr.open_dataset(self.input, use_cftime=True) | |
162 | |
110 if verbose: | 163 if verbose: |
111 print("input: ", self.input) | 164 print("input: ", self.input) |
112 print("proj: ", self.proj) | 165 print("proj: ", self.proj) |
113 print("varname: ", self.varname) | 166 print("varname: ", self.varname) |
114 print("time: ", self.time) | 167 print("time: ", self.time) |
135 def projection(self): | 188 def projection(self): |
136 if self.proj is None: | 189 if self.proj is None: |
137 return ccrs.PlateCarree() | 190 return ccrs.PlateCarree() |
138 | 191 |
139 proj_dict = ast.literal_eval(self.proj) | 192 proj_dict = ast.literal_eval(self.proj) |
140 | |
141 user_proj = proj_dict.pop("proj") | 193 user_proj = proj_dict.pop("proj") |
142 if user_proj == 'PlateCarree': | 194 if user_proj == 'PlateCarree': |
143 self.xylim_supported = True | 195 self.xylim_supported = True |
144 return ccrs.PlateCarree(**proj_dict) | 196 return ccrs.PlateCarree(**proj_dict) |
145 elif user_proj == 'AlbersEqualArea': | 197 elif user_proj == 'AlbersEqualArea': |
316 parser = argparse.ArgumentParser() | 368 parser = argparse.ArgumentParser() |
317 parser.add_argument( | 369 parser.add_argument( |
318 'input', | 370 'input', |
319 help='input filename with geographical coordinates (netCDF format)' | 371 help='input filename with geographical coordinates (netCDF format)' |
320 ) | 372 ) |
321 | |
322 parser.add_argument( | 373 parser.add_argument( |
323 '--proj', | 374 '--proj', |
324 help='Specify the projection on which we draw' | 375 help='Config file with the projection on which we draw' |
325 ) | 376 ) |
326 parser.add_argument( | 377 parser.add_argument( |
327 'varname', | 378 'varname', |
328 help='Specify which variable to plot (case sensitive)' | 379 help='Specify which variable to plot (case sensitive)' |
329 ) | 380 ) |
330 parser.add_argument( | 381 parser.add_argument( |
331 '--cmap', | |
332 help='Specify which colormap to use for plotting' | |
333 ) | |
334 parser.add_argument( | |
335 '--output', | 382 '--output', |
336 help='output filename to store resulting image (png format)' | 383 help='output filename to store resulting image (png format)' |
337 ) | 384 ) |
338 parser.add_argument( | 385 parser.add_argument( |
339 '--time', | 386 '--config', |
340 help='list of times to plot for multiple plots' | 387 help='pass plotting parameters via a config file' |
341 ) | |
342 parser.add_argument( | |
343 '--title', | |
344 help='plot title' | |
345 ) | |
346 parser.add_argument( | |
347 '--latitude', | |
348 help='variable name for latitude' | |
349 ) | |
350 parser.add_argument( | |
351 '--longitude', | |
352 help='variable name for longitude' | |
353 ) | |
354 parser.add_argument( | |
355 '--land', | |
356 help='add land on plot with alpha value [0-1]' | |
357 ) | |
358 parser.add_argument( | |
359 '--ocean', | |
360 help='add oceans on plot with alpha value [0-1]' | |
361 ) | |
362 parser.add_argument( | |
363 '--coastline', | |
364 help='add coastline with alpha value [0-1]' | |
365 ) | |
366 parser.add_argument( | |
367 '--borders', | |
368 help='add country borders with alpha value [0-1]' | |
369 ) | |
370 parser.add_argument( | |
371 '--xlim', | |
372 help='limited geographical area longitudes "x1,x2"' | |
373 ) | |
374 parser.add_argument( | |
375 '--ylim', | |
376 help='limited geographical area latitudes "y1,y2"' | |
377 ) | |
378 parser.add_argument( | |
379 '--range', | |
380 help='min and max values for plotting "minval,maxval"' | |
381 ) | |
382 parser.add_argument( | |
383 '--threshold', | |
384 help='do not plot values below threshold' | |
385 ) | |
386 parser.add_argument( | |
387 '--label', | |
388 help='set a label for colorbar' | |
389 ) | 388 ) |
390 parser.add_argument( | 389 parser.add_argument( |
391 '--shift', | 390 '--shift', |
392 help='shift longitudes if specified', | 391 help='shift longitudes if specified', |
393 action="store_true" | 392 action="store_true" |
396 "-v", "--verbose", | 395 "-v", "--verbose", |
397 help="switch on verbose mode", | 396 help="switch on verbose mode", |
398 action="store_true") | 397 action="store_true") |
399 args = parser.parse_args() | 398 args = parser.parse_args() |
400 | 399 |
401 if args.time is None: | 400 dset = MapPlotXr(input=args.input, varname=args.varname, |
402 time = [] | 401 output=args.output, verbose=args.verbose, |
403 else: | 402 config_file=args.config, proj=args.proj, |
404 time = list(map(int, args.time.split(","))) | 403 shift=args.shift) |
405 if args.xlim is None: | |
406 xlim = [] | |
407 else: | |
408 xlim = list(map(float, args.xlim.split(","))) | |
409 if args.ylim is None: | |
410 ylim = [] | |
411 else: | |
412 ylim = list(map(float, args.ylim.split(","))) | |
413 if args.range is None: | |
414 range_values = [] | |
415 else: | |
416 range_values = list(map(float, args.range.split(","))) | |
417 if args.latitude is None: | |
418 latitude = "latitude" | |
419 else: | |
420 latitude = args.latitude | |
421 if args.longitude is None: | |
422 longitude = "longitude" | |
423 else: | |
424 longitude = args.longitude | |
425 if args.land is None: | |
426 land = 0 | |
427 else: | |
428 land = float(args.land) | |
429 if args.ocean is None: | |
430 ocean = 0 | |
431 else: | |
432 ocean = float(args.ocean) | |
433 if args.coastline is None: | |
434 coastline = 0 | |
435 else: | |
436 coastline = float(args.coastline) | |
437 if args.borders is None: | |
438 borders = 0 | |
439 else: | |
440 borders = float(args.borders) | |
441 | |
442 dset = MapPlotXr(input=args.input, proj=args.proj, varname=args.varname, | |
443 cmap=args.cmap, output=args.output, verbose=args.verbose, | |
444 time=time, title=args.title, | |
445 latitude=latitude, longitude=longitude, land=land, | |
446 ocean=ocean, coastline=coastline, borders=borders, | |
447 xlim=xlim, ylim=ylim, threshold=args.threshold, | |
448 label=args.label, shift=args.shift, | |
449 range_values=range_values) | |
450 | 404 |
451 if dset.time == []: | 405 if dset.time == []: |
452 dset.plot() | 406 dset.plot() |
453 else: | 407 else: |
454 for t in dset.time: | 408 for t in dset.time: |