189 lines
4.2 KiB
Markdown
189 lines
4.2 KiB
Markdown
# Examples for backend: pyplot
|
|
|
|
- Supported arguments: `annotation`, `args`, `axis`, `background_color`, `color`, `foreground_color`, `group`, `kwargs`, `label`, `layout`, `legend`, `linestyle`, `linetype`, `marker`, `markercolor`, `markersize`, `n`, `nbins`, `nc`, `nr`, `show`, `size`, `title`, `width`, `windowtitle`, `x`, `xlabel`, `y`, `ylabel`, `yrightlabel`
|
|
- Supported values for axis: `:auto`, `:left`, `:right`
|
|
- Supported values for linetype: `:none`, `:line`, `:path`, `:step`, `:stepinverted`, `:sticks`, `:scatter`, `:heatmap`, `:hexbin`, `:hist`, `:bar`
|
|
- Supported values for linestyle: `:auto`, `:solid`, `:dash`, `:dot`, `:dashdot`
|
|
- Supported values for marker: `:none`, `:auto`, `:rect`, `:ellipse`, `:diamond`, `:utriangle`, `:dtriangle`, `:cross`, `:xcross`, `:star1`, `:hexagon`
|
|
- Is `subplot`/`subplot!` supported? No
|
|
|
|
### Initialize
|
|
|
|
```julia
|
|
using Plots
|
|
pyplot()
|
|
```
|
|
|
|
### Lines
|
|
|
|
A simple line plot of the columns.
|
|
|
|
```julia
|
|
plot(rand(50,5),w=3)
|
|
```
|
|
|
|

|
|
|
|
### Functions
|
|
|
|
Plot multiple functions. You can also put the function first.
|
|
|
|
```julia
|
|
plot(0:0.01:4π,[sin,cos])
|
|
```
|
|
|
|

|
|
|
|
###
|
|
|
|
You can also call it with plot(f, xmin, xmax).
|
|
|
|
```julia
|
|
plot([sin,cos],0,4π)
|
|
```
|
|
|
|

|
|
|
|
###
|
|
|
|
Or make a parametric plot (i.e. plot: (fx(u), fy(u))) with plot(fx, fy, umin, umax).
|
|
|
|
```julia
|
|
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!`
|
|
|
|
```julia
|
|
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
|
|
|
|
```julia
|
|
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`).
|
|
|
|
```julia
|
|
plot(Vector[rand(10),rand(20)]; marker=:ellipse,markersize=8,c=[:red,:blue])
|
|
```
|
|
|
|

|
|
|
|
### Build plot in pieces
|
|
|
|
Start with a base plot...
|
|
|
|
```julia
|
|
plot(rand(100) / 3,reg=true,fillto=0)
|
|
```
|
|
|
|

|
|
|
|
###
|
|
|
|
and add to it later.
|
|
|
|
```julia
|
|
scatter!(rand(100),markersize=6,c=:blue)
|
|
```
|
|
|
|

|
|
|
|
### Heatmaps
|
|
|
|
|
|
|
|
```julia
|
|
heatmap(randn(10000),randn(10000),nbins=100)
|
|
```
|
|
|
|

|
|
|
|
### Line types
|
|
|
|
|
|
|
|
```julia
|
|
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
|
|
|
|
|
|
|
|
```julia
|
|
styles = setdiff(supportedStyles(),[:auto])
|
|
plot(cumsum(randn(20,length(styles)),1); style=:auto,label=map(string,styles),w=5)
|
|
```
|
|
|
|

|
|
|
|
### Marker types
|
|
|
|
|
|
|
|
```julia
|
|
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)
|
|
|
|
```julia
|
|
bar(randn(1000))
|
|
```
|
|
|
|

|
|
|
|
### Histogram
|
|
|
|
|
|
|
|
```julia
|
|
histogram(randn(1000),nbins=50)
|
|
```
|
|
|
|

|
|
|
|
### 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)`
|
|
|
|
```julia
|
|
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")])
|
|
```
|
|
|
|

|
|
|