Home > MicroWorlds Logo Links & Examples > MicroWorlds Code Pages > spirals3 Code

Spirals3 Code

spirals3.txt 6 KB


; Purpose: To play with recursion
; Copyright © 2004 by Rupert Russell
; e-mail: rupert.russell1@gmail.com
; URL: http://www.rupert.id.au/microworlds/index.html
; Created: October 14, 2004
;
; Based code from Jeff Fox
; http://el.media.mit.edu/logo-foundation/logo/turtle.html
;
; This program is free software; you can redistribute it and/or modify
; it under the terms of the GNU General Public License as published by
; the Free Software Foundation; either version 2 of the License, or
; (at your option) any later version.
;
; This program is distributed in the hope that it will be useful,
; but WITHOUT ANY WARRANTY; without even the implied warranty of
; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
; GNU General Public License for more details.
;
; You should have received a copy of the GNU General Public License
; along with this program; if not, write to the Free Software
; Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
; --------------------------------------------------------------
;

to startup
   make "last_n 1
end

to go
   setc "black
   st
   cg
   curve 0 0
end

to ++
   ; add 1 to the current setting of the deg slider
   ; if the slider is already at its minimum do nothing

   carefully [set "deg "value deg + 1] [ ]
   cg
   go
end

to --
   ; subtract 1 from the current setting of the deg slider
   ; if the slider is already at its minimum do nothing

   carefully [set "deg "value deg - 1][ ]
   cg
   go
end

to favourites
   ; set the value of the deg slider to a random one of my favourites
   make "n (random 29) + 1

   ; make sure not to repeat the same shape twice in a row
   if :n = :last_n [ifelse :n = 29 [make "n 1][make "n :n + 1]]

   if :n = 1 [set "deg "value 30]
   if :n = 2 [set "deg "value 33]
   if :n = 3 [set "deg "value 36]
   if :n = 4 [set "deg "value 40]
   if :n = 5 [set "deg "value 44]
   if :n = 6 [set "deg "value 45]
   if :n = 7 [set "deg "value 47]
   if :n = 8 [set "deg "value 51]
   if :n = 9 [set "deg "value 55]
   if :n = 10 [set "deg "value 59]
   if :n = 11 [set "deg "value 71]
   if :n = 12 [set "deg "value 75]
   if :n = 13 [set "deg "value 77]
   if :n = 14 [set "deg "value 83]
   if :n = 15 [set "deg "value 89]
   if :n = 16 [set "deg "value 94]
   if :n = 17 [set "deg "value 97]
   if :n = 18 [set "deg "value 98]
   if :n = 19 [set "deg "value 99]
   if :n = 20 [set "deg "value 103]
   if :n = 21 [set "deg "value 117]
   if :n = 22 [set "deg "value 126]
   if :n = 23 [set "deg "value 127]
   if :n = 24 [set "deg "value 136]
   if :n = 25 [set "deg "value 144]
   if :n = 26 [set "deg "value 149]
   if :n = 27 [set "deg "value 162]
   if :n = 28 [set "deg "value 166]
   if :n = 29 [set "deg "value 171]
   if :n = 30 [set "deg "value 179]
   make "last_n :n
   go

end

to curve :size deg
   ; this is the heart of the program
   pd
   ifelse (and ((first pos) < 200 ) ((last pos) < 200) ) [
   fd :size
   rt :deg
   make "size :size + 0.3
   curve :size deg ; recursive call
   ] [pu fd 2 setc "yellow fill ht stop] ; recursive stop
end


APA citation:
Russell, R. (2016, July 04, 04:17 pm). spirals3 code.
     Retrieved January 22, 2025, from http://www.rupert.id.au/microworlds/code/spirals3.php



2882 Visits since October 14, 2004