-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsiman_nestloop.sthlp
152 lines (107 loc) · 8.05 KB
/
siman_nestloop.sthlp
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
{smcl}
{* *! version 0.11.1 21oct2024}{...}
{vieweralsosee "Main siman help page" "siman"}{...}
{viewerjumpto "Syntax" "siman_nestloop##syntax"}{...}
{viewerjumpto "Description" "siman_nestloop##description"}{...}
{viewerjumpto "Example" "siman_nestloop##example"}{...}
{viewerjumpto "References" "siman_nestloop##references"}{...}
{viewerjumpto "Authors" "siman_nestloop##authors"}{...}
{title:Title}
{phang}
{bf:siman nestloop} {hline 2} Nested loop plot of performance measures data.
{marker syntax}{...}
{title:Syntax}
{phang}
{cmdab:siman nestloop} [{it:performancemeasures}] [if]
[{cmd:,}
{it:options}]
{pstd}{it:performancemeasures} are any performance measures that have been calculated by {help siman analyse}. See {help siman analyse##perfmeas:performance measures}.
{pstd}The {it:if} condition should usually apply only to {bf:dgm}, {bf:target} and {bf:method}, and not e.g. to {bf:repetition}. A warning is issued if this is breached.
{synoptset 28 tabbed}{...}
{synopthdr}
{synoptline}
{syntab:Options controlling the main graph}
{synopt:{opt dgmo:rder(string)}}defines the order of data generating mechanisms for the nested loop plot. A negative sign in front of the variable name
will display its values on the graph in descending order.{p_end}
{synopt:{opt stag:ger(#)}}horizontally staggers the main graphs for different methods. Default # is 0. Try {cmd:stagger(0.05)} to make the lines more distinct.{p_end}
{synopt:{opt c:onnect(string)}}controls how the main graph and descriptor graph are connected.
Default is {cmd:connect(J)} which shows each performance measure value as a horizontal line with vertical joins (as described by {help siman nestloop##ruckerschwarzer:Rücker and Schwarzer, 2014}).
An alternative is {cmd:connect(L)} which shows each performance measure value at a point with diagonal joins.{p_end}
{synopt:{opt noref:line}}prevents display of reference lines for certain performance measures (coverage, bias, relprec and relerror).{p_end}
{synopt:{opt lev:el}}specifies where the reference line for performance measure coverage will be drawn.{p_end}
{syntab:Options controlling the descriptor graph}
{synopt:{opt dgsi:ze(#)}}defines the vertical size of the descriptor graph, as a fraction of the whole vertical axis. Default # is 0.35.{p_end}
{synopt:{opt dgga:p(#)}}defines the vertical size of the gap between the main graph and the descriptor graph, as a fraction of the whole vertical axis. Default # is 0.{p_end}
{synopt:{opt dgin:nergap(#)}}controls the vertical spacing between the descriptor graphs. Default # is 3.{p_end}
{synopt:{opt dgco:lor(string)}}controls the colour(s) for the descriptor graphs and their labels. Default is gs4.{p_end}
{synopt:{opt dgpa:ttern(string)}}controls the pattern(s) for descriptor graph. Default is solid.{p_end}
{synopt:{opt dgla:bsize(string)}}controls the size of the descriptor graph labels. Default is vsmall.{p_end}
{synopt:{opt dgst:yle(string)}}controls the style(s) of the descriptor graph.{p_end}
{synopt:{opt dglw:idth(string)}}controls the width(s) of the descriptor graph.{p_end}
{syntab:Other graph options}
{synopt:{opt methleg:end}{cmd:(item|title)}}includes the name of the method variable in each legend item or as the legend title. The default is neither.{p_end}
{synopt:{opt scena:riolabel}}labels the horizontal axis with scenario numbers.
The default is an unlabelled axis, since the descriptor graphs describe the scenarios.{p_end}
{synopt:{it:graph_options}}Most of the valid options for {help line:line} are available.
We find these especially useful: {cmd:ylabel()} to stop the y-labels extending to the descriptor graph;
{cmd:legend()} to arrange legends in a single row or column, e.g.
{cmd:legend(pos(6) row(1))} or {cmd:legend(pos(3) col(1))}.{p_end}
{syntab:Saving options}
{synopt:{opt sav:ing}{it:(namestub[}{cmd:, replace}{it:])}}saves each graph to disk in Stata format.
The graph name is {it:namestub} with the target and performance measures appended.{p_end}
{synopt:{opt exp:ort}{it:(format[}{cmd:, replace}{it:])}}exports each graph to disk in non-Stata format.
{cmd:saving()} must also be specified, and the file name is the same as for {cmd:saving()} with the appropriate filetype.{p_end}
{synoptline}
{marker description}{...}
{title:Description}
{pstd}
{cmd:siman nestloop} draws a nested loop plot of performance measures data ({help siman nestloop##ruckerschwarzer:Rücker and Schwarzer, 2014}).
One graph is drawn for each combination of target and performance measure.
Each graph presents the simulation results for all data generating mechanisms and all methods in one plot.
{pstd}
The performance measure is split by method and is stacked according to the levels of the data generating mechanisms along the horizontal axis.
The nested loop plot loops through nested data-generating mechanisms and plots results for different methods on top of each other in a full factorial design.
{pstd}The user can select a subset of performance measures to be graphed using the
performance measures listed in {help siman analyse##perfmeas:performance measures}.
If no performance measures are specified, then graphs will be drawn for {help siman analyse##bias:bias}, {help siman analyse##empse:empse} and {help siman analyse##cover:coverage};
except that if {cmd:true()} was not specified in {help siman setup}, then graphs will be drawn for {help siman analyse##mean:mean}, {help siman analyse##empse:empse} and {help siman analyse##relerror:relerror}.
{pstd}
The user can specify {it:if} within the {cmd:siman lollyplot} syntax.
The {it:if} condition should only apply to {bf:dgm}, {bf:target} and {bf:method}.
If the {it:if} condition is applied to other variables, an error "no observations" is likely.
{pstd}
We recommend to sort the simulation dataset in such a way that the simulation parameter with the largest influence on the criterion
of interest is considered first, and so forth. Further guidance can be found in {help siman nestloop##ruckerschwarzer:Rücker and Schwarzer, 2014}.
{pstd}
{help siman setup} and {help siman analyse} need to be run first before {bf:siman nestloop}.
{marker example}{...}
{title:Example}
{pstd}Read and set up data
{phang}. {stata "use https://raw.githubusercontent.com/UCL/siman/master/testing/data/extendedtestdata, clear"}
{phang}. {stata "siman setup, rep(rep) dgm(beta pmiss mech) method(method) target(estimand) est(b) se(se) true(true)"}
{phang}. {stata "siman analyse, notable"}
{pstd}Simple use of nestloop, focussing on one performance measure (% error in model-based standard error)
{phang}. {stata "siman nestloop relerror"}
{pstd}Focus on one estimand
{phang}. {stata `"siman nestloop relerror if estimand=="effect""'}
{pstd}Tailor the graph appearance
{phang}. {stata `"siman nestloop relerror if estimand=="effect", dgmorder(beta pmiss -mech) stagger(0.04) lcol(black red blue) title(Estimand: effect) xlab(none) norefline legend(row(1)) ytitle(% error in model-based SE) note("")"'}
{pstd}Tailor the descriptor graph appearance
{phang}. {stata `"siman nestloop relerror if estimand=="effect", dgsize(.4) dggap(.1) dgcol(green orange purple) dgpatt(dash solid =) dglabsize(medium) dglwidth(*2)"'}
{marker references}{...}
{title:References}
{phang}{marker ruckerschwarzer}Rücker G, Schwarzer G.
Presenting simulation results in a nested loop plot. BMC Med Res Methodol 14, 129 (2014).
{browse "https://doi.org/10.1186/1471-2288-14-129":doi:10.1186/1471-2288-14-129}
{phang}Latimer N, White I, Tilling K, Siebert U.
Improved two-stage estimation to adjust for treatment switching in randomised trials:
g-estimation to address time-dependent confounding. Statistical Methods in Medical Research. 2020;29(10):2900-2918.
{browse "https://doi.org/10.1177/0962280220912524":doi:10.1177/0962280220912524}
{marker authors}{...}
{title:Authors}
{pstd}Ella Marley-Zagar, MRC Clinical Trials Unit at UCL{break}
{pstd}Ian White, MRC Clinical Trials Unit at UCL{break}
Email: {browse "mailto:[email protected]":Ian White}
{pstd}Tim Morris, MRC Clinical Trials Unit at UCL, London, UK.{break}
Email: {browse "mailto:[email protected]":Tim Morris}
{p}{helpb siman: Return to main help page for siman}