#!/usr/bin/env ruby
require("rbgsl")
n = 100
data = GSL::Vector.alloc(n)
#data = NArray.float(n)
for i in (n/3)...(2*n/3) do
data[i] = 1.0
end
org = data.clone
rtable = GSL::FFT::Real::Wavetable.alloc(n)
rwork = GSL::FFT::Real::Workspace.alloc(n)
data.real_transform!(rtable, rwork)
for i in 11...n do
data[i] = 0.0
end
hctable = GSL::FFT::HalfComplex::Wavetable.alloc(n)
#data2 = ffted.halfcomplex_inverse(hctable, rwork)
#data2 = ffted.halfcomplex_inverse()
#data2 = ffted.ifft
#data2 = GSL::FFT::HalfComplex.inverse(ffted)
#data.halfcomplex_inverse!(hctable, rwork)
data.ifft!(hctable, rwork)
GSL::graph(nil, org, data, "-T X -C -g 3 -L 'Real-halfcomplex' -x 0 #{data.size}")
syntax highlighted by Code2HTML, v. 0.9.1