Sha256: 4712da9f7ce86435f59e4f8da6237386d68d8d68badc566eac0c3d3e9a0465f7

Contents?: true

Size: 1.52 KB

Versions: 6

Compression:

Stored size: 1.52 KB

Contents

#!/usr/bin/env ruby
# This example is taken from frei2.cpp
# in "Numerische Physik" p205-206 (Springer).
#
# Reference:
#   "Numerische Physik", by Harald Wiedemann, Springer (2004)
#   ISBN: 3-540-40774-X
#   http://www.springeronline.com/sgw/cda/frontpage/0,10735,1-102-22-22345455-0,00.html

require("gsl")

#NMAX = 8192
NMAX = 256

psi = GSL::Vector::Complex[NMAX]

dx = 0.1
dt = 0.1
n_out = 20
alpha = 1
p_0 = -0.5

dp = 2*Math::PI/dx/NMAX

sum = 0.0
for n in 0...NMAX
  x = (n-NMAX/2) * dx
  psi[n] = Math::exp(-GSL::pow_2(x/alpha)/2)
  sum += GSL::pow_2(psi[n].re);
end
sum = 1.0/Math::sqrt(sum)

for n in 0...NMAX
  x = (n-NMAX/2) * dx
  psi[n] *= GSL::Complex[
    sum * Math::cos(p_0*x),
    -sum * Math::sin(p_0*x) # Imaginaerteil
  ]
end

IO.popen("graph -T X -C -g 3", "w") do |io|
  psi_p = psi.duplicate
  for n1 in 0...NMAX do
    x = (n1-NMAX/2) * dx
    io.printf("%e %e\n", x, psi[n1].abs)
  end
  io.printf("\n")

  psi_p.radix2_forward!


  t = 0.0
  for n in 1..n_out do
    t1 = n*dt
    STDOUT.printf("t = %2.1f (%2d/%2d)\n", t1, n, n_out)
    for n1 in 0...(NMAX/2) do
      pp = n1*dp
      arg = GSL::pow_2(pp)*t1/2
      psi[n1] = psi_p[n1] * GSL::Complex.polar(1, -arg)
    end
    for n1 in (NMAX/2)...NMAX do
      pp = (n1-NMAX)*dp
      arg = GSL::pow_2(pp)*t1/2
      psi[n1] = psi_p[n1] * GSL::Complex.polar(1, -arg)
    end
    psi.radix2_inverse!
    if n%10 == 0
      for n1 in 0...NMAX do
        x = (n1-NMAX/2) * dx
        io.printf("%e %e\n", x, psi[n1].abs)
      end
      io.printf("\n")
    end
  end
end

Version data entries

6 entries across 6 versions & 2 rubygems

Version Path
gsl-2.1.0.3 examples/odeiv/frei2.rb
gsl-2.1.0.2 examples/odeiv/frei2.rb
gsl-2.1.0.1 examples/odeiv/frei2.rb
gsl-2.1.0 examples/odeiv/frei2.rb
gsl-1.16.0.6 examples/odeiv/frei2.rb
rb-gsl-1.16.0.5 examples/odeiv/frei2.rb