As an example, a tiled plot of labeled auto-covariance plots will be created.
First, we need data to plot:
= acov(eeg, lag=5)
ac, lags = labels(eeg)[signal_channels(eeg)] l
Next, a vector of plots has to be created:
= Plots.Plot{Plots.GRBackend}[]
p for idx in 1:size(ac, 1)
push!(p, plot_xac(ac[idx, :], lags, title=l[idx]))
end
There is also plot_compose()
function available:
plot_compose(p[1:7], layout=(4, 2))
This can also be done manually. Create a tiled plot (two columns) of first seven plots. First example is to plot even number of plots in two columns:
= p[1:7]
p # add empty plot in case of odd number of sub-plots
isodd(length(p)) && push!(p, plot_empty())
= Plots.plot(p..., layout=(length(p) ÷ 2, 2))
p plot_save(p, file_name="images/multi-acov.png")
It is also possible to combine different plots using complex layout:
= plot(eeg, ch=1:2)
p1 = plot_psd(eeg, ch=1, ep=1)
p2 = plot_locs(eeg, ch=1:19, selected=1:2, labels=false, large=false)
p3
# @layout macro requires Plots package to be loaded
= Plots.plot(p1, p2, p3, plot_size=(1200, 600), layout=@layout [a b; _ c{0.5h} _])
p plot_save(p, file_name="images/complex_layout.png")