TweetFollow Us on Twitter

Recursion and Windows
Volume Number:1
Issue Number:11
Column Tag:Lisp Listener

Recursion and Windows

By Andy Cohen, Human Factors Engineer, MacTutor Contributing Editor

MacScheme offers an Alternative

This month I am happy to announce that there is now a third Lisp environment available for the Mac. The first was XLisp (which is now in version 5, which included some quickdraw routines), the second was ExperLisp (see below for the current version number) and the third is called MacScheme from Semantic Micro Systems in Beaverton, Oregon. MacScheme is an implementation of Scheme, which is actually an idealized version of Common Lisp which was proposed by Guy Steele. MacScheme is implemented on the Macintosh in a different way then ExperLisp or XLisp. I will give the details of how it was developed in a more detailed review in the near future. For now though I can say that it will have the capability to manipulate over 20,000 cons cells with just a 512K Mac. I'm also told that a Levco MonsterMac (2 mbyte) using Macscheme can have approximately 120,000 cons cells. In contrast, ExperLisp can only create 5,912 cons cells in a 512K Mac and 30,480 in a MonsterMac. Macscheme however, will not have the bells and whistles that ExperLisp has. There is currently no way in Macscheme to access the Mac's rom toolbox. John Ulrich, one of the developers of Macscheme tells me that in time they eventually will be able to access the toolbox. Macscheme does use the standard Macintosh user-interface. It uses the menu bar and can produce up to four windows. These windows contain things like a compiler, an editor, a debugger (!) and a Listener window. It is supposedly as interactive as ExperLisp. One can compile and evaluate a single line from the Listener window or compile an entire file. There are two more aspects to Macscheme which I feel are almost as significant as it's capacity; cost and copy protection. The cost is extremely low, $125.00 and it is not copy protected. It can easily be put onto a hard disk or a RAM disk for more speed during startup. As soon as I get Macscheme I will give a more detailed review. I hope to include some benchmarks and a better comparison to ExperLisp.

SIMPLE RECURSION

Recursion is one of the most basic control structures in Lisp. To recur is to occur again. A recursive structure or function is one which is essentially iterative in that it is repetitive. Recursive structures or functions are different from iterative procedures in that they call themselves repeatedly in a circular fashion in order to solve a problem. The recursion ends when the solution is computed. For example, suppose one needed to know how fast a printer can print a certain number of pages. Let us assume that we already know it takes .763 minutes per page. We have also just learned that a certain Masters thesis is 72 pages long. Well, we could just simply multiply .763 by 72, however that would not be an example of recursion. Multiplication would be the easy way. Let's try the hard way. What the following will do is add the time per page (.763) to a variable, which I have called timecount, once for each page.

(setq timecount 0)
(defun Printtime (pagenum)
(setq timecount (+ timecount .763)) 
    (cond ((= 1 pagenum) timecount)
    (t (Printtime (sub1 pagenum)))))

(Printtime 72)
;54.936

When the above is compiled, "timecount" is assigned the value zero. When "Printtime" is called the value sent with the call is the number of pages (pagenum). The second line of Printtime reassigns to "timecount" the value of the sum of the previous value of timecount and the number .763. The next line is a conditional which tests the value of pagenum. If pagenum is one, the "=" predicate returns "t", the value of timecount is displayed and the procedure is terminated. If pagenum is not equal to the number one then the equal predicate returns "nil" and the next line is evaluated. The third line forces it's evaluation by virtue of the "t" at the beginning of the list. This list then calls the very same defined function, however the parameter ,"pagenum" is decremented by one. This continues until pagenum equals zero. The time it took the printer to print the given number of pages is then displayed. In the case of 72 pages it took 54.936 minutes (it was probably high quality!).

Sometimes it requires more than one function to solve a problem. Two-part recursion is when one function calls a second and the second function does all the work. Since we actually need to have the variable "timecount" set to zero every time we use the function it can be more efficiently implemented in terms of our Lisp environment as a two-part recursive function.

(defun setup (n)
   (setq timecount 0)
   (Printtime n))

(defun Printtime (pagenum)
    (setq timecount (+ timecount .763)) 
    (cond ((zerop pagenum) timecount)
    (t (Printtime (sub1 pagenum)))))

(setup 72)
; 54.936
(setup 90)
;68.67 
(setup 12)
;9.156 
(setup 32)
;24.416 

Given the above, one can now solve the problem without having to compile the entire source listing everytime. Using "setup" which calls "Printtime" the variable timecount is initiated without recompiling. Note that the value represented by variable "n" is passed to Printtime which then assigns it to "pagenum". If one was to call Printtime after compiling and running the above, the last number assigned to timecount will still be assigned. Therefore, the number returned is the total of the last total time plus the number of pages given when Printtime was called by itself. Recursion is an important feature of Lisp. The above was a very simple example. In next month's column I'll discuss more complicated recursive functions.

Windows!

Yes, ExperLisp does do windows. After months of saying that I'll show how, I've finally got around to doing it. As you might already know from previous months, one may generate a window by simply accessing either the Bunny or Quickdraw graphics routines available in ExperLisp. In this case the window is the standard graphics window or "Std_graf" to ExperLisp. "Std_graf" is the term used by ExperLisp in referring to a window. One may associate a "Std_graf" with their own window by assigning the special term "newgraphwindow" and a list containing a set of coordinates (which correspond to the top left and bottom right corners of the window) to the chosen term which identifies the window. For my example the term I have chosen is "Win1". After this assignment is made one must then assign the name "Win1" to the special term "Std_graf". To assign a title to the window which will be displayed on top of the window the special term "setwtitle" is used. My sample follows:

(setq Win1 (newgrafwindow '(90 115 290 335))
           std_graf Win1))
 (Win1 'setwtitle "My First Window")

The above will generate a window which does not contain scroll bars or an expand corner. Expanding the window or shrinking it however, is possible by placing the mouse on the lower right corner and dragging it to the desired size. One might note that after running the above, the window is covered up by the Listener Window. It has to be selected before it can be changed or moved. This is because when there is no other functions operating the Listener Window becomes the active window. In order to keep the programmed window active one must be within a procedure which selected it or a procedure which is called by a previous procedure which selected the window. Figure 1 is a screen dump of what the window looks like on the ExperLisp desktop. The screen dump also contains the output generated within the Listener window as a result of the window creation. Windows can also be selected via quickdraw routines. For example:

(FILLOVAL '(34 67 89 90) dkgrey Win1)

The window is selected by including the window title at the end of the quickdraw routine. The window can be deleted by using the following:

(CLOSEWINDOW)

One can size a window using the following:

(SIZEWINDOW width height)

One can also HIDEWINDOW, SHOWWINDOW, MOVEWINDOW x y, or SENDBEHIND window. All of the window primitives are as easy to use as those sampled above.

Putting It All Together

Now lets' put all that has been discussed over the last couple of months together into a simple bunch of procedures which will allow the user to draw a black rectangle with the mouse into the window generated by the code described above.

(defun Watch ()
 (Win1 'selectwindow) 
   (prog ()
     look
      (if (button) (Mousey (REVERSE (getmouse))))
       (go look)))

(defun Mousey (x) 
      (prog ()
     try
         (setq inputs (append x (REVERSE(getmouse))))
          (framerect inputs)
          (eraserect inputs)
          (if (not(button)) (halt x) (go try))))

(defun halt (x)
   (paintrect (append x (REVERSE (getmouse)))))

(Watch)

The overall structure of the above is the same as that used with the procedures presented last month which printed the mouse location. When "Watch" is called, the window "Win1" is selected and brought to the front. The procedure "Watch" also scans the mouse awaiting a button press. When the button on the mouse is pressed the X-Yvalues of the mouse position are reversed (to correspond to the top-left of the quickdraw syntax) and sent in a list as a parameter to the procedure "Mousey". Mousey appends together a list made up of the passed parameter "x" and a second (REVERSE (GETMOUSE)). This list is assigned to the symbol "inputs", which is then used in the FRAMERECT. The FRAMERECT is immediately erased using ERASERECT to give the outline effect prior to releasing the button and selecting the rectangle size. When the button is released the procedure "Halt" is called with the exact same value passed to it as the value passed to "Mousey". It is still the top, left hand corner of our rectangle. In "Halt" the rectangle is finally drawn using the latest mouse position for the bottom, right hand corner.

When compiling these routines one should see each function name printed in the Listener Window as the function is compiled. If the name does not appear and the "I" beam cursor reappears, there is a typo. Chances are it is a problem with the parentheses. If the names show up but the functions are not initiated, chances are a parenthesis was left out somewhere. The above should work fine. One of the biggest disadvantages in using ExperLisp at this time is the poor error messages given when the programmer has done something wrong. I find that most of my errors are in leaving out a parenthesis or putting too many in. Parentheses matching is a capability inherent in an editor which gives some indication to the programmer as to which parenthesis goes with another. Some Lisp machines actually put the parenthesis in for the programmer automatically. In version 1.04 of ExperLisp we will be given the luxury of parenthesis matching. Version 1.04 should be released by the time this column is in print. This new version of ExperLisp will handle parenthesis matching by highlighting the opening parenthesis of the matching closing parenthesis to the left of the entry point. By placing the entry point next to each closing parenthesis the programmer can check to see that all the lists are closed properly. Believe me, after just two minutes of use you will never want to be without parenthesis matching again! Another helpful feature of version 1.04 is a form of trace capability. In the beta version this capability was initiated within the ªlispINIT file. When certain kinds of errors are encountered the same kind of message is generated as was in the earlier versions, however with this form of trace on the message is followed by each list that was invoked and the order of occurrence. These are generated in the Listener window. There is a drawback to this feature though, the listing can get quite long for even a small program. The best way to debug at this time is still to break the code down into small functions.

ExperLisp Versions

There are currently four versions of ExperLisp. Version 1.01 was the first release. The first update was version 1.02, in which some of the routines were fixed (i.e. MAPCAR and nested CARs and CDRs, etc.) and some routines added (i.e. FREECONS). Version 1.03 is a version of ExperLisp which was included with ExperOps5. Registered owners of both ExperLisp and ExperOps5 should receive version 1.04. There are many differences between each of these versions. To see what routines and functions are available within a version of ExperLisp type the following in the Listener window:

(APROPOS "")

The function names will then be generated within the Listener window. Good luck, the list is long.

The Experts Complain

Recently a letter was received by Mactutor which criticized the accuracy and reliability of this column. I would like to say that I am NOT a Lisp programmer. That is probably obviously apparent to one who is. The goal of this article is to be more then just a tutorial, it is to demonstate the findings of one who is learning Lisp ON THE MAC with only minor consulting from the experts. If you feel something is incorrect, then by all means write to Mactutor with your comments. We welcome suggestions for topics of interest to our readership. Let us know how we can meet your needs.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Hopper Disassembler 4.2.5- - Binary disa...
Hopper Disassembler is a binary disassembler, decompiler, and debugger for 32-bit and 64-bit executables. It will let you disassemble any binary you want, and provide you all the information about... Read more
BetterTouchTool 2.261 - Customize Multi-...
BetterTouchTool adds many new, fully customizable gestures to the Magic Mouse, Multi-Touch MacBook trackpad, and Magic Trackpad. These gestures are customizable: Magic Mouse: Pinch in / out (zoom... Read more
Sketch 44.1 - Design app for UX/UI for i...
Sketch is an innovative and fresh look at vector drawing. Its intentionally minimalist design is based upon a drawing space of unlimited size and layers, free of palettes, panels, menus, windows, and... Read more
BetterTouchTool 2.260 - Customize Multi-...
BetterTouchTool adds many new, fully customizable gestures to the Magic Mouse, Multi-Touch MacBook trackpad, and Magic Trackpad. These gestures are customizable: Magic Mouse: Pinch in / out (zoom... Read more
Chromium 59.0.3071.115 - Fast and stable...
Chromium is an open-source browser project that aims to build a safer, faster, and more stable way for all Internet users to experience the web. Version 59.0.3071.115: This update has no Flash plug... Read more
SyncTwoFolders 2.2.3 - Syncs two user-sp...
SyncTwoFolders simply synchronizes two folders. It supports synchronization across mounted network drives and it is a possibility to run a simulation showing in a log what will be done. Please visit... Read more
Myriad 4.1 - $79.00
Myriad is, simply put, one of the best audio batch processors. Totally redesigned, it looks beautiful and delivers incredible performance. Let Myriad do the heavy lifting while you get back to doing... Read more
Suitcase Fusion 7 18.2.4 - Font manageme...
Suitcase Fusion 7 is the creative professional's font manager. Every professional font manager should deliver the basics: spectacular previews, powerful search tools, and efficient font organization... Read more
SoftRAID 5.6.1 - High-quality RAID manag...
SoftRAID allows you to create and manage disk arrays to increase performance and reliability. SoftRAID allows the user to create and manage RAID 4 and 5 volumes, RAID 1+0, and RAID 1 (Mirror) and... Read more
BetterTouchTool 2.25 - Customize Multi-T...
BetterTouchTool adds many new, fully customizable gestures to the Magic Mouse, Multi-Touch MacBook trackpad, and Magic Trackpad. These gestures are customizable: Magic Mouse: Pinch in / out (zoom... Read more

Latest Forum Discussions

See All

Missile Cards (Games)
Missile Cards 1.0.9 Device: iOS Universal Category: Games Price: $2.99, Version: 1.0.9 (iTunes) Description: "Missile Command meets Solitaire...only with more doomlasers, death, and explosions." | Read more »
Collect mini assassins in 'Assassin...
Assassin's Creed is traveling back in time to the Spanish Inquisition for its latest mobile entry, Assassin's Creed Rebellion. The game is giving the series a look that's a huge departure from its past design, recreating classic characters in a... | Read more »
Animal Crossing is still coming to mobil...
Animal Crossing is still coming to mobile in 2017, according to aWaypointinterview with Nintendo. Announced in 2016, the game was delayed without a defined release window. However, fans of Nintendo's fantasy slice of life game won't have to wait... | Read more »
Ravenscroft 275 Piano (Music)
Ravenscroft 275 Piano 1.0.0 Device: iOS Universal Category: Music Price: $35.99, Version: 1.0.0 (iTunes) Description: Experience the splendor of a Ravenscroft Grand with the most realistic sounding piano ever created for iOS. Launch... | Read more »
This War of Mine gets a new ending and m...
This War of Mine just got a big new update, featuring free DLC that adds a new ending to the game, among other exciting changes. The update is celebrating the game's two-year release anniversary. Apart from the new ending, which will be quite... | Read more »
Summon eight new heroes in Fire Emblem H...
Nintendo keeps coming at us with Fire Emblem Heroes updates, and it doesn't look like that trend is stopping anytime soon. The folks behind the game have just announced the new War of the Clerics Voting Gauntlet, expected to start next Tuesday. [... | Read more »
The best deals on the App Store this wee...
iOS publishers are pulling out all the stops this week -- there's a huge number of seriously great games at discounted prices this week. Let's not waste any time and get right down to business. [Read more] | Read more »
The House of da Vinci (Games)
The House of da Vinci 1.0.0 Device: iOS Universal Category: Games Price: $4.99, Version: 1.0.0 (iTunes) Description: Enter The House of Da Vinci, a new must-try 3D puzzle adventure game. Solve mechanical puzzles, discover hidden... | Read more »
Solve the disappearance of history’s gre...
Blue Brain Games invites you to indulge in an immersive hands-on 3D puzzle adventure in similar vein to The Room series, with its debut release The House of Da Vinci. Set during the historic period of the Italian Renaissance (when Leonardo himself... | Read more »
Age of Rivals (Games)
Age of Rivals 3.3 Device: iOS Universal Category: Games Price: $.99, Version: 3.3 (iTunes) Description: Deep civilization-building strategy in a fast-paced card game! | Read more »

Price Scanner via MacPrices.net

Apple Releases iOS 11 Public Beta; How To Get...
The official release of Apple’s latest mobile operating system iOS 11 is vaguely slated for the fall, but as of June 26, ordinary users can download an iOS 11 public beta. To download the iOS 11... Read more
Extend Life of MacBook Pro Retina 2.0TB With...
MacSales.com/Other World Computing has announced availability of the new OWC 2.0TB Aura Pro Solid State Drive for mid-2012 to early 2013 Apple MacBook Pro with Retina display. One of the fastest... Read more
BBEdit SummerFest 2017 Discount Ends Friday,...
You can get 20% off BBEdit for a limited time in Bare Bones Software’s http://www.eastgate.com/Tinderbox/Specials/SummerFest.html?mc_cid=f2101ca260&mc_eid=[UNIQID]SummerFest 2017 sale and... Read more
Use Apple’s Education discount to save up to...
Purchase a new Mac using Apple’s Education discount, and take up to $300 off MSRP. All teachers, students, and staff of any educational institution qualify for the discount. Shipping is free: - 15″ 2... Read more
Clearance 27-inch 3.3GHz 5K iMac available fo...
Amazon clearance 27″ 3.3GHz 5K iMacs (MK482LL/A) available for $1799.90 including free shipping. Their price is $500 off original MSRP, and it’s the lowest price available for this model from any... Read more
13-inch 1.8GHz/256GB MacBook Air on sale for...
B&H Photo has the updated 2017 13″ 1.8GHz/256GB MacBook Air (MQD42LL/A) in stock and on sale for $1129 including free shipping plus NY & NJ tax only. Their price is $70 off MSRP. Read more
27-inch 3.4GHz iMac on sale for $1699, save $...
B&H Photo has the new 2017 27″ 3.4GHz iMac (MNE92LL/A) in stock and on sale for $1699 including free shipping plus NY & NJ sales tax only. Their price is $100 off MSRP. Read more
21-inch 2.3GHz iMac on sale for $1049, save $...
B&H Photo has the new 2017 21″ 2.3GHz iMac (MMQA2LL/A) in stock and on sale for $1049 including free shipping plus NY & NJ tax only. Their price is $50 off MSRP. Read more
ABBYY TextGrabber 6 for iOS Implements Instan...
ABBYY has announced the release of TextGrabber 6.0.0, an important feature update to the company’s productivity app developed for iOS and Android devices. TextGrabber 6.0 now offers Real-Time... Read more
vPhone, First Smartphone That Can’t Be Lost,...
Austin, Texas based Hypori has introduced the vPhone, a virtual smartphone that affords every business user the benefits of separate work and personal phones, conveniently delivered on a single... Read more

Jobs Board

*Apple* News Product Marketing Mgr., Publish...
…organizational consensus on strategy and vision for publisher tools, authoring, and Apple News Format.Carries this strategy and vision across the organization to Read more
*Apple* Retail - Multiple Positions - Apple,...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
Security Data Analyst - *Apple* Information...
…data sources need to be collected to allow Information Security to better protect Apple employees and customers from a wide range of threats.Act as the subject matter Read more
Lead *Apple* Solutions Consultant - Apple I...
…integrity, and trust.Success Metrics/Key Performance Indicators:Quantitative* Year over Year growth in Apple Product and Beyond the Box sales in the assigned Point of Read more
*Apple* Solutions Consultant till v%u00E5r...
…ethics, integrity, and trust.Success Metrics/Key Performance Indicators:QuantitativeYear over Year growth in Apple Product and Beyond the Box sales in the assigned Point Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.