Benchmark your box

Guest
You can run several instances of this and watch them all crunch.

This is a Linux app BTW. So try it in the Linux Windows now lets
you have too!

So, set a command prompt to as big an x,y size you can get. Then
set the font to a very, very tiny font you can barely see.

Then run this bash script in each prompt. It produces a mandelbrot
using bash script. Pretty cool. Be cool to see one that does use
more precision. But this one is pretty tight for a character based
output! Do not forget to unmunge the lines wrapped by my Usenet
client.

quote:

#!/bin/bash -i
# Draws a mandelbrot set.
# Author: Benjamin Staffin
#
# Simulates floating point by using big integers. Flagrantly uses
two integers
# instead of complex numbers. I couldn't be arsed to calculate
infinity limits
# of logarithmic functions in bash, so this just uses escape time
values for
# colors.
#
# Algorithm reference:
http://en.wikipedia.org/wiki/Mandelbrot_set#For_programmers
# Colors: http://en.wikipedia.org/wiki/ANSI_escape_code#Colors

L=128 # Iteration limit. Even on a 238x61 terminal, 99 is plenty.
P=100000000
Q=$(( P/100 ))
X=$(( Q*320 / ($COLUMNS-1) ))
Y=$(( Q*210 / $LINES ))
y=$(( Q*-105 ))
v=$(( Q*-220 ))
x=$v

# "pixel" 0,0 is the top-left corner of our character grid.

# Outer loop: lines (y values)
while (( y<105*Q )); do

# Inner loop: columns (x values)
while (( x<P )); do
(( a=b=i=c=0 ))
while (( a*a + b*b < 4*P**2 && i++ < L )); do
(( c=a,
a=(a**2 - b**2)/P + x,
b=2*b*c/P + y ))
done

# Color selection via escape values.
# We stop at $L iterations, so this sets the color of the "lake":
if (( i >= L )); then j=0; else (( j=i%16 )); fi

# k controls regular vs bright colors.
if (( j>7 )); then (( k=1, j-= 8 )); else k=0; fi

# ANSI SGR color codes start at 30, hence j+30 here:
printf "\E[$k;$((j+30))m#"

(( x+=X )) # okay, next...
done
printf '\E[0m'

(( x=v, y+=Y )) # On to the next line!
done
 
DecadentLinuxUserNumeroUno@decadence.org wrote in
news:r232nn$13ta$1@gioia.aioe.org:

> You can run several instances of this and watch them all crunch.

Forgot to mention the filename is Mandel.sh or whatever dot sh you
want to name it. It is a bash script file.
This is a Linux app BTW. So try it in the Linux Windows now
lets
you have too!

So, set a command prompt to as big an x,y size you can get.
Then
set the font to a very, very tiny font you can barely see.

Then run this bash script in each prompt. It produces a
mandelbrot
using bash script. Pretty cool. Be cool to see one that does use
more precision. But this one is pretty tight for a character
based output! Do not forget to unmunge the lines wrapped by my
Usenet client.

quote:

#!/bin/bash -i
# Draws a mandelbrot set.
# Author: Benjamin Staffin
#
# Simulates floating point by using big integers. Flagrantly uses
two integers
# instead of complex numbers. I couldn't be arsed to calculate
infinity limits
# of logarithmic functions in bash, so this just uses escape time
values for
# colors.
#
# Algorithm reference:
http://en.wikipedia.org/wiki/Mandelbrot_set#For_programmers
# Colors: http://en.wikipedia.org/wiki/ANSI_escape_code#Colors

L=128 # Iteration limit. Even on a 238x61 terminal, 99 is plenty.
P=100000000
Q=$(( P/100 ))
X=$(( Q*320 / ($COLUMNS-1) ))
Y=$(( Q*210 / $LINES ))
y=$(( Q*-105 ))
v=$(( Q*-220 ))
x=$v

# "pixel" 0,0 is the top-left corner of our character grid.

# Outer loop: lines (y values)
while (( y<105*Q )); do

# Inner loop: columns (x values)
while (( x<P )); do
(( a=b=i=c=0 ))
while (( a*a + b*b < 4*P**2 && i++ < L )); do
(( c=a,
a=(a**2 - b**2)/P + x,
b=2*b*c/P + y ))
done

# Color selection via escape values.
# We stop at $L iterations, so this sets the color of the
"lake": if (( i >= L )); then j=0; else (( j=i%16 )); fi

# k controls regular vs bright colors.
if (( j>7 )); then (( k=1, j-= 8 )); else k=0; fi

# ANSI SGR color codes start at 30, hence j+30 here:
printf "\E[$k;$((j+30))m#"

(( x+=X )) # okay, next...
done
printf '\E[0m'

(( x=v, y+=Y )) # On to the next line!
done
 

Welcome to EDABoard.com

Sponsor

Back
Top