Plots.jl/docs/gadfly_examples.md
Thomas Breloff 001abf684c examples
2015-09-28 15:35:45 -04:00

5.4 KiB

Examples for backend: gadfly

  • Supported arguments: annotation, args, background_color, color, fillto, group, kwargs, label, layout, legend, linestyle, linetype, marker, markercolor, markersize, n, nbins, nc, nr, reg, show, size, title, width, windowtitle, x, xlabel, xlims, xticks, y, ylabel, ylims, yticks
  • Supported values for axis: :auto, :left
  • Supported values for linetype: :none, :line, :path, :steppost, :sticks, :scatter, :heatmap, :hexbin, :hist, :bar, :hline, :vline, :ohlc
  • Supported values for linestyle: :auto, :solid, :dash, :dot, :dashdot, :dashdotdot
  • Supported values for marker: :none, :auto, :rect, :ellipse, :diamond, :utriangle, :dtriangle, :cross, :xcross, :star1, :star2, :hexagon, :octagon
  • Is subplot/subplot! supported? Yes

Initialize

using Plots
gadfly!()

Lines

A simple line plot of the columns.

plot(rand(50,5),w=3)

Functions

Plot multiple functions. You can also put the function first.

plot(0:0.01:4π,[sin,cos])

You can also call it with plot(f, xmin, xmax).

plot([sin,cos],0,4π)

Or make a parametric plot (i.e. plot: (fx(u), fy(u))) with plot(fx, fy, umin, umax).

plot(sin,(x->begin  # /home/tom/.julia/v0.4/Plots/docs/example_generation.jl, line 33:
            sin(2x)
        end),0,2π,legend=false,fillto=0)

Global

Change the guides/background/limits/ticks. You can also use shorthand functions: title!, xlabel!, ylabel!, xlims!, ylims!, xticks!, yticks!

plot(rand(10),title="TITLE",xlabel="XLABEL",ylabel="YLABEL",background_color=RGB(0.2,0.2,0.2),xlim=(-3,13),yticks=0:0.1:1)

Two-axis

Use the axis arguments.

Note: Currently only supported with Qwt and PyPlot

plot(Vector[randn(100),randn(100) * 100]; axis=[:l,:r],ylabel="LEFT",yrightlabel="RIGHT")

Vectors w/ pluralized args

Plot multiple series with different numbers of points. Mix arguments that apply to all series (singular... see marker) with arguments unique to each series (pluralized... see colors).

plot(Vector[rand(10),rand(20)]; marker=:ellipse,markersize=8,c=[:red,:blue])

Build plot in pieces

Start with a base plot...

plot(rand(100) / 3,reg=true,fillto=0)

and add to it later.

scatter!(rand(100),markersize=6,c=:blue)

Heatmaps

heatmap(randn(10000),randn(10000),nbins=100)

Line types

types = intersect(supportedTypes(),[:line,:path,:steppre,:steppost,:sticks,:scatter])
n = length(types)
x = Vector[sort(rand(20)) for i = 1:n]
y = rand(20,n)
plot(x,y,t=types,lab=map(string,types))

Line styles

styles = setdiff(supportedStyles(),[:auto])
plot(cumsum(randn(20,length(styles)),1); style=:auto,label=map(string,styles),w=5)

Marker types

markers = setdiff(supportedMarkers(),[:none,:auto])
scatter(0.5:9.5,[fill(i - 0.5,10) for i = length(markers):-1:1]; marker=:auto,label=map(string,markers),ms=10)

Bar

x is the midpoint of the bar. (todo: allow passing of edges instead of midpoints)

bar(randn(1000))

Histogram

histogram(randn(1000),nbins=50)

Subplots

subplot and subplot! are distinct commands which create many plots and add series to them in a circular fashion. You can define the layout with keyword params... either set the number of plots n (and optionally number of rows nr or number of columns nc), or you can set the layout directly with layout.

subplot(randn(100,5),layout=[1,1,3],t=[:line,:hist,:scatter,:step,:bar],nbins=10,leg=false)

Adding to subplots

Note here the automatic grid layout, as well as the order in which new series are added to the plots.

subplot(randn(100,5),n=4)

subplot!(randn(100,3))

Open/High/Low/Close

Create an OHLC chart. Pass in a vector of OHLC objects as your y argument. Adjust the tick width with arg markersize.

n = 20
hgt = rand(n) + 1
bot = randn(n)
openpct = rand(n)
closepct = rand(n)
y = [OHLC(openpct[i] * hgt[i] + bot[i],bot[i] + hgt[i],bot[i],closepct[i] * hgt[i] + bot[i]) for i = 1:n]
ohlc(y; markersize=8)

Annotations

Currently only text annotations are supported. Pass in a tuple or vector-of-tuples: (x,y,text). annotate!(ann) is shorthand for plot!(; annotation=ann)

y = rand(10)
plot(y,ann=(3,y[3],"this is #3"))
annotate!([(5,y[5],"this is #5"),(9,y[10],"this is #10")])