<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Kalimat al-Mutafalsif &#187; Scheme</title>
	<atom:link href="http://thesnarky.com/category/interests/programming/scheme/feed/" rel="self" type="application/rss+xml" />
	<link>http://thesnarky.com</link>
	<description>The Words of the One Who Calls Himself a Philosopher</description>
	<lastBuildDate>Tue, 26 Oct 2010 22:57:56 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Ray Casting in Scheme</title>
		<link>http://thesnarky.com/2010/02/23/ray-casting-in-scheme/</link>
		<comments>http://thesnarky.com/2010/02/23/ray-casting-in-scheme/#comments</comments>
		<pubDate>Wed, 24 Feb 2010 04:50:26 +0000</pubDate>
		<dc:creator>Snarky</dc:creator>
				<category><![CDATA[Games]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Scheme]]></category>

		<guid isPermaLink="false">http://thesnarky.com/?p=424</guid>
		<description><![CDATA[My last post was about getting started picking up Scheme again for use in the 7 Day Roguelike contest. Of note I mentioned that I had decided on using Gambit as I could nicely tie Scheme and C libraries together, which I wanted so that I could use ncurses to do all my terminal control [...]]]></description>
			<content:encoded><![CDATA[<p>My<a href="http://thesnarky.com/2010/02/23/library-7drl-import-rnrs/"> last post</a> was about getting started picking up Scheme again for use in the <a href="http://groups.google.com/group/rec.games.roguelike.development/browse_thread/thread/96fae2f059d0b2b2/88349386000aaa8b?lnk=raot">7 Day Roguelike contest</a>. Of note I mentioned that I had decided on using <a href="http://dynamo.iro.umontreal.ca/~gambit/wiki/index.php/Main_Page">Gambit</a> as I could nicely tie Scheme and C libraries together, which I wanted so that I could use <a href="http://en.wikipedia.org/wiki/Ncurses">ncurses</a> to do all my terminal control (output and reading user input). </p>
<p>I got ncurses working, and managed to get a simple little walk around demo going. However I wanted something a bit deeper than just having the entire map visible from the start, so I poked back at some test code <a href="http://push.cx/">Harkins</a> wrote last year for Ruby (when I had aspirations of learning another language), and read up on <a href="http://http://roguebasin.roguelikedevelopment.org/index.php?title=Main_Page">Rogue Basin</a> for various examples. In the end I stole Harkin's map, and went with the pseudo code Elig created <a href="http://roguebasin.roguelikedevelopment.org/index.php?title=Eligloscode">here</a>.</p>
<p>Without further ado, the code busted apart into a few sections. (Full version can be found <a href="http://pastebin.com/WBDsz8Re">here</a>).</p>
<pre class="scheme">&nbsp;
<span style="color: #808080; font-style: italic;">;;Scheme ray casting/FOV demo</span>
<span style="color: #808080; font-style: italic;">;;Adapted from pseudo code found at</span>
<span style="color: #808080; font-style: italic;">;;http://roguebasin.roguelikedevelopment.org/index.php?title=Eligloscode</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Prep work for 7DLR 2010 (to brush back up on my Scheme)</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Global defines</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> char-x <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;x coordinate for the fake character</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> char-y <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;y coordinate for the fake character</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> VIEW-RADIUS <span style="color: #cc66cc;">3</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;View radius for FOV demo</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;List of tiles we don't want to walk through (Walls and water)</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> IMPASSABLE-TILES <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">list</span> #\# #\~<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
<span style="color: #808080; font-style: italic;">;;List of tiles that will break the ray casting (walls)</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> OPAQUE-TILES <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">list</span> #\#<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> 
&nbsp;
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> test-env <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">list</span>
                    <span style="color: #ff0000;">&quot;###################&quot;</span>
                    <span style="color: #ff0000;">&quot;#...#.............#&quot;</span>
                    <span style="color: #ff0000;">&quot;#...#...#~~~~~....#&quot;</span>
                    <span style="color: #ff0000;">&quot;#.......#~~~~~....#&quot;</span>
                    <span style="color: #ff0000;">&quot;###################&quot;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;</pre>
<p>First I set up some variables to work with.</p>
<pre class="scheme">&nbsp;
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;</span>
<span style="color: #808080; font-style: italic;">;;Functions to create the environment;;</span>
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to create our working environment given an array of strings such as test-env</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> create-env
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">null?</span> env<span style="color: #66cc66;">&#41;</span>
            '<span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cons</span> <span style="color: #66cc66;">&#40;</span>create-env-row <span style="color: #66cc66;">&#40;</span>string-&gt;list <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>create-env <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cdr</span> env<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function that helps create-env by creating a given row</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> create-env-row
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env-row<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">null?</span> env-row<span style="color: #66cc66;">&#41;</span>
            '<span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cons</span> <span style="color: #66cc66;">&#40;</span>create-env-cell <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env-row<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>create-env-row <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cdr</span> env-row<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to create a given env cell, helps create-env-row</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> create-env-cell
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env-cell<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">list</span> env-cell #f<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;</pre>
<p>Next I define some functions to get a map (which is really a list of strings) to something we can work with (nested lists that act like a two dimensional array).</p>
<pre class="scheme">&nbsp;
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;</span>
<span style="color: #808080; font-style: italic;">;;Functions to display the environment;;</span>
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to write the env</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> write-env
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>write-env-help env <span style="color: #cc66cc;">0</span> <span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function that does the brunt of the env write</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> write-env-help
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env x y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">null?</span> env<span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">newline</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">begin</span>
                <span style="color: #66cc66;">&#40;</span>write-env-row <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env<span style="color: #66cc66;">&#41;</span> x y<span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span>write-env-help <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cdr</span> env<span style="color: #66cc66;">&#41;</span> x <span style="color: #66cc66;">&#40;</span>+ y <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function that writes a given row of the env</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> write-env-row
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env-row x y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">null?</span> env-row<span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">newline</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">begin</span>
                <span style="color: #66cc66;">&#40;</span>write-env-cell <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env-row<span style="color: #66cc66;">&#41;</span> x y<span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span>write-env-row <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cdr</span> env-row<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>+ x <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span> y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function that writes out a given cell of the env</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> write-env-cell
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env-cell x y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>char <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env-cell<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;The symbol we'll possibly display</span>
              <span style="color: #808080; font-style: italic;">;;The boolean bit of the env cell that holds if its visible or not</span>
              <span style="color: #66cc66;">&#40;</span>visible <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cadr</span> env-cell<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> visible <span style="color: #808080; font-style: italic;">;;If this cell was marked to be seen</span>
                <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">and</span> <span style="color: #66cc66;">&#40;</span>= x char-x<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>= y char-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;Check if its where the character is</span>
                    <span style="color: #66cc66;">&#40;</span>print <span style="color: #ff0000;">&quot;@&quot;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;If so, lets show an @ symbol</span>
                    <span style="color: #66cc66;">&#40;</span>print char<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;Else show whatever character should be displayed</span>
                <span style="color: #66cc66;">&#40;</span>print <span style="color: #ff0000;">&quot; &quot;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;If this cell wasn't marked to be shown, just put a space</span>
            <span style="color: #66cc66;">&#40;</span>print <span style="color: #ff0000;">&quot; &quot;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;Put a space after it for pretty printing</span>
&nbsp;</pre>
<p>Naturally you need some way to nicely see what's going on in your environment. That's what these functions do.</p>
<pre class="scheme">&nbsp;
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;</span>
<span style="color: #808080; font-style: italic;">;;Functions for the FOV demo;;</span>
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to update the FOV as a whole</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> update-fov
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env char-x char-y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>update-fov-help env char-x char-y <span style="color: #cc66cc;">0</span> <span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function that does the actual work of updating the FOV</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> update-fov-help
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env char-x char-y x y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">null?</span> env<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">begin</span>
                <span style="color: #66cc66;">&#40;</span>update-fov-row <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env<span style="color: #66cc66;">&#41;</span> char-x char-y x y<span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span>update-fov-help <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cdr</span> env<span style="color: #66cc66;">&#41;</span> char-x char-y x <span style="color: #66cc66;">&#40;</span>+ y <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function that updates the FOV for a given row</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> update-fov-row
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env-row char-x char-y x y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">null?</span> env-row<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">begin</span>
                <span style="color: #66cc66;">&#40;</span>update-fov-cell <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env-row<span style="color: #66cc66;">&#41;</span> char-x char-y x y<span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span>update-fov-row <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cdr</span> env-row<span style="color: #66cc66;">&#41;</span> char-x char-y <span style="color: #66cc66;">&#40;</span>+ x <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span> y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function that does the real work to update a given cell's FOV</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> update-fov-cell
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env-cell char-x char-y x y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>set-cell-visible env-cell #f<span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;Set visible to false</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span>* <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>dx <span style="color: #66cc66;">&#40;</span>- x char-x<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
               <span style="color: #66cc66;">&#40;</span>dy <span style="color: #66cc66;">&#40;</span>- y char-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
               <span style="color: #808080; font-style: italic;">;;Get the distance between the character and the cell</span>
               <span style="color: #66cc66;">&#40;</span>distance <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">sqrt</span> <span style="color: #66cc66;">&#40;</span>+ <span style="color: #66cc66;">&#40;</span>* dx dx<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>* dy dy<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span>&lt; distance VIEW-RADIUS<span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;If we're within out viewing radius</span>
                <span style="color: #66cc66;">&#40;</span>set-cell-visible env-cell #t<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;set the cell to be shown</span>
&nbsp;</pre>
<p>Finally we get to the good stuff. This code is for the Field of View demo, which just shows everything within the sight radius. What it does, basically, is loops through every cell on the map, sets it to invisible (aka sets the cdr of the env-cell to be #f), and then checks to see how far from the player it is. If its within our view-radius, it then flips the visibility to true. Slow for big maps, but simple to implement.</p>
<pre class="scheme">&nbsp;
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;</span>
<span style="color: #808080; font-style: italic;">;;Function for the Ray casting demo;;</span>
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to clear the entire env</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> clear-cells
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">null?</span> env<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">begin</span>
                <span style="color: #66cc66;">&#40;</span>clear-cells-row <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span>clear-cells <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cdr</span> env<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function that clears a row of the env</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> clear-cells-row
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env-row<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">null?</span> env-row<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">begin</span>
                <span style="color: #66cc66;">&#40;</span>clear-cells-cell <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env-row<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span>clear-cells-row <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cdr</span> env-row<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to clear a cell in the env</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> clear-cells-cell
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env-cell<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>set-cell-visible env-cell #f<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to do the ray-cast</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> cast-rays
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env char-x char-y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>clear-cells env<span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;Clear everything first</span>
        <span style="color: #66cc66;">&#40;</span>cast-rays-help env char-x char-y <span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to do the real work of casting some rays</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> cast-rays-help
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env char-x char-y i<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span>&lt;= i <span style="color: #cc66cc;">360</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>x <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cos</span> <span style="color: #66cc66;">&#40;</span>* i <span style="color: #cc66cc;">0.01745</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                  <span style="color: #66cc66;">&#40;</span>y <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">sin</span> <span style="color: #66cc66;">&#40;</span>* i <span style="color: #cc66cc;">0.01745</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                  <span style="color: #66cc66;">&#40;</span>trace-ray env char-x char-y x y <span style="color: #66cc66;">&#40;</span>+ char-x .<span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>+ char-y .<span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#41;</span> <span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#41;</span>
                  <span style="color: #66cc66;">&#40;</span>cast-rays-help env char-x char-y <span style="color: #66cc66;">&#40;</span>+ i <span style="color: #cc66cc;">16</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to trace the specific ray to its end</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> trace-ray
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env char-x char-y x y dx dy i<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span>&gt; i VIEW-RADIUS<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span>* <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>cell-x <span style="color: #66cc66;">&#40;</span>round dx<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                   <span style="color: #66cc66;">&#40;</span>cell-y <span style="color: #66cc66;">&#40;</span>round dy<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                   <span style="color: #66cc66;">&#40;</span>cell <span style="color: #66cc66;">&#40;</span>get-cell env cell-x cell-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> cell
                    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">begin</span>
                        <span style="color: #66cc66;">&#40;</span>set-cell-visible cell #t<span style="color: #66cc66;">&#41;</span>
                        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span>cell-opaque? cell<span style="color: #66cc66;">&#41;</span>
                            <span style="color: #66cc66;">&#40;</span>trace-ray env char-x char-y x y <span style="color: #66cc66;">&#40;</span>+ dx x<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>+ dy y<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>+ i <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;</pre>
<p>The first three functions simply clear all the cells on the map. Unlike FOV our work functions aren't visiting every cell (we hope) and so we have to go through ahead of time and clear them out.</p>
<p>The rest of the functions do the ray casting. Starting at the character's position, it draws a line (trace-ray) out in a given direction. If it gets either past the view radius, or to a cell considered opaque, it doesn't recur. Otherwise it calls itself and continues stepping out. Trace-ray is called once per every 16 degrees around the circle. Its not entirely accurate, but its a lot faster than using 1 as the increment and drawing 360 rays. </p>
<pre class="scheme">&nbsp;
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;;;;;;;;;;;;;;;</span>
<span style="color: #808080; font-style: italic;">;;Random helper functions;;</span>
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;;;;;;;;;;;;;;;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to get a given cell</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> get-cell
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env x y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>get-cell-help env x y <span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function does most of the real work to get a given cell</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> get-cell-help
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env new-x new-y y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">null?</span> env<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span>= y new-y<span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span>get-cell-x <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env<span style="color: #66cc66;">&#41;</span> new-x new-y <span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span>get-cell-help <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cdr</span> env<span style="color: #66cc66;">&#41;</span> new-x new-y <span style="color: #66cc66;">&#40;</span>+ y <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            #f<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Final helper to get a given cell</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> get-cell-x
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env-row new-x new-y x<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">null?</span> env-row<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span>= x new-x<span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> env-row<span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span>get-cell-x <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">cdr</span> env-row<span style="color: #66cc66;">&#41;</span> new-x new-y <span style="color: #66cc66;">&#40;</span>+ x <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            #f<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to tell if a cell is passable</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> cell-passable?
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>cell<span style="color: #66cc66;">&#41;</span>
         <span style="color: #808080; font-style: italic;">;;Check to see if symbol is in our list of impassable tiles</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">member</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> cell<span style="color: #66cc66;">&#41;</span> IMPASSABLE-TILES<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> 
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to tell if a cell is opaque</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> cell-opaque?
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>cell<span style="color: #66cc66;">&#41;</span>
        <span style="color: #808080; font-style: italic;">;;Check to see if symbol is in our list of opaque tiles</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">member</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">car</span> cell<span style="color: #66cc66;">&#41;</span> OPAQUE-TILES<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> 
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to 'move' our 'character' to another cell</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> move-to
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env x y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span>cell-passable? <span style="color: #66cc66;">&#40;</span>get-cell env x y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;Check to make sure they can move there</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">begin</span>
                <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">set!</span> char-x x<span style="color: #66cc66;">&#41;</span> <span style="color: #808080; font-style: italic;">;;'Move' them by changing our global vars</span>
                <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">set!</span> char-y y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Function to set a given cell's visibility to the given boolean</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> set-cell-visible
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>cell bool<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>set-<span style="color: #b1b100;">cdr</span>! cell <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">list</span> bool<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;</pre>
<p>These functions simply help the above code look prettier. The first make the environment which is really just a list (in true Scheme form) behave more like a two dimensional array. Cell-passable? and opaque? check to see if a cell can be traveled into or seen through. Move-to moves the character, and set-cell-visible helps quickly toggle a cell's visibility.</p>
<pre class="scheme">&nbsp;
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;</span>
<span style="color: #808080; font-style: italic;">;;Test code;;</span>
<span style="color: #808080; font-style: italic;">;;;;;;;;;;;;;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Setup the environment</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> our-env <span style="color: #66cc66;">&#40;</span>create-env test-env<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Run the fov-demo</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> fov-demo
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>print <span style="color: #ff0000;">&quot;FOV demo, use h, j, k, and l to move, q to quit<span style="color: #000099; font-weight: bold;">\n</span>&quot;</span><span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>update-fov our-env char-x char-y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>write-env our-env<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> read-loop <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>x <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">read-char</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">or</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">char=?</span> x #\q<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">char=?</span> x #\<span style="color: #b1b100;">newline</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">begin</span>
                    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">case</span> x
                        <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\<span style="color: #b1b100;">l</span><span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>new-x <span style="color: #66cc66;">&#40;</span>+ char-x <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                     <span style="color: #66cc66;">&#40;</span>new-y char-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                    <span style="color: #66cc66;">&#40;</span>move-to our-env new-x new-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span>
                        <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\k<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>new-x char-x<span style="color: #66cc66;">&#41;</span>
                                     <span style="color: #66cc66;">&#40;</span>new-y <span style="color: #66cc66;">&#40;</span>- char-y <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                    <span style="color: #66cc66;">&#40;</span>move-to our-env new-x new-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span>
                        <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\j<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>new-x char-x<span style="color: #66cc66;">&#41;</span>
                                     <span style="color: #66cc66;">&#40;</span>new-y <span style="color: #66cc66;">&#40;</span>+ char-y <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                    <span style="color: #66cc66;">&#40;</span>move-to our-env new-x new-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span>
                        <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\h<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>new-x <span style="color: #66cc66;">&#40;</span>- char-x <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                     <span style="color: #66cc66;">&#40;</span>new-y char-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                    <span style="color: #66cc66;">&#40;</span>move-to our-env new-x new-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span><span style="color: #66cc66;">&#41;</span>
                    <span style="color: #66cc66;">&#40;</span>update-fov our-env char-x char-y<span style="color: #66cc66;">&#41;</span>
                    <span style="color: #66cc66;">&#40;</span>write-env our-env<span style="color: #66cc66;">&#41;</span>
                    <span style="color: #66cc66;">&#40;</span>read-loop <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">read-char</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">case</span> x
                    <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\q<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>print <span style="color: #ff0000;">&quot;--End of FOV Demo--<span style="color: #000099; font-weight: bold;">\n</span>&quot;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span>
                    <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\<span style="color: #b1b100;">newline</span><span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>read-loop <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">read-char</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Run the ray-casting-demo</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> ray-casting-demo
    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span>env<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>print <span style="color: #ff0000;">&quot;Ray casting demo, use h, j, k, and l to move, q to quit<span style="color: #000099; font-weight: bold;">\n</span>&quot;</span><span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>cast-rays our-env char-x char-y<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span>write-env our-env<span style="color: #66cc66;">&#41;</span>
        <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> read-loop <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>x <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">read-char</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
            <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">not</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">or</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">char=?</span> x #\q<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">char=?</span> x #\<span style="color: #b1b100;">newline</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">begin</span>
                    <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">case</span> x
                        <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\<span style="color: #b1b100;">l</span><span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>new-x <span style="color: #66cc66;">&#40;</span>+ char-x <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                     <span style="color: #66cc66;">&#40;</span>new-y char-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                    <span style="color: #66cc66;">&#40;</span>move-to our-env new-x new-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span>
                        <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\k<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>new-x char-x<span style="color: #66cc66;">&#41;</span>
                                     <span style="color: #66cc66;">&#40;</span>new-y <span style="color: #66cc66;">&#40;</span>- char-y <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                    <span style="color: #66cc66;">&#40;</span>move-to our-env new-x new-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span>
                        <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\j<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>new-x char-x<span style="color: #66cc66;">&#41;</span>
                                     <span style="color: #66cc66;">&#40;</span>new-y <span style="color: #66cc66;">&#40;</span>+ char-y <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                    <span style="color: #66cc66;">&#40;</span>move-to our-env new-x new-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span>
                        <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\h<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">let</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>new-x <span style="color: #66cc66;">&#40;</span>- char-x <span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                     <span style="color: #66cc66;">&#40;</span>new-y char-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                                    <span style="color: #66cc66;">&#40;</span>move-to our-env new-x new-y<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span><span style="color: #66cc66;">&#41;</span>
                    <span style="color: #66cc66;">&#40;</span>cast-rays our-env char-x char-y<span style="color: #66cc66;">&#41;</span>
                    <span style="color: #66cc66;">&#40;</span>write-env our-env<span style="color: #66cc66;">&#41;</span>
                    <span style="color: #66cc66;">&#40;</span>read-loop <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">read-char</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
                <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">case</span> x <span style="color: #808080; font-style: italic;">;;Enter or q was pressed</span>
                    <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\q<span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>print <span style="color: #ff0000;">&quot;--End of Ray casting demo--<span style="color: #000099; font-weight: bold;">\n</span>&quot;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span> <span style="color: #808080; font-style: italic;">;;If q, lets quit</span>
                    <span style="color: #808080; font-style: italic;">;;If enter just read the next char, it happens</span>
                    <span style="color: #66cc66;">&#91;</span><span style="color: #66cc66;">&#40;</span>#\<span style="color: #b1b100;">newline</span><span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#40;</span>read-loop <span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">read-char</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#93;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> 
&nbsp;
<span style="color: #808080; font-style: italic;">;;Run our demos</span>
<span style="color: #66cc66;">&#40;</span>fov-demo our-env<span style="color: #66cc66;">&#41;</span>
<span style="color: #66cc66;">&#40;</span>ray-casting-demo our-env<span style="color: #66cc66;">&#41;</span>
&nbsp;</pre>
<p>And finally the test code. Both of these loops behave the same, they use typical roguelike controls to move up (k), down (j), left (h), and right (l), as well as (q) to quit. You'll notice I also had to catch enter or read-char would spit out the map twice. At the end we call both of these functions so we can show off both types, back to back.</p>
<p>So there you have it, simple ray casting done in Scheme. I'll note that its not exceptionally fast, in fact for my test map the FOV demo was far quicker, but by degrading the accuracy and reducing the number of rays drawn the speed gets back up to something decent. I suspect that may also have to do with drawing it all out to the terminal, and will see what happens when I plug this into my ncurses code at a later point.</p>
<p>Hope that's commented well enough in the code. Enjoy!</p>
]]></content:encoded>
			<wfw:commentRss>http://thesnarky.com/2010/02/23/ray-casting-in-scheme/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>(library 7DRL (import (rnrs))</title>
		<link>http://thesnarky.com/2010/02/23/library-7drl-import-rnrs/</link>
		<comments>http://thesnarky.com/2010/02/23/library-7drl-import-rnrs/#comments</comments>
		<pubDate>Tue, 23 Feb 2010 23:40:09 +0000</pubDate>
		<dc:creator>Snarky</dc:creator>
				<category><![CDATA[Games]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Scheme]]></category>

		<guid isPermaLink="false">http://thesnarky.com/?p=413</guid>
		<description><![CDATA[7DRL Some friends were discussing the upcoming 7 Day Roguelike contest and I thought it'd be a fun thing to do after completing a browser based game in a month contest just a week back. However, I wanted to use something besides something besides the PHP I've been using for so very long, and somehow [...]]]></description>
			<content:encoded><![CDATA[<p><strong>7DRL</strong></p>
<p>Some friends were discussing the upcoming <a href="http://groups.google.com/group/rec.games.roguelike.development/browse_thread/thread/96fae2f059d0b2b2/88349386000aaa8b?lnk=raot">7 Day Roguelike contest </a> and I thought it'd be a fun thing to do after completing a <a href="http://community.bbgamezone.net/index.php/topic,2612.0.html">browser based game in a month contest</a> just a week back. However, I wanted to use something besides something besides the PHP I've been using for so very long, and somehow in the same IRC channel <a href="http://www.r6rs.org/">Scheme</a> came up.</p>
<p>Scheme is a LISP language that I learned back in college and very quickly grew a nice love/hate relationship. I love seeing the beauty of recursion expressed so easily, and I just hate to see so many parenthesis all over the place. Seriously they make your eyes bleed. But the idea hit me that it'd be fun to try to do the roguelike in Scheme, and I decided to enter. I most likely won't finish, and I'm not too happy with the idea I have, but it'll be fun nonetheless.</p>
<p><strong>Flavors</strong></p>
<p>To that end, I've been playing in Scheme for the past week to familiarize myself with a language I haven't touched in a few years and which has had some nice advances since that time. First job was getting it installed on Ubuntu. I'd recommend playing with various flavors and seeing what you like best. I tried <a href="http://www.gnu.org/software/mit-scheme/">Mit-Scheme</a>, <a href="http://scheme.com/">Chez Scheme</a>, <a href="http://www.plt-scheme.org/">PLT Scheme</a> (Dr Scheme), <a href="http://tinyscheme.sourceforge.net/home.html">Tiny Scheme</a>, and <a href="http://dynamo.iro.umontreal.ca/~gambit/wiki/index.php/Main_Page">Gambit</a>. These can all be installed under Linux (fairly) easily, and all have upsides and downsides. </p>
<ul>
<li>MIT Scheme - I had used this a tad during school, but sadly they're not supporting R6RS, and don't have a full implementation of R5RS, so its essentially useless.</li>
<li>Chez Scheme - What my school used primarily. Has a copy of the <a href="http://www.amazon.com/Scheme-Programming-Language-4th/dp/026251298X/ref=sr_1_1?ie=UTF8&s=books&qid=1266964867&sr=8-1">Scheme Programming Language Version 4</a> free <a href="http://scheme.com/tspl4/">on their site</a> which is a big plus. They support all three major OS's and include an RPM/instructions for Debian installation.</li>
<li>PLT Scheme - The other product we used at school, it comes as a Scheme IDE with the ability to select from a variety of language subsets. The Ubuntu 9.04 package isn't up to date, but the package available on their site includes R6RS, so grab their install script and forgo synaptic. Big plus of being a fully featured IDE.</li>
<li>Tinyscheme - From the command line I actually liked this flavor the best. Sadly its a subset of the R5RS standard so it won't do everything you need, but for small proof-of-concept or test code, its nice and fast. I know it'd defeat the purpose, but I wish there was an R6RS version.</li>
<li>Gambit Scheme - This is a flavor I only came across this past week, had no prior experience with it. I love it. Again the version in the 9.04 Ubuntu repos is a bit old, so grab the newest version (4.6 as of now) <a href="http://www.iro.umontreal.ca/~gambit/download/gambit/v4.6/source/gambc-v4_6_0.tgz">here</a>. If you just want to use Gambit as an interpreter/REPL you're good to go. If you want to use it to spit out C code as well, you may need to make sure your gambit.h file is in the right location.</li>
</ul>
<p><strong>Gambit</strong></p>
<p>Yes, I said spit out C, as Gambit-C compiles your Scheme nicely into C files that gcc will then happily compile for you along with real C to use both languages. This is going to play greatly into my 7DRL as I wanted to use the NCurses library to handle my screen output and to I can easily include that now. An example of Hello World in Gambit Scheme with NCurses:</p>
<pre class="scheme">&nbsp;
<span style="color: #808080; font-style: italic;">;;Hello World example for Gambit/NCurses</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Include our headers</span>
<span style="color: #66cc66;">&#40;</span>c-declare <span style="color: #ff0000;">&quot;#include &lt;ncurses.h&gt;&quot;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Define the function</span>
<span style="color: #66cc66;">&#40;</span><span style="color: #b1b100;">define</span> hello-world
    <span style="color: #808080; font-style: italic;">;;C lambda performs c commands, this is a basic ncurses</span>
    <span style="color: #808080; font-style: italic;">;;example that inits the screen, prints our string, waits</span>
    <span style="color: #808080; font-style: italic;">;;for input so it stays on the screen, and then kills the window</span>
    <span style="color: #66cc66;">&#40;</span>c-<span style="color: #b1b100;">lambda</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#41;</span> int <span style="color: #ff0000;">&quot;initscr(); printw(<span style="color: #000099; font-weight: bold;">\&quot;</span>Hello World<span style="color: #000099; font-weight: bold;">\&quot;</span>); refresh(); getch(); endwin();&quot;</span> <span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>
&nbsp;
<span style="color: #808080; font-style: italic;">;;Gotta remember to call it!</span>
<span style="color: #66cc66;">&#40;</span>hello-world<span style="color: #66cc66;">&#41;</span>
&nbsp;</pre>
<p>Now link, compile, and run it:</p>
<pre>
snarky@Reaper$ gsc -link ncurses.scm
snarky@Reaper$ gcc ncurses_.c ncurses.c -lgambc -lncurses -o ncurses
snarky@Reaper$ ./ncurses
Hello World
</pre>
<p>(Of course, the above output is slightly tweaked as I'm opting not to take a screenshot of a terminal empty save for one string)</p>
<p>It should be noted that once you start including C in your scheme you can no longer use the Gambit Scheme Interpreter to test your code, so I'd recommend breaking those bits out into other files if possible. </p>
<p>There are some other great additions within the Gambit system, such as the ability to have optional arguments in your functions, keyed variables passed to functions, and some random extensions like vector-copy, as well as, obviously, in-lining C in your Scheme. I highly recommend checking our their <a href="http://www.iro.umontreal.ca/~gambit/doc/gambit-c.html">manual</a> if you're at all interested. </p>
<p><strong>Gotchas</strong></p>
<p>I did get bit by a few things in Gambit, that I feel I should clarify. Even after reading through the manual, I missed that the compiler is spitting out linked files, not actual executables. To make sure you're getting an executable out of it make sure you do something akin to:</p>
<pre>
snarky@Reaper$ gsc -link file.scm
snarky@Reaper$ gcc file_.c file.c -lgambc
</pre>
<p>I very quickly just made a make file to handle it to simply forget about what steps go into it.</p>
<p>The big thing that bit me, however, was when I got out of the nice usual functions and into some higher syntax, specifically define-syntax. Gambit has a bunch of functionality turned off by default and requires that you turn it all on to use it. However I didn't feel like the documentation beat that into my head enough, so here's what you have to do:</p>
<p>For the interpreter:</p>
<pre>
snarky@Reaper$ gsi -:s
</pre>
<p>And for the compiler:</p>
<pre>
snarky@Reaper$ gsc -:s -link file.scm

OR

snarky@Reaper$ gsc -link -e '(load "/usr/local/Gambit-C/lib/syntax-case.scm")' file.scm
</pre>
<p>The top example turns a whole bunch of syntactic sugar on, while the bottom I believe just turns on some of the syntax. I could be wrong there.</p>
<p>I'm quite looking forward to playing with Gambit more and getting to know Scheme as I used to. Hopefully someone else can find a new sadistic language out of this post.</p>
]]></content:encoded>
			<wfw:commentRss>http://thesnarky.com/2010/02/23/library-7drl-import-rnrs/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
	</channel>
</rss>

