cryplot v0.1.1
Crystal Plotting Shard
Cryplot
is Crystal plotting library powered by gnuplot
. The goal of the Cryplot is to enable you, Crystal programmer, to conveniently plot beautiful graphs as easy as in other high-level programming languages.
The only external runtime dependencies is gnuplot executable and it need to be in your system path.
gnuplot-palettes color palettes are downloaded at shard installation and made available to your use via simply invoking the plot#palette
and passing in any available palette enum Cryplot::Palette
.
Installation
-
Add the dependency to your
shard.yml
:dependencies: cryplot: github: naqvis/cryplot
-
Run
shards install
Example 1
require "cryplot"
# Create a vector with values from 0 to 5 divived into 100 uniform intervals
x = Cryplot.linspace(0.0, 5.0, 100)
# Create a plot object
Cryplot.plot {
# set color palette
palette(:set2)
# Draw a sine graph putting x on the x-axis and sin(x) on the y-axis
draw_curve(x, x.map { |v| Math.sin(v) }).label("sin(x)").line_width(4)
# Draw a cosine graph putting x on the x-axis and cos(x) on the y-axis
draw_curve(x, x.map { |v| Math.cos(v) }).label("cos(x)").line_width(4)
# Show the plot in a pop-up window
show
# Save the plot a PDF file
save("plot.pdf")
}
Running above sample code will produce and show you following plot:
Example 2 (Use custom gnuplot commands)
require "cryplot"
time = [0.0, 1.0, 2.1, 3.1, 4.2, 5.2, 6.2, 7.2, 8.2, 9.1, 10.0, 11.0, 12.0,
12.9, 13.8, 14.9, 15.9, 17.0, 17.9, 18.9, 20.0, 21.0, 22.0, 23.0, 24.0, 25.0,
26.0, 27.0, 28.0, 29.0, 30.0, 31.0, 32.0, 32.9, 33.8, 34.7, 35.7, 36.6, 37.7]
angle = [-14.7, 8.6, 28.8, 46.7, 47.4, 36.5, 37.0, 5.1, -11.2, -22.4, -35.5, -33.6, -21.1,
-15.0, -1.6, 19.5, 27.5, 32.6, 27.5, 20.2, 13.8, -1.3, -24.5, -25.0, -25.0, -20.2,
-9.9, 5.8, 14.7, 21.8, 29.8, 21.4, 24.6, 25.8, 0.6, -16.6, -24.0, -24.6, -19.8]
stdvar = [3.6, 3.6, 3.0, 3.4, 3.5, 3.4, 10.3, 3.4, 3.4, 3.5, 3.6, 3.9, 3.9,
4.2, 2.7, 3.2, 2.8, 3.5, 2.7, 3.3, 3.4, 4.2, 6.7, 3.3, 3.1, 3.6,
3.2, 3.2, 3.0, 3.5, 2.7, 4.1, 2.7, 12.0, 2.9, 3.2, 3.7, 3.8, 3.5]
Cryplot.plot {
# Set the Title of the plort
title("Cavendish Data").title_font_size(20).title_text_color("blue")
# Set x-axix and y-axis labels
xlabel("Time (s)")
ylabel("Angle (mrad)")
# Adjust the Legend position
legend.at_top_right
# Adjust grid , border, style, tics settings
grid
.show
.back
.line_width(1)
border.none
style_fill.border_show
tics.hide
border.left.right.top.bottom.back
# Draw Error Bars
draw_error_bars_y(time, angle, stdvar).line_width(2).line_color("purple").label_none
# Draw raw-data line by using the same dataset
draw("1:2", "lines").line_color("green").line_width(2).label("raw data")
# custom gnuplot commands (these commands are passed as-is to gnuplot)
gnuplot("theta(t) = theta0 + a * exp(-t / tau) * sin(2 * pi * t / T + phi)")
gnuplot("fit theta(x) '#{data_filename}' using 1:2:3 via a, tau, phi, T, theta0")
# draw best fit curve
draw("theta(x)", "", "").label("best-fit curve").line_width(3).line_color("orange")
# Set the size
size(480, 380)
# Show the plot in a pop-up window
show
# Save the plot in PNG file
save("best-fit-curve.png")
}
Running above sample code will produce and show you following plot:
Refer to specs
or examples
folder for further samples.
Available Color Palettes
Do you want to change the colors?
All available color palettes and their names can be found here.
Development
To run all tests:
crystal spec
Contributing
- Fork it (https://github.com/naqvis/cryplot/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
Contributors
- Ali Naqvi - creator and maintainer
cryplot
- 22
- 4
- 2
- 2
- 0
- 2 months ago
- May 27, 2021
MIT License
Tue, 21 Jan 2025 22:33:56 GMT