[Shootout-list] Ruby Mandelbrot

Karl von Laudermann karlvonl@rcn.com
Thu, 24 Mar 2005 00:17:57 -0500


Here's my Ruby implementation of the Mandelbrot test. Enjoy.


#!/usr/bin/env ruby
#  The Great Computer Language Shootout
#  http://shootout.alioth.debian.org/
#
#  contributed by Karl von Laudermann
#
#  mandelbrot.rb 400 > out.pbm

size = ARGV[0].to_i

puts "P4\n#{size} #{size}"

iter = 50
limit = 2.0
byte_acc = 0
bit_num = 0

size.times do |y|
     size.times do |x|
         zr = 0.0
         zi = 0.0
         cr = (2.0*x/size)-1.5
         ci = (2.0*y/size)-1.0
         escape = false

         iter.times do
            tr = zr*zr - zi*zi + cr
            ti = 2*zr*zi + ci
            zr, zi = tr, ti

            if (zr*zr+zi*zi) > (limit*limit)
                escape = true
                break
            end
         end

         byte_acc = (byte_acc << 1) | (escape ? 0b0 : 0b1)
         bit_num += 1

         if (bit_num == 8) || (x == size - 1)
             byte_acc <<= (8 - bit_num)
             print byte_acc.chr
             byte_acc = 0
             bit_num = 0
         end
     end
end


-- 
				Karl J. von Laudermann
				karlvonl@rcn.com
				http://www.geocities.com/~karlvonl/
				Richard's PBeM Server ID: karlvonl