File: area_interpolation.rb

package info (click to toggle)
ruby-rubyvis 0.6.1%2Bdfsg1-2
  • links: PTS, VCS
  • area: main
  • in suites: buster, stretch
  • size: 1,808 kB
  • ctags: 679
  • sloc: ruby: 11,114; makefile: 2
file content (63 lines) | stat: -rw-r--r-- 1,320 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# = Area Interpolation
# This example show the 5 types of interpolation available for areas:
# * linear
# * step-before
# * step-after
# * basis
# * cardinal
# 
# See also "Line Interpolation":line_interpolation.html
$:.unshift(File.dirname(__FILE__)+"/../../lib")
require 'rubyvis'

data = Rubyvis.range(0, 10, 0.5).map {|x| 
  OpenStruct.new({:x=> x, :y=> Math.sin(x) + 2+rand()*0.3})
}

p_w=200
p_h=150
#p data
w = 20+p_w*2
h = 20+p_h*3

x = Rubyvis.Scale.linear(data, lambda {|d| d.x}).range(0, p_w-30)
y = Rubyvis.Scale.linear(data, lambda {|d| d.y}).range(0, p_h-20);
interpolations=["linear","step-before","step-after", "basis", "cardinal"]

vis = Rubyvis::Panel.new do |pan|
  pan.width w 
  pan.height h 
  pan.bottom 20 
  pan.left 20 
  pan.right 10 
  pan.top 5 

  interpolations.each_with_index do |inter,i|
    n=i%2
    m=(i/2).floor
    pan.panel do
      left(n*(p_w+10))
      top(m*(p_h+10))
      width p_w
      height p_h
      label(:anchor=>'top') do
        text(inter)
      end
      # uses 'a' as reference inside block
      # to use data method with data variable
      area do |a| 
        a.data data
        a.left {|d| x.scale(d.x)}
        a.height {|d| y.scale(d.y)}
        a.bottom 1
        a.interpolate inter
      end
    end
  end
end  
     

vis.render();


puts vis.to_svg