File: hello.rb

package info (click to toggle)
fityk 1.3.2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 3,772 kB
  • sloc: cpp: 34,595; ansic: 4,676; python: 963; makefile: 384; sh: 119; xml: 91; java: 31; ruby: 27; perl: 25
file content (39 lines) | stat: -rwxr-xr-x 1,014 bytes parent folder | download | duplicates (6)
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
#!/usr/bin/env ruby

# Example of using libfityk from ruby.
# To run this example, you need fityk extension for Ruby: after compiling
# fityk go to src/, run "make ruby" and copy swig/fityk.so.

require 'fityk'

class GaussianFitter < Fityk::Fityk
    def initialize(filename)
        super()
        raise "File `#{filename}' not found." unless File::exists? filename
        @filename = filename
        execute("@0 < '#{filename}'")
        puts "Data info: " + get_info("data", 0)
    end

    def run()
        execute("guess %gauss = Gaussian")
        puts "Fitting #{@filename}..."
        execute("fit")
        puts "WSSR=%g" % get_wssr()
        puts "Gaussian center: %.5g" % calculate_expr("%gauss.center")
    end

    def save_session(filename)
        execute("info state >'%s'" % filename)
    end
end

f = Fityk::Fityk.new
puts f.get_info("version")
puts "ln(2) = %.9f" % f.calculate_expr("ln(2)")
f = nil

gauss = GaussianFitter.new("nacl01.dat")
gauss.run()
gauss.save_session("tmp_save.fit")