File: GMT_hexbinning.sh

package info (click to toggle)
gmt 6.5.0%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 117,824 kB
  • sloc: ansic: 291,750; sh: 10,024; fortran: 49; makefile: 43; perl: 32; csh: 9
file content (53 lines) | stat: -rwxr-xr-x 2,232 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#!/usr/bin/env bash
# Test hexagon tile binning on counting values in gmtbinstats
#
# Hardwire some values to draw the bottom plot so we avoid lots of shell math
# The commented stuff shows how the script and data were developed
#e=5
#n=3
#dy=1
#ny=$(gmt math -Q $n SUB $dy DIV =)
#r=$(gmt math -Q $dy 0.5 MUL 30 COSD DIV =)
#dx=$(gmt math -Q 3 $r MUL =)
#nx=$(gmt math -Q $e $dx DIV RINT 1 ADD =)
#e2=$(gmt math -Q 0 $nx 1 SUB $dx MUL ADD =)
#r=$(gmt math -Q $dy 30 COSD DIV =)
#echo "Revised: 0/$e2/0/$n -I$dx/$dy for a pseudo $nx by $ny grid with hexagon radius $r"
#dx2=$(gmt math -Q $dx 2 DIV =)
#dy2=$(gmt math -Q $dy 2 DIV =)
#wb=$(gmt math -Q 0 $dx2 ADD =)
#eb=$(gmt math -Q $e2 $dx2 SUB =)
#sb=$(gmt math -Q 0 $dy2 ADD =)
#nb=$(gmt math -Q $n $dy2 SUB =)
#rh=$(gmt math -Q 4 30 COSD DIV =)
#gmt math -T1/100/1 0 $e2 RAND = x
#gmt math -T1/100/1 0 $n RAND = y
#gmt math -T1/100/1 50 25 NRAND = z
#gmt convert -A x y z -o1,3,5 > hex_data.txt
#  hex_data.txt lives in the cache

# Create grids to find nodes of hexagons
# All nodes in the grid
gmt grdmath -R0/5.19615242271/0/3 -I1.73205080757/1 0 = b.grd
# Only nodes that yield hexagons wholly falling inside
gmt grdmath -R0.866025403785/4.33012701893/0.5/2.5 -I1.73205080757/1 0 = r.grd
# Only nodes that are not hexagon centers
gmt grdmath -R0/5.19615242271/0/3 -I0.866025403785/0.5 0 = t.grd
H=$(gmt math -Q 3.46410161514 2 DIV =)
gmt begin GMT_hexbinning
	gmt grd2xyz b.grd | gmt plot -Sh${H}c -Glightblue@50 -W1p -N -R0/5.19615242271/0/3 -Jx1.5c -X0.5i
	gmt grd2xyz b.grd | gmt plot -Sh${H}c -Glightblue -W1p
	gmt grd2xyz r.grd | gmt plot -Sh${H}c -Glightred@50 -W1p -N
	gmt grd2xyz r.grd | gmt plot -Sh${H}c -Glightred -W1p
	gmt grd2xyz t.grd | gmt plot -Sc0.1c -Gwhite -Wfaint -N
	gmt grd2xyz r.grd b.grd | gmt plot -Sc0.1c -Gblack -N
	gmt basemap -Bxafg0.866025403785 -Byafg0.5
	gmt plot @hex_data.txt -Ss0.1c -Gyellow -Wfaint
	echo "a)" | gmt text -F+f12p+cTL -Dj-26p -N
	gmt binstats @hex_data.txt -R0/5/0/3 -I1 -Th -Cn > bin.txt
	gmt makecpt -Cjet -T1/10/1 -A50
	gmt plot -Baf -X9.25c bin.txt -C -Sh${H}c -W1p -Baf
	gmt text bin.txt -F+f7p,Helvetica-Bold -Gwhite -W0.25p -N
	echo "b)" | gmt text -F+f12p+cTL -Dj-12p/-26p -N
	gmt colorbar -DJRM+o4p/0
gmt end show