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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
|
- .. index:: ! subplot
- .. include:: module_core_purpose.rst_
- *******
- subplot
- *******
- |subplot_purpose|
- The **subplot** module is used to split the current figure into a rectangular layout of subplots
- that each may contain a single self-contained figure. A subplot setup is started with the **begin**
- directive that defines the layout of the subplots, while positioning to a particular subplot for
- plotting is done via the **set** directive. The subplot process is completed via the **end** directive.
- Synopsis (begin mode)
- ---------------------
- .. include:: common_SYN_OPTs.rst_
- **gmt subplot begin** *nrows*\ **x**\ *ncols*
- |-F|\ [**f**\|\ **s**]\ *width*\ /*height*\ [**+f**\ *wfracs*\ /*hfracs*][**+c**\ *dx/dy*][**+g**\ *fill*][**+p**\ *pen*][**+w**\ *pen*]
- [ |-A|\ *autolabel* ]
- [ |-C|\ [*side*]\ *clearance* ]
- [ |SYN_OPT-B| ]
- [ |-J|\ *parameters* ]
- [ |-M|\ *margins* ]
- [ |SYN_OPT-R| ]
- [ |-S|\ *layout* ]
- [ |-T|\ *title* ]
- [ |SYN_OPT-V| ]
- [ |SYN_OPT-X| ]
- [ |SYN_OPT-Y| ]
- [ |SYN_OPT--| ]
- |No-spaces|
- Description
- -----------
- The **begin** directive of subplot defines the layout of the entire multi-panel illustration. Several
- options are available to specify the systematic layout, labeling, dimensions, and more for the subplots.
- Required Arguments
- ------------------
- *nrows*\ **x**\ *ncols*
- Specifies the number of rows and columns of subplots. Each row will have
- the same number of subplots.
- **Note**: You are not required to place a plot in each subplot.
- .. _-F:
- **-F**\ [**f**\|\ **s**]\ *width(s)*\ /*height(s)*\ \ [**+f**\ *wfracs*\ /*hfracs*][**+c**\ *dx/dy*][**+g**\ *fill*][**+p**\ *pen*][**+w**\ *pen*]
- Specify the dimensions of the figure. There are two different ways to do this:
- (**f**) Specify overall figure dimensions or (**s**) specify the dimensions of
- a single subplot.
- **-Ff**
- Specify the final **f**\ igure dimensions. The subplot dimensions are then calculated from the figure
- dimensions after accounting for the space that optional tick marks, annotations, labels, and margins occupy between subplots.
- As for other figures, annotations, ticks, and labels along the outside perimeter are not counted as part of the figure dimensions.
- To specify different subplot dimensions for each row (or column), append **+f** followed by a comma-separated list of width
- fractions, a slash, and then the list of height fractions. For example **-Ff**\ 10c/10c\ **+f**\ 3,1/1,2 will make the first column
- three times as wide as the second, while the second row will be twice as tall as the first row.
- A single number means constant widths (or heights) [Default].
- **-Fs**
- Specify the dimensions of each **s**\ ubplot directly. Then, the figure dimensions are computed from the
- subplot dimensions after adding the space that optional tick marks, annotations, labels, and margins occupy between subplots.
- As for other figures, annotations, ticks, and labels along the outside perimeter are not counted as part of the figure dimensions.
- To specify different subplot dimensions for each row (or column), append a comma-separated list of widths,
- a slash, and then the comma-separated list of heights. A single number means constant widths (or heights) [Default].
- For example **-Fs**\ 5c,8c/8c will make the first column 5 cm wide and the second column 8 cm wide, with
- all having a constant height of 8 cm. The number of values must either be one (constant across the rows or columns)
- or exactly match the number of rows (or columns). For geographic maps, the height of each subplot depends on
- your map region and projection. There are two options: (1) Specify both **-R** and **-J** and we use these
- to compute the height of each subplot. All subplots must share the same region and projection and you specify
- a zero *height*, or (2) you can select *height* based on trial and error to suit your plot layout.
- Optionally, you may draw the outline (**+p**\ *pen*) or paint (**+g**\ *fill*\) the figure rectangle behind the
- subplots, add dividing lines between panels (**+w**\ *pen*), and even expand it via **+c**. These are most
- useful if you supply **-B+n** to **subplot begin**, meaning no ticks or annotations will take place in the subplots.
- Optional Arguments
- ------------------
- .. _-A:
- **-A**\ [*autolabel*][**+c**\ *dx*\ [/*dy*]][**+g**\ *fill*][**+j**\|\ **J**\ *refpoint*][**+o**\ *dx*\ [/*dy*]][**+p**\ *pen*][**+r**\|\ **R**][**+v**]
- Specify automatic tagging of each subplot. Append either a number or letter [a].
- This sets the tag of the first, top-left subplot and others follow sequentially.
- Surround the number or letter by parentheses on any side if these should be typeset
- as part of the tag (**Note**: In UNIX shells you may need to escape these parentheses.)
- Use **+j**\|\ **J**\ *refpoint* to specify where the tag should be placed in the subplot [TL].
- **Note**: **+j** sets the justification of the tag to *refpoint* (suitable for interior tags)
- while **+J** instead selects the mirror opposite (suitable for exterior tags).
- Append **+c**\ *dx*\ [/*dy*] to set the clearance between the tag and a surrounding text box
- requested via **+g** or **+p** [3p/3p, i.e., 15% of the :term:`FONT_TAG` size dimension].
- Append **+g**\ *fill* to paint the tag's text box with *fill* [no painting].
- Append **+o**\ *dx*\ [/*dy*] to offset the tag's reference point in the direction implied
- by the justification [4p/4p, i.e., 20% of the :term:`FONT_TAG` size].
- Append **+p**\ *pen* to draw the outline of the tag's text box using selected *pen* [no outline].
- Append **+r** to typeset your tag numbers using lowercase Roman numerals;
- use **+R** for uppercase Roman numerals [Arabic numerals].
- Append **+v** to increase tag numbers vertically down columns [horizontally across rows].
- .. include:: explain_-B.rst_
- .. _-C:
- **-C**\ [*side*]\ *clearance*
- Reserve a space of dimension *clearance* between the margin and the subplot on the specified
- side, using *side* values from **w**, **e**, **s**, or **n**, or **x** for both **w** and **e**
- or **y** for both **s** and **n**. No *side* means all sides. The option is repeatable to set aside space
- on more than one side. Such space will be left untouched by the main map plotting but can
- be accessed by modules that plot scales, bars, text, etc. Settings specified under **begin** directive apply
- to all subplots, while settings under **set** only apply to the selected (active) subplot. **Note**: Common options **-X**
- and **-Y** are not available during subplots; use **-C** instead.
- .. _-J:
- .. |Add_-J| unicode:: 0x20 .. just an invisible code
- .. include:: explain_-J.rst_
- .. _-M:
- **-M**\ *margins*
- This is margin space that is added *between* neighboring subplots (i.e., the interior margins) *in addition*
- to the automatic space added for tick marks, annotations, and labels. The margins can be specified as
- a single value (for same margin on all sides), a pair of values separated by slashes
- (for setting separate horizontal and vertical margins), or the full set of four slash-separated margins
- (for setting separate left, right, bottom, and top margins). The actual gap created is always a sum of
- the margins for the two opposing sides (e.g., east plus west or south plus north margins) [Default is
- half the primary annotation font size, giving the full annotation font size as the default gap].
- .. _-R:
- .. |Add_-R| replace:: This is useful when all subplots share a common plot domain. In this module, the chosen region will also become the default for any data region needed by computational modules.
- .. include:: explain_-R.rst_
- .. _-S:
- **-S**\ *layout*
- Set subplot layout for shared axes. May be set separately for rows (**-SR**) and columns (**-SC**).
- Considerations for **-SC**: Use when all subplots in a **C**\ olumn share a common *x*-range. The first (i.e., **t**\ op) and the last
- (i.e., **b**\ ottom) rows will have *x* annotations; append **t** or **b** to select only one of those two rows [both].
- Append **+l** if annotated *x*-axes should have a label [none]; optionally append the label if it is the same
- for the entire subplot.
- Append **+t** to make space for subplot titles for each row; use **+tc** for top row titles only [no subplot titles].
- Labels and titles that depends on which row or column are specified as usual via a subplot's own **-B** setting.
- Considerations for **-SR**: Use when all subplots in a **R**\ ow share a common *y*-range. The first (i.e., **l**\ eft) and the last
- (i.e., **r**\ ight) columns will have *y*-annotations; append **l** or **r** to select only one of those two columns [both].
- Append **+l** if annotated *y*-axes will have a label [none]; optionally, append the label if it is the same
- for the entire subplot.
- Append **+p** to make all annotations axis-parallel [horizontal]; if not used you may have to set **-C** to secure
- extra space for long horizontal annotations.
- Append **+w** to draw horizontal and vertical lines between interior panels using selected pen [no lines].
- .. _-T:
- **-T**\ *heading*
- While individual subplots can have titles (see **-S** or **-B**), the entire figure may also have a
- overarching *heading* [no heading]. Font is determined by setting :term:`FONT_HEADING`.
- .. _-V:
- .. |Add_-V| unicode:: 0x20 .. just an invisible code
- .. include:: explain_-V.rst_
- .. _-X:
- .. include:: explain_-XY.rst_
- .. include:: explain_help.rst_
- Synopsis (set mode)
- -------------------
- **gmt subplot set** [ *row,col*\|\ *index* ] [ **-A**\ *fixedlabel*] [ **-C**\ *side*\ *clearance* ] [ |SYN_OPT-V| ]
- Before you start plotting you must first select the active subplot.
- **Note**: If any **-J** option is passed with **?** as scale or width when plotting subplots,
- then the dimensions of the map are automatically determined by the subplot size and your region.
- For Cartesian plots: If you want the scale to apply *equally* to both dimensions
- then you must specify **-Jx** [The default **-JX** will fill the subplot by using unequal scales].
- Optional Arguments
- ------------------
- *row,col*
- Sets the current subplot until further notice. **Note**: First *row* or *col* is 0, not 1. If not given we go to the next subplot by order
- specified via **-A**. As an alternative, you may bypass the **set** mode and
- instead supply the common option **-c**\ [*row,col*] to the first plot command you issue in that subplot.
- GMT maintains information about the current figure and subplot. Also, you may give the one-dimensional
- *index* instead which starts at 0 and follows the row or column order set via **-A**.
- .. _subplot_set-A:
- **-A**\ *fixedlabel*
- Overrides the automatic labeling with the given string. No modifiers are allowed.
- Placement, justification, etc. are all inherited from how **-A** was specified by the
- initial **subplot begin** command.
- .. _subplot_set-C2:
- **-C**\ [*side*]\ *clearance*
- Reserve a space of dimension *clearance* between the margin and the subplot on the specified
- side, using *side* values from **w**, **e**, **s**, or **n**. The option is repeatable to set aside space
- on more than one side. Such space will be left untouched by the main map plotting but can
- be accessed by modules that plot scales, bars, text, etc. This setting overrides the common
- clearances set by **-C** during **subplot begin**.
- .. _subplot_set-V:
- .. include:: explain_-V.rst_
- Any number of plotting command can now take place and all output will be directed to the
- selected subplot. There are a few other rules that need to be followed:
- (1) The subplot machinery expects the first plotting command in a new subplot window
- to take care of plotting the base frame. The particulars of this frame may have been
- specified by the **-S** option in **subplot begin**. In either case, should you need to set or override
- frame and axis parameters then you must specify these **-B** options with this first plot
- command. (2) The subplot machinery automatically uses the **-X** and **-Y** options under
- the hood so these options are not available while a subplot is active.
- Synopsis (end mode)
- -------------------
- **gmt subplot end** [ |SYN_OPT-V| ]
- This command finalizes the current subplot, including any placement of tags, and updates the
- gmt.history to reflect the dimensions and linear projection required to draw the entire figure
- outline. This allows subsequent commands, such as colorbar, to use **-DJ** to place bars with
- reference to the complete figure dimensions. We also reset
- the current plot location to where it was prior to the subplot.
- Optional Arguments
- ------------------
- .. _subplot_end-V:
- .. include:: explain_-V.rst_
- Examples
- --------
- To make a minimalistic 2x2 basemap layout called panels.pdf, try::
- gmt begin panels pdf
- gmt subplot begin 2x2 -Fs8c -M5p -A -SCb -SRl -Bwstr
- gmt subplot set
- gmt basemap -R0/80/0/10
- gmt subplot set
- gmt basemap
- gmt subplot set
- gmt basemap
- gmt subplot set
- gmt basemap
- gmt subplot end
- gmt end show
- Restriction
- -----------
- Currently, nesting of subplots is not implemented.
- See Also
- --------
- :doc:`begin`,
- :doc:`clear`,
- :doc:`docs`,
- :doc:`end`,
- :doc:`figure`,
- :doc:`inset`,
- :doc:`gmt`
|