GR.rb
Installation
First, install GR. Then install gr-plot
gem.
gem install gr-plot
pkg-config will detect the location of the shared library. Otherwise, you need to specify the environment variable.
export GRDIR="/your/path/to/gr"
Quick Start
require 'gr/plot'
x = [0, 0.2, 0.4, 0.6, 0.8, 1.0]
y = [0.3, 0.5, 0.4, 0.2, 0.6, 0.7]
# show the figure
GR.plot(x, y)
# Save the figure in PNG format.
GR.savefig("figure.png")
GR.rb supports Jupyter Notebook / Lab.
API Overview
GR::Plot - A simple, matlab-style API
require 'gr/plot'
GR.plot(x, y)
List of available functions.
plot
step
plot3
polar
scatter
scatter3
stem
barplot
histogram
polarhistogram
hexbin
contour
contourf
β¦
GR.rb is a Ruby visualization tool I've been working since last fall. This is the binding of GR Framework, which is the default backend for Plots.jl. Here you can see a gallery of some of our examples.
Getting ready
Install GR Framework.
Set environment variable GRDIR.
export GRDIR="/your/path/to/gr"
gem install ruby-gr
```
you'll need the `ruby-gr`, `numo-narray` gems.
```
gem install ruby-gr
```
```ruby
require 'gr/plot'
require 'numo/narray'
```
## Line Plots
```ruby
x = Numo::DFloat.linspace(0, 10, 1001)
y = Numo::NMath.sin(x)
GR.plot(x, y)
```
data:image/s3,"s3://crabby-images/fd63d/fd63d37754863c702aebc5a3bb018f452019530d" alt=""
```ruby
x = Numo::DFloat.linspace(0, 10, 51)
y = Numo::NMath.sin(x)
GR.step(x, y)
```
data:image/s3,"s3://crabby-images/07c40/07c4015cfcdf61561a83a8d1535777227f6e94ea" alt=""
```ruby
x = Numo::DFloat.linspace(0, 30, 1000)
y = Numo::NMath.cos(x) * x
z = Numo::NMath.sin(x) * x
GR.plot3(x, y, z)
```
data:image/s3,"s3://crabby-images/8af9d/8af9dce408f88f538f9147870a26122e3d8f11e8" alt=""
```ruby
angles = Numo::DFloat.linspace(0, 2 * Math::PI, 40)
radii = Numo::DFloat.linspace(0, 20, 40)
GR.polar(angles, radii)
```
data:image/s3,"s3://crabby-images/65056/65056b7dfa578ec48fcc95f6ef968ee2a79b0a59" alt=""
## Scatter Plots
```ruby
x = Numo::DFloat.linspace(0, 1, 51)
y = x - x**2
s = x * 200
GR.scatter(x, y, s)
```
data:image/s3,"s3://crabby-images/03b04/03b04ab244ba33909be6727419cb858a4de8dd61" alt=""
```ruby
x = Numo::DFloat.linspace(0, 1, 51)
y = x - x**2
s = Numo::DFloat.linspace(50, 300, x.size)
c = Numo::DFloat.linspace(0, 255, x.size)
GR.scatter(x, y, s, c)
```
data:image/s3,"s3://crabby-images/d6ee6/d6ee6a360745751f60e7fe258d55a372a89ebd47" alt=""
```ruby
x = 2 * Numo::DFloat.new(100).rand - 1
y = 2 * Numo::DFloat.new(100).rand - 1
z = 2 * Numo::DFloat.new(100).rand - 1
c = 999 * Numo::DFloat.new(100).rand + 1
GR.scatter3(x, y, z, c)
```
data:image/s3,"s3://crabby-images/bb14d/bb14d8ac157f2e3911cc6397133b0b8421e8431a" alt=""
## Stem Plots
```ruby
x = Numo::DFloat.linspace(-2, 2, 40)
y = x ** 3 + x ** 2 + x + 6
GR.stem(x, y)
```
data:image/s3,"s3://crabby-images/2a9b2/2a9b2e00766262b9e7e3bd31934d5d56c46065a6" alt=""
## Bar Plots
```ruby
continents = ["Africa", "America", "Asia", "Europe", "Oceania"]
population_2010 = [1044, 944, 4170, 735, 36]
GR.barplot(continents, population_2010)
```
data:image/s3,"s3://crabby-images/26dd5/26dd5bb98484b2936c2d9ada6f5af21b5dc3ba31" alt=""
## Histograms
```ruby
x = Numo::DFloat.new(10_000).rand_norm
GR.histogram(x)
```
data:image/s3,"s3://crabby-images/a0233/a02334b9dc287772caa1e861e47ac6590b14001a" alt="image"
```ruby
x = Numo::DFloat.new(10_000).rand_norm
y = Numo::DFloat.new(10_000).rand_norm
GR.hexbin(x, y)
```
data:image/s3,"s3://crabby-images/db9af/db9aff22ea3404b051dd2f390b0d78b509602c7a" alt="image"
## Contour Plots
```ruby
x = 8 * Numo::DFloat.new(60).rand - 4
y = 8 * Numo::DFloat.new(60).rand - 4
z = Numo::NMath.sin(x) + Numo::NMath.cos(y)
GR.contour(x, y, z)
```
data:image/s3,"s3://crabby-images/78b09/78b0911eefb1cbe23d91933943fb4c0192a82dc0" alt="image"
```ruby
_x = Numo::DFloat.linspace(-2, 2, 40)
_y = Numo::DFloat.linspace(0, Math::PI, 20)
x = (_x.expand_dims(0) * Numo::DFloat.ones(_y.size, 1)).flatten
y = (_y.expand_dims(1) * Numo::DFloat.ones(1, _x.size)).flatten
z = (Numo::NMath.sin(x) + Numo::NMath.cos(y)).flatten
GR.contour(x, y, z)
```
data:image/s3,"s3://crabby-images/c78f0/c78f0a5273b440f80fa6a827ae00f41fefbb617e" alt=""
```ruby
x = 8 * Numo::DFloat.new(100).rand - 4
y = 8 * Numo::DFloat.new(100).rand - 4
z = Numo::NMath.sin(x) + Numo::NMath.cos(y)
GR.contourf(x, y, z)
```
data:image/s3,"s3://crabby-images/d70fb/d70fba73939307da820584b1b471ef35a93c5abd" alt=""
```ruby
x = 8 * Numo::DFloat.new(300).rand - 4
y = 8 * Numo::DFloat.new(300).rand - 4
z = Numo::NMath.sin(x) + Numo::NMath.cos(y)
GR.tricont(x, y, z)
```
data:image/s3,"s3://crabby-images/f5b3a/f5b3ac56ff254adba66f22508da12c68df7ca6bd" alt=""
## Surface Plots
```ruby
x = 8 * Numo::DFloat.new(100).rand - 4
y = 8 * Numo::DFloat.new(100).rand - 4
z = Numo::NMath.sin(x) + Numo::NMath.cos(y)
GR.surface(x, y, z)
```
data:image/s3,"s3://crabby-images/cac0e/cac0e5f939c6e98e70b99547f508b112710309ae" alt=""
```ruby
x = 8 * Numo::DFloat.new(100).rand - 4
y = 8 * Numo::DFloat.new(100).rand - 4
z = Numo::NMath.sin(x) + Numo::NMath.cos(y)
GR.trisurf(x, y, z)
```
data:image/s3,"s3://crabby-images/a9400/a9400bd2ef3a579af6c0fa78f68ec7b04aff9f8d" alt=""
```ruby
x = 8 * Numo::DFloat.new(1000).rand - 4
y = 8 * Numo::DFloat.new(1000).rand - 4
z = Numo::NMath.sin(x) + Numo::NMath.cos(y)
GR.wireframe(x, y, z)
```
data:image/s3,"s3://crabby-images/5bbbd/5bbbd6d416f3e910b85c7f2df1f5cc3bb28b8461" alt=""
## Volume Rendering
```ruby
z = Numo::DFloat.new(50, 50, 50).rand_norm
GR.volume(z)
```
data:image/s3,"s3://crabby-images/75f40/75f40dd8e9d056cf93173426420999db615b623f" alt=""
## Heatmaps
```ruby
x = Numo::DFloat.linspace(-2, 2, 40)
y = Numo::DFloat.linspace(0, Math::PI, 20)
z = Numo::NMath.sin(x).expand_dims(0).transpose + Numo::NMath.cos(y)
GR.heatmap(z)
```
data:image/s3,"s3://crabby-images/46ed3/46ed316155603a02410585042af6b607dfa2407c" alt="image"
```ruby
n = 1_000_000
x = Numo::DFloat.new(n).rand_norm
y = Numo::DFloat.new(n).rand_norm
GR.shade(x, y)
```
data:image/s3,"s3://crabby-images/1daa1/1daa1b93cd2e952457a7fac829f7cd59468981eb" alt=""
## Images
```ruby
x = Numo::DFloat.linspace(-1, 1, 20)
y = Numo::DFloat.linspace(0, Math::PI, 30)
z = Numo::NMath.sin(x).expand_dims(0).transpose + Numo::NMath.cos(y)
GR.imshow(z)
```
data:image/s3,"s3://crabby-images/e0e3f/e0e3f9b41cee4b6cd8bc1a8a45f65bba3570d8dc" alt=""
## Isosurfaces
```ruby
s = Numo::DFloat.linspace(-0.6, 0.6, 50)
v = 1 - ((s**2 + (s**2).expand_dims(0).transpose).expand_dims(2) + s.reshape(1, 1, true)**2)**0.5
GR.isosurface(v)
```
data:image/s3,"s3://crabby-images/8deb5/8deb5debc8da316214e61b37a7b57943c9ef6e0f" alt=""
## Subplots
```ruby
require 'gr/plot'
x = [1,2,3,4,5,6,7,8,9,10]
y = x.shuffle
GR.barplot x, y, GR.subplot(2, 2, 1)
GR.stem x, y, GR.subplot(2, 2, 2)
GR.step x, y, GR.subplot(2, 2, 3)
GR.plot x, y, GR.subplot(2, 2, 4)
```
data:image/s3,"s3://crabby-images/4071f/4071f72e02ba9aa7fb60980277adfe6de5cd1e32" alt=""
## Resources
* https://github.com/red-data-tools/GR.rb/wiki/
Top comments (0)