~johanvandegriff/ruegolike

f9caeee2647bf025d45a90c97bf81fc85a5b5b61 — Johan Vandegriff 1 year, 5 months ago 1e2ec35
cave level gen and guaranteed stairs reachable (flood fill)
5 files changed, 166 insertions(+), 5116 deletions(-)

D Roguelike Vision Algorithms - Adam Milazzo's Personal Site (2020-05-15 9_27_23 PM).html
D RoguelikeVisionAlgorithms.txt
M display.go
M generate.go
M main.go
D Roguelike Vision Algorithms - Adam Milazzo's Personal Site (2020-05-15 9_27_23 PM).html => Roguelike Vision Algorithms - Adam Milazzo's Personal Site (2020-05-15 9_27_23 PM).html +0 -4832
@@ 1,4832 0,0 @@
<!DOCTYPE html> <html style><!--
 Page saved with SingleFile 
 url: http://www.adammil.net/blog/v125_Roguelike_Vision_Algorithms.html#raycast 
 saved date: Thu May 14 2020 21:27:23 GMT-0400 (Eastern Daylight Time)
--><meta charset=utf-8>
<title>Roguelike Vision Algorithms - Adam Milazzo's Personal Site</title>
<meta name=viewport content="width=device-width, initial-scale=1">
<style>body{box-sizing:border-box;margin:0.5em;background-color:#999;font-family:Verdana,sans-serif;font-size:10pt}*,*:before,*:after{box-sizing:inherit}h1{font-size:150%}h2{font-size:125%}h3{font-size:115%;margin-bottom:0px}h4{font-size:100%;margin-bottom:0px}h1,h2,h3,h4{margin-top:0px}p:first-of-type{margin-top:0px}.left{float:left}.clear{clear:both}header,footer{background-color:#354463;color:white;border:1px solid black}header{margin-bottom:0.25em;padding:0.25em}header h1{margin:0px 0px 0px 0.75em}header aside,header blockquote{text-align:right;font-size:90%}header blockquote{margin:0px}footer{padding:0.125em 0.25em;margin-top:0.25em;font-size:80%;text-align:center}.navbar{width:100%;overflow:hidden;background-color:#5f7797;border:1px solid black}.navbar a{padding:0.375em 1em;float:left;width:auto;display:block;color:white;text-decoration:none}.navbar a{border-right:1px solid #354463}.navbar a:hover,.navbar a.selected{background-color:#354463}.navbar a.selected{font-weight:bold}.mainArea{background-color:#f0f0f0;color:black;padding:0.5em;border:1px solid black;border-top:0px}main.twoCol{width:87.4%;float:right}.sidebar{width:12.5%;min-width:10em}.box{background-color:#5f7797;color:white;border:1px solid black;margin:0px 0.5em 0.5em 0px}.box:last-of-type{margin-bottom:0px}.box A{color:white}.box .title{width:100%;padding:0.25em 0.5em;font-weight:bold;text-transform:uppercase;background-color:#354463}.box .title span::before{content:":: "}.box .content{padding:0.25em 0.5em;font-size:80%;text-align:center}.box .content ul{padding:0px 0px 0px 1em;margin:0.1875em 0px}.box .content li{margin-top:0.375em}.box .content li:first-of-type{margin-top:0px}.code{margin-left:1em;margin-bottom:1em;background-color:#cccccc;clear:both;overflow:auto}.blogPost{background-color:white;padding:0.25em 0.5em;border:1px solid #999}.blogPost>.header{margin-bottom:0.5em}.blogPost>.header h2{margin-bottom:0px}.blogPost>.header .date{color:#666;font-size:85%}.blogPost>.content{padding-bottom:1em;text-align:justify}.comments{margin-top:1em}.comment{background-color:white;padding:0.25em 0.5em;border:1px solid #999;margin-top:1em}.comment .header{margin-bottom:0.5em}.comment .header .title{font-weight:bold}.comment .header .date{color:#666}.comment .poster{text-align:right}form input,form textarea{margin:0.125em 0px}form input[type=text],form input[type=email],form input[type=password],form textarea{width:100%}form textarea{height:10em}@media only screen and (min-width:1200px){form{max-width:40em}}@media only screen and (min-width:769px) and (max-width:1199px){form{max-width:40em}.sidebar{width:20%}main.twoCol{width:79.8%}}@media only screen and (max-width:768px){.hide-small{display:none!important}.navbar a{border:none}header h1,header blockquote{text-align:center;margin:0px}header blockquote{font-size:80%}.sidebar,main.twoCol{width:100%}.box{margin-right:0px;margin-top:1em}.code{margin-left:0px}form,form input[type=submit]{width:100%}ul,ol{padding-left:1.25em}}</style>
<link rel=alternate type=application/rss+xml title=RSS href=http://www.adammil.net/blog/rss.xml><style>.pln{color:#000}@media screen{.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun{color:#660}}pre.prettyprint{padding:2px;border:1px solid #888}</style><link type=image/x-icon rel="shortcut icon" href=""><style>.sf-hidden{display:none!important}</style><link rel=canonical href=http://www.adammil.net/blog/v125_Roguelike_Vision_Algorithms.html#raycast></head>
<body>
<header>
 <aside class=hide-small>May 14, 2020 18:07:25</aside>
 <h1>Web Rarely</h1>
 <blockquote>The program isn't debugged until the last user is dead.</blockquote>
</header>
<nav class=navbar>
 <a href=# class="menuButton show-small sf-hidden">Menu »</a>
 <span id=menu class=hide-small>
 <a href=http://www.adammil.net/index.html>Home</a>
 <a href=http://www.adammil.net/me.html>Me</a>
 <a href=http://www.adammil.net/art.html>Art</a>
 <a href=http://www.adammil.net/baking.html>Baking</a>
 <a href=http://www.adammil.net/code.html>Code</a>
 <a href=http://www.adammil.net/math/index.html>Math</a>
 <a href=http://www.adammil.net/japanese/index.html>Japanese</a>
 <a href=http://www.adammil.net/blog/index.html class=selected>Rarely</a>
 <a href=http://www.adammil.net/resume.html>Résumé (CV)</a>
 <a href=http://www.adammil.net/contact.html>Contact</a>
 </span>
</nav>
<div class=mainArea>
<main class=twoCol>
<div class=blogPost>
<div class=header>
 <h2>Roguelike Vision Algorithms</h2>
 <span class=date>2014-10-08</span>
</div>
<div class=content>
<style>.simpleTable .green{background-color:#99ff99}.simpleTable .yellow{background-color:#f0ff99}.simpleTable .orange{background-color:#ffcc78}.simpleTable .red{background-color:#ff9999}.sshotc{display:inline-block;text-align:center;vertical-align:top}.sshot{background-color:black;color:#333333;display:inline-block;font-size:16pt;margin:0px}.sshot .red{color:#800000}.sshot .green{color:#008000}.sshot .blue{color:#000080}.sshot .yellow{color:#808000}.sshot .purple{color:#800080}.sshot .cyan{color:#008080}.sshot .gray{color:#808080}.sshot .lt{color:white}.sshot .bddk{color:#660000}.sshot .bdlt{color:#ff3333}.caption{font-size:9pt;text-align:center}</style>
<h3>Table of Contents</h3>
<ol>
<li><a href=#intro>Introduction</a></li>
<li><a href=#props>Desirable Algorithm Properties</a></li>
<li><a href=#survey>Existing Algorithms</a>
 <ol type=a>
 <li><a href=#raycast>Ray casting</a></li>
 <li><a href=#shadowcast>Shadow casting</a> (point-to-tile or point-to-point)</li>
 <li><a href=#diamondwalls>Diamond walls</a> (point-to-tile or point-to-point)</li>
 <li><a href=#halfwidth>Half-width walls</a> (point-to-tile or point-to-point)</li>
 <li><a href=#permissive>Permissive field of view</a> (tile-to-tile)</li>
 <li><a href=#digital>Digital field of view</a> (diamond-to-diamond)</li>
 <li><a href=#mine>My algorithm</a></li>
 </ol>
</li>
<li><a href=#compare>Comparison</a>
 <ol type=a>
 <li><a href=#cmpcorn>Corner peeking</a></li>
 <li><a href=#cmpcorr>Corridor asymmetry</a></li>
 <li><a href=#cmpnarrow>Narrow spaces</a></li>
 <li><a href=#cmpdiag>Diagonal spaces</a></li>
 <li><a href=#cmprooms>Rooms</a></li>
 <li><a href=#cmppillar>Pillars</a></li>
 <li><a href=#cmpsymmetry>Symmetrical versions</a></li>
 <li><a href=#cmpperf>Performance</a></li>
 </ol>
</li>
<li><a href=#code>Code</a>
 <ol type=a>
 <li><a href=#raycode>Ray casting</a></li>
 <li><a href=#shadowcode>Shadow casting</a></li>
 <li><a href=#diamondcode>Diamond walls</a></li>
 <li><a href=#permissivecode>Permissive field of view</a></li>
 <li><a href=#mycode>My algorithm</a></li>
 </ol>
</li>
<li><a href=#further>Further Possibilities</a>
 <ol type=a>
 <li><a href=#nethack>NetHack-style lighting</a></li>
 <li><a href=#lightsources>Light sources</a></li>
 <li><a href=#falloff>Light falloff</a></li>
 <li><a href=#colored>Colored lighting</a></li>
 </ol>
</li>
</ol>
<a name=intro></a>
<h3>Introduction</h3>
<p>One task when implementing a roguelike is to figure out how to compute the region of the dungeon that's visible to the
player or another monster. There are many existing algorithms, but they all have flaws, so I set out to develop a new
algorithm that is fast, exact, and aesthetically pleasing to me. Although I didn't create a perfect algorithm, I still
think my algorithm is an improvement over the others.</p>
<p>The visible region is called a monster's <i>field of view</i>, and determines whether the monster can see a
particular part of the dungeon terrain. I'll assume that the dungeon is tile-based, which is usual. Whether the player
can see a tile (called having <i>line of sight</i> and abbreviated LOS) is occasionally different from whether the
player can see a monster in that tile, and frequently different from whether he can target that monster with a ranged
weapon or spell (called having <i>line of targeting</i> here and abbreviated LOT).</p>
<a name=props></a>
<h3>Desirable Algorithm Properties</h3>
I'll first describe some frequently desirable traits of a field-of-view algorithm and then show why most existing
algorithms lack one or more of these traits.
<ul>
<li><b>Symmetry:</b> If you can see tile B while standing on tile A, then you should be able to see tile A when
 standing on tile B. This is generally considered desirable, partly because it's fair, and partly because the
 asymmetry in vision that almost all asymmetrical algorithms produce leads to poor tactical gameplay when the line of
 targeting is the same as the line of sight (as is normally the case). An algorithm that manages to be asymmetrical in
 the opposite of the normal way might actually be better than a symmetric algorithm.
</li>
<li><b>Expansive walls:</b> When standing in a (convex) room, you can see all of the room's walls, and when standing in
 a long corridor you can see all the wall tiles along the sides of the corridor. Although it rarely affects gameplay
 tactics much, it looks ugly and can make exploration tedious if an algorithm does not have this property.
</li>
<li><b>Expanding pillar shadows:</b> When sight is blocked by a pillar (an opaque tile not connected to others), the
 pillar should cast a shadow in the shape of a circular sector. This usually allows for more tactical gameplay, since
 it's easier to hide from, ambush, and escape other monsters. However, many roguelikes don't generate pillars, making
 this less relevant for them.
</li>
<li><b>No blind corners:</b> You can see at least two tiles around a corner, so that if you move diagonally around the
 corner, you won't find yourself next to (and being gored by) a monster you couldn't see. This also implies that you
 can see at least two tiles to either side before stepping into a hallway. This is desirable in most cases, since it's
 tedious if players must step carefully around every corner. Some algorithms allow you to see infinitely far around
 corners, protecting you from monsters with ranged weapons as well.
</li>
<li><b>No artifacts:</b> Although there can be reasonable disagreement over what the "right" behavior is for a
 field-of-view algorithm, an algorithm should at least do what it's supposed to. Generally this means that the
 algorithm should define the world geometry and accurately model light propagation within that geometry. The main
 causes of artifacts are the algorithm simply not corresponding to the world geometry, the algorithm being implemented
 using approximate rather than exact math, and bugs in the implementation.
</li>
<li><b>Efficiency:</b> The algorithm shouldn't take a long time, and preferrably should avoid testing the same tiles
 repeatedly.
</li>
</ul>
<a name=survey></a>
<h3>Existing Algorithms</h3>
<p>This is not an exhaustive list of algorithms, but covers the most frequently used ones.</p>
<a name=raycast></a>
<h4>Ray casting</h4>
<b>Pros:</b> Simple. Pretty fast. Expanding pillar shadows. Good balance of light and shadow. No blind corners.
<b>Cons:</b> Asymmetrical. Lots of gaps. No expansive walls. Quirky.
<p>Ray casting involves casting rays from the player to every point along the edge of the map or every point along the
circumference of the player's view radius. The rays are cast using a simple line-drawing algorithm, usually <a target=_new href=https://en.wikipedia.org/wiki/Bresenham%27s_line_algorithm>Bresenham's</a>, which stops as soon as
it hits a wall. Ray casting is the simplest algorithm, and quite fast, but it has numerous problems. First, it's highly
asymmetrical. Bresenham's algorithm isn't symmetrical, but even if you use a symmetrical line-drawing algorithm (which
causes its own problems), the result will still be asymmetrical because the endpoints of the lines aren't simply
reversed when you alternate positions. The algorithm also has gaps in both visible points and shadows and is generally
very quirky. Gaps in the walls can be fixed up in a post-processing pass, which removes the ugliest artifacts, but this
slows the algorithm and doesn't fix the other problems. The algorithm tests tiles multiple times, making it somewhat
inefficient, but due to its simplicity it still ends up being pretty fast, especially with a small sight radius. (Ray
casting has a reputation for being the fastest algorithm by far, but that's mainly due to people's generally poor
implementations of more complex algorithms. A well-implemented shadow casting algorithm beats ray casting every time.)
Leaving aside the numerous gaps and asymmetries and just considering the shapes of light and shadow, ray casting
produces nicer results in my opinion than more complicated algorithms like shadow casting and diamond walls. Also, most
of its problems become less severe as the sight radius decreases, and with a circular sight radius of 4 or less it
actually works very nicely, with no post-processing required (although some artifacts remain).</p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>───────────</span>─<span class=lt>─</span>─<span class=lt>─</span>──<span class=lt>─</span>─┤
<span class=lt>∙@∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>─────┬┬─∙┌┬</span>─<span class=lt>─</span>┐<span class=lt>∙∙∙∙∙+</span>
     ├┘∙∙└┤  └─────┤
</pre>
<div class=caption>Gaps in walls<br>(can be fixed with post-processing)</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙@∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙┼</span>∙<span class=lt>∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙</span>∙∙
</pre>
<div class=caption>Gaps in shadow</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙@∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙┼∙┼∙┼∙∙∙∙</span>
∙∙∙<span class=bddk>∙</span><span class=lt>∙∙</span>∙<span class=lt>∙∙<span class=bdlt>∙</span></span>∙∙∙
∙∙<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙∙∙</span>∙∙
</pre>
<div class=caption>Shadow asymmetry</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>──────────</span>─<span class=lt>─</span>─<span class=lt>─</span>──<span class=lt>─</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┬┬─∙┌</span>┬<span class=lt>─</span>─<span class=lt>┐</span><span class=bddk>∙∙</span><span class=lt>∙</span>
     ├┘∙∙└┤  └───
</pre>
<div class=caption>More gaps (see next two)</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>───────────</span>─<span class=lt>─</span>─<span class=lt>─</span>──
<span class=lt>∙@∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┬┬─∙┌┬</span>─<span class=lt>─</span>┐<span class=lt><span class=bdlt>∙∙</span>∙</span>
     ├┘∙∙└┤  └───
</pre>
<div class=caption>Shadow disappears</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>────────────</span>─<span class=lt>─</span>─<span class=lt>─</span>─
<span class=lt>∙∙@∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┬┬─∙┌┬─</span>─<span class=lt>┐</span><span class=bddk>∙</span><span class=lt><span class=bdlt>∙</span>∙</span>
     ├┘∙∙└┤  └───
</pre>
<div class=caption>Shadow partly reappears</div>
</div>
<p></p>
<p>Code to implement ray casting is <a href=#raycode>below</a>.</p>
<a name=shadowcast></a>
<h4>Shadow casting (point-to-tile or point-to-point)</h4>
<b>Pros:</b> Fast. Expanding pillar shadows. Expansive walls. Continuous point visibility.
<b>Cons:</b> Diagonal vision much narrower than cardinal. Blind corners. Beam expands too much through a door.
Asymmetrical. Nontrivial to eliminate all artifacts.
<p>Shadow casting is the technique of casting circular sectors of light outward from the player. When a sector hits a
wall, the sector may be reduced in angle or split into two sectors which are then processed independently.
Implementations vary, but a good implementation will visit each tile only once, or nearly so, and a small and roughly
constant amount of work is done per tile. This makes shadow casting one of the fastest algorithms if implemented well,
but in poor implementations it can perform relatively slowly in diagonal tunnels and in open areas with lots of small
obstructions. "Shadow casting" is a bit of a misnomer because what's actually cast is light, but I'll use it since
"light casting" seems too similar to "ray casting". In every case I've seen, shadow casting has used square tiles, but
other tile shapes are possible.</p>
<p>In the usual implementation, shadow casting renders a tile visible if there is an unobstructed line from the center
of the player's tile to any part of the target tile. Here's an example to illustrate how shadow casting works for a
single octant. (Not all implementations work in octants.) In the first picture, a 45-degree sector of light is projected
down the 45-degree octant. The green line bounds the top of the sector and the blue line bounds the bottom. The
fractions displayed are the slopes of the lines, which are always from 0 to 1 (inclusive). Tiles with circles are
considered visible. Then, the algorithm works from left to right (increasing X). For each column, it scans from the top
tile within the sector down to the bottom tile within the sector. If a transition from clear to opaque or vice versa is
found, the sector is adjusted. In the second picture, the first three columns have been scanned and a transition from
opaque to clear has been found in the fourth column, so the top vector is adjusted downward. In the next picture, a
clear-to-opaque transition has been found and the bottom vector is adjusted upward. In the final picture, you can see
that both types of transitions were found in the fifth column, so the sector splits into two sectors, each of which
continue independently. The algorithm stops when it hits the maximum sight distance or all the sectors become empty
(bottom slope &gt; top slope).</p>
<p><img src=> <img src=> <img src="">
<img src=></p>
<p>Here are some of the features and problems of shadow casting (with the usual square tiles).</p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙@┼</span>∙∙∙∙∙
<span class=lt>∙∙∙┼∙</span>∙∙∙∙∙
<span class=lt>∙∙</span>┼∙∙<span class=lt>∙</span>∙∙∙∙
<span class=lt>∙</span>┼∙∙∙∙<span class=lt>∙</span>∙∙∙
┼∙∙∙∙∙∙<span class=lt>∙</span>∙∙
</pre>
<div class=caption>Thin diagonal spaces</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙@┼</span>∙∙∙┼∙
<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙
<span class=lt>∙∙∙∙┼∙</span>∙∙┼∙
<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙</span>∙∙∙
<span class=lt>∙∙∙∙∙</span>∙∙<span class=lt>∙</span>∙∙
</pre>
<div class=caption>In this case too</div>
</div>
<div class=sshotc>
<pre class=sshot>───<span class=lt>─────</span>───
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
──┬┬<span class=lt>─@┌</span>┬───
  ├┘<span class=lt>∙∙└</span>┤   
 ┌┘<span class=lt>∙∙│∙</span>└┐  
</pre>
<div class=caption>Has blind corners</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>───────────</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┬┬─∙┌┬</span>
     ├┘∙∙└┤
    ┌┘∙∙│∙└
</pre>
<div class=caption>Asymmetrical<br>(compare w/ previous)</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙</span>∙∙∙
<span class=lt>∙∙∙∙∙┼∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Gaps in pillar shadows<br>(not an artifact, just ugly)</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙</span>∙<span class=bdlt>∙∙</span>∙│ 
<span class=lt>∙∙∙∙┼∙│</span>∙∙│ 
<span class=lt>∙∙∙∙∙∙│∙∙│</span> 
<span class=lt>∙∙∙∙∙∙∙∙∙└</span>─
<span class=lt>∙@∙∙∙│</span>∙∙∙∙∙
</pre>
<div class=caption>Red shouldn't be visible<br>(implementation artifact)</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙│</span>                   │∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>∙└───────────────────┤∙∙∙∙∙∙∙┼∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───────┬┬─∙┌┬────────┤∙∙∙∙∙∙∙┼∙∙∙</span>
       ├┘∙∙└┤        │∙∙∙∙∙∙∙∙∙∙∙
</pre>
<div class=caption>Always a three-high beam through a door, and the beam isn't blocked by pillars<br>
 (not an artifact, but very ugly)
</div>
</div>
<p></p>
<p>The asymmetry displayed above is an example of how asymmetrical algorithms tend to create unsatisfying tactical
situations. If you can target what you can see, then the monster in the middle of the corridor would have an advantage
over a monster on the side of it, despite the monster on the side appearing to have better cover. The monster on the
side could be shot without even seeing the attacker. Asymmetries like these are why symmetry is considered a desirable
property. However, if the asymmetry was reversed, it might actually be an improvement over symmetrical algorithms by
allowing you to take cover, giving a more tactical feel to the gameplay (although it would probably be best if the
visibility was symmetrical but not the targeting). There is an algorithm called "reverse shadow casting" which reverses the asymmetry, but it generally looks much poorer and runs much slower.</p>
<p>A small modification to the shadow casting code suffices to make it symmetrical, though. This works by changing the
algorithm so it considers a tile visible only if there's an unobstructed line from the center of the player's tile to
the center of the target tile (rather than any part of the target tile). This fixes some problems and causes others, as you can see below.</p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>──</span>─────────
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>──</span>───┬┬─∙┌┬
     ├┘∙∙└┤
    ┌┘∙∙│∙└
</pre>
<div class=caption>Symmetrical,<br>no expansive walls</div>
</div>
<div class=sshotc>
<pre class=sshot>    ┌<span class=lt>─────</span>─
    │<span class=lt>∙∙∙∙∙∙</span>
    │<span class=lt>∙∙∙∙∙∙</span>
    <span class=lt>│∙∙∙∙∙∙</span>
    <span class=lt>│@∙∙∙∙∙</span>
</pre>
<div class=caption>No expansive walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙</span>∙
<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙
<span class=lt>∙∙∙∙∙┼</span>∙∙∙∙∙
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>No shadow gaps</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙</span>∙∙∙∙∙│ 
<span class=lt>∙∙∙∙┼</span>∙<span class=lt>│</span>∙∙│ 
<span class=lt>∙∙∙∙∙∙│</span>∙∙<span class=lt>│</span> 
<span class=lt>∙∙∙∙∙∙∙∙∙</span>└─
<span class=lt>∙@∙∙∙│</span>∙∙∙∙∙
</pre>
<div class=caption>Artifact is gone</div>
</div>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>∙∙∙∙∙∙
<span class=lt>──</span>─┤∙∙∙<span class=lt>∙∙∙∙┼</span>∙∙∙┼∙∙∙∙∙
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>──</span>─┤∙∙∙<span class=lt>∙∙∙∙┼</span>∙∙∙┼∙∙∙∙∙
   │∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>∙∙∙∙∙∙
</pre>
<div class=caption>Better propagation through narrow spaces</div>
</div>
<p></p>
<p>Code to implement basic shadow casting is <a href=#shadowcode>below</a>.</p>
<a name=diamondwalls></a>
<h4>Diamond walls (point-to-tile or point-to-point)</h4>
<b>Pros:</b> Pretty fast. Expanding pillar shadows. Expansive walls. No blind corners. Mostly continuous point visibility.
<b>Cons:</b> Beam expands too much through a door. Asymmetrical; a small change fixes this but loses expansive walls and
causes more visual discontinuities.
<p>Like shadow casting, the diamond walls algorithm treats a tile as visible if there's an unobstructed line from the
center of the player's tile to any part of the target tile. However, for the purpose of occlusion it treats walls as
though they were diamonds (embedded in the tile, the remainder being empty space). This eliminates the thin diagonal
spaces from the standard shadow casting algorithm and allows better peeking around corners, but it causes a couple
problems of its own. The main new problem is that it is, in my opinion, a bit too permissive, meaning that it makes too
many tiles visible. Nonetheless it seems like an improvement on standard shadow casting. (I chose to implement it by
modifying my shadow casting code.) As for efficiency, it is somewhat slower than plain shadow casting, since it needs to
do more work per tile, but it's still reasonably fast.</p>
<p>Treating walls as diamonds actually makes a lot of sense in roguelikes, although it sounds ridiculous. The reason is
that most roguelikes allow monsters to move between diagonally adjacent walls, and if the walls were square, their
corners would be touching, leaving no space. This is illustrated in the picture below. Making the physics of the world
more consistent naturally leads to more intuitive lighting. Diamond walls also allow better vision around corners, which
is usually desirable.</p>
<p><img src=""> <img src=""> <img src=></p>
<p>Unfortunately, there is a theoretical problem with diamond walls. The description states that lines tangent to a wall
diamond aren't considered to intersect it and zero-width beams of light still illuminate tiles. This provides better
vision around corners but also allows the following case where a monster can see through a wall. Implementations are
expected to disallow seeing through walls as a special case, which prevents the problem but requires inconsistent
physics.</p>
<p><img src=""></p>
<p>Here are some features and problems of shadow casting with diamond walls.</p>
<p>
<div class=sshotc>
<pre class=sshot>   <span class=lt>│∙∙∙∙∙</span>∙∙
   <span class=lt>│∙∙∙∙∙∙</span>∙
   │∙<span class=lt>∙∙∙∙∙</span>∙
───┤∙∙∙<span class=lt>∙∙∙┼</span>
∙∙∙■∙∙∙∙∙<span class=lt>┼@</span>
</pre>
<div class=caption>Visibility through diagonals</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>@┼</span>∙∙∙∙∙∙∙∙∙
<span class=lt>∙∙∙∙</span>∙∙∙∙∙∙∙
<span class=lt>∙┼∙∙∙∙</span>∙∙∙∙∙
<span class=lt>∙∙∙∙∙∙∙∙</span>∙∙∙
<span class=lt>∙┼</span>∙<span class=lt>∙∙∙∙∙∙∙</span>∙
</pre>
<div class=caption>Here too</div>
</div>
<div class=sshotc>
<pre class=sshot>─<span class=lt>─────────</span>─
∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙∙
──┬┬<span class=lt>─@┌</span>┬───
  ├<span class=lt>┘∙∙└</span>┤   
 ┌<span class=lt>┘∙∙│∙</span>└┐  
</pre>
<div class=caption>No blind corners</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>───────────</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┬┬─∙┌┬</span>
     ├┘∙∙└┤
    ┌┘∙∙│∙└
</pre>
<div class=caption>Still asymmetrical</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙┼∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Bigger shadow gaps<br>than shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>           │∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>───────────┤∙∙∙∙∙∙∙┼∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙┌┬────────┤∙∙∙∙∙∙∙┼∙∙∙</span>
<span class=lt>∙└</span>┤        │∙∙∙∙∙∙∙∙∙∙∙
</pre>
<div class=caption>Same problem casting through narrow spaces</div>
</div>
<p></p>
<p>The same simple change can be made to turn the diamond wall algorithm into a symmetric one, and it has the same
benefits and drawbacks that it has for regular shadow casting.</p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>───</span>────────
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───</span>──┬┬─∙┌┬
     ├┘∙∙└┤
    ┌┘∙∙│∙└
</pre>
<div class=caption>Symmetrical,<br>no expansive walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>─────</span>─────┐
<span class=lt>∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙│</span>
</pre>
<div class=caption>No expansive walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙
<span class=lt>∙∙∙∙∙┼</span>∙∙∙∙<span class=lt>∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>No shadow gaps</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>├───∙─</span>─────
│∙∙∙∙<span class=lt>∙</span>∙∙∙∙∙
│∙∙∙∙∙┼<span class=lt>∙</span>┼∙∙
│∙∙∙∙∙∙∙∙∙∙
│∙∙∙∙∙∙∙∙│<span class=lt>∙</span>
</pre>
<div class=caption>Discontinuous visibility</div>
</div>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙∙∙
<span class=lt>───</span>┤∙∙<span class=lt>∙∙∙∙∙┼</span>∙∙∙┼∙∙∙∙∙
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───</span>┤∙∙<span class=lt>∙∙∙∙∙┼</span>∙∙∙┼∙∙∙∙∙
   │∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙∙∙
</pre>
<div class=caption>Better propagation through narrow spaces</div>
</div>
<p></p>
<p>Code to implement diamond walls is <a href=#diamondcode>below</a>.</p>
<a name=halfwidth></a>
<h4>Half-width walls</h4>
<b>Pros &amp; cons:</b> The same as diamond walls, but more permissive and slightly slower.
<p>There is another idea similar to diamond walls except that it uses walls that are half the usual width. It also
solves the problem of not being able to see between diagonal tiles, but in my opinion looks poorer than diamond walls by
being too permissive. The implementation is also slightly slower since not every wall tile has the same shape. (The
shape depends on whether there is an adjacent wall for it to join with.) I implemented the algorithm but I don't
consider it worth the effort to present.</p>
<a name=permissive></a>
<h4>Permissive field of view (tile-to-tile)</h4>
<b>Pros:</b> Symmetry. No blind corners. Expansive walls. Continuous point visibility.
<b>Cons:</b> Slow. No expanding pillar shadows. Perhaps too much visibility around corners.
<p>The permissive field of view algorithm treats a tile as visible if there's an unobstructed line from any part of the
player's tile to any part of the target tile. Most implementations of this use an approximation, such as just testing
the corners against each other, which fails in some cases. Exact implementations work in all cases but tend to be fairly
slow. I provide an exact implementation (cleaned up and adapted from a demo by
<a target=_new href=https://user.xmission.com/~tyrecius/>Jonathon Duerig</a>). The main features of the algorithm
are that it's symmetrical and allows peeking very far around corners, but it's too permissive for my taste, so I haven't
made any effort to optimize the algorithm. That said, the algorithm looks and works much better if all creatures have a
short sight radius.</p>
<p>There exists a version of the permissive FOV algorithm that allows the permissivity to be changed at runtime. I
played with it, and half the usual permissivity looks decent to my eye, but then it's no longer symmetrical and I'd prefer to have a faster algorithm anyway.</p>
<p>
<div class=sshotc>
<pre class=sshot>   <span class=lt>│∙∙∙∙∙∙</span>∙<span class=lt>∙∙</span>
<span class=lt>───┤∙∙∙∙∙∙∙┼∙</span>
<span class=lt>∙∙∙■∙∙∙∙∙∙∙∙∙</span>
───┤∙∙∙∙∙∙∙<span class=lt>┼@</span>
   <span class=lt>│∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Thin pillar shadows</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙┼∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Pillar shadow gaps</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>─┴─────────■───</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>@┌</span>─────────■───
<span class=lt>∙│</span>∙∙∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>+┤</span>∙∙∙∙∙∙∙∙│∙∙∙∙
</pre>
<div class=caption>Can see <i>all</i> the way around corners</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>│∙│</span>                 ┌┬───┐
<span class=lt>│∙├</span>┬──<span class=lt>──────────────┴┘∙∙∙│</span>
<span class=lt>│∙└┘∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙┌</span>─┘
<span class=lt>│@∙∙∙┌</span>─────────────────┘  
<span class=lt>└────┘</span>                    
</pre>
<div class=caption>Including down Kuo corridors</div>
</div>
<p></p>
<p>Code to implement the permissive field of view algorithm is <a href=#permissivecode>below</a>.</p>
<a name=digital></a>
<h4>Digital field of view (diamond-to-diamond)</h4>
<b>Pros &amp; cons:</b> Same as the permissive field of view algorithm.
<p>The digital field of view algorithm treats every tile as a diamond (embedded in the square, the remainder being empty
space) and considers a tile visible if there is an unobstructed line from any part of the player's diamond to any part
of the target diamond. As a result, it's slightly more permissive than even the permissive field of view algorithm
(since walls present less of an obstruction), but otherwise it shares all the same features and drawbacks while being
even slower. The idea is based on the rather unwieldy concept of
<a target=_new href=http://libdgtal.org/doc/stable/moduleArithDSSReco.html>digital straight line segments</a>, and I
did not bother to create an implementation of it. One interesting feature of the algorithm is that the knowledge of
the digital line segment from a line-of-sight calculation allows easy tracing of a projectile path through space without
hitting any walls, even down somewhat twisted tunnels (such as the Kuo corridor above). But the complexity seems to
outweight the benefit.</p>
<a name=mine></a>
<h3>My algorithm</h3>
None of the above algorithms really satisfy me. First of all, except for ray casting they're all either too permissive
or too restrictive – sometimes both at once, and ray casting has too many artifacts to be usable. Here are the
problems I intend to fix and the features I intend to have.
<ul>
<li>Less permissive than most other algorithms</li>
<li>More symmetrical than other algorithms</li>
<li>Able to be made symmetrical (at least versus non-passwall monsters) without losing expansive walls</li>
<li>Good vision through diagonal spaces, but not too much</li>
<li>Good light casting through narrow spaces, without losing expansive walls</li>
<li>Reduced shadow gaps compared to other algorithms</li>
<li>Efficiency on par with diamond walls</li>
<li>No blind corners</li>
<li>No artifacts</li>
<li>Consistent physics</li>
</ul>
To accomplish this, I'll represent the dungeon geometry as in the following image. (NOTE: Two corners in the second image should be beveled. I drew it incorrectly. Nonetheless, the image illustrates the utility of the inner square.)
<p><img src=""> <img src=""></p>
<p>A corner is beveled if neither of the two cardinally adjacent tiles are walls. Wall tiles are considered visible if a
beam of light intersects the wall shape while clear tiles are considered visible if light intersects the central square
(which can be at most 1/2 the width or height of the tile). Tangents to a shape do not intersect it, and a zero-width
sector of light can't illuminate anything.</p>
<p>Solid walls with beveled edges allow peeking around corners and seeing through diagonal spaces while avoiding the
theoretical problem of diamond walls. Not showing clear tiles unless light passes near the center should make it a bit
less permissive, reduce shadow gaps, reduce asymmetry, and fix the behavior of light passing through narrow spaces.</p>
<p>The problem with light passage through narrow spaces is illustrated in the second image above. No matter how far you
are down the tunnel, the circular sector will open up as it leaves the narrow space and, with other algorithms,
immediately illuminate the tiles above and below. As seen in the screenshots above, pillars cannot stop this
illumination. The reason is that, like the walls of the tunnel, the sector is still opening up after it passes between
the pillars. Not illuminating tiles only barely touched by light avoids this, and allows pillars to effectively stop the
light. This should also reduce shadow gaps by preventing small slivers of light from dispelling the shadow from a
tile.</p>
<p>Permissivity can be tuned by adjusting the angle of the bevel and the size of the inner square. Another shape besides
a square can be used, but it must fit within the area of the largest diamond that can be placed in the tile (i.e. it may
not extend beyond the shape of a pillar). For a square, the maximum is 1/2 the width of the tile. Testing shows
that using 1/2 the width gives good results. Using 3/8 the width of the tile allows for symmetrical sight between
creatures in and on the side of a narrow corridor, which is a nice feature, but it looks a bit too restrictive otherwise
(especially if there are many pillars), so I'll stick with 1/2. The actual implementation will use a modified shadow
casting algorithm, giving decent performance as long as I can avoid doing too much work per tile.</p>
<p>Here are some samples from the asymmetrical version.</p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙@┼</span>∙∙∙∙∙
<span class=lt>∙∙∙┼∙∙</span>∙∙∙∙
<span class=lt>∙∙┼</span>∙<span class=lt>∙∙∙∙</span>∙∙
<span class=lt>∙┼</span>∙∙∙<span class=lt>∙∙∙∙∙</span>
<span class=lt>┼</span>∙∙∙∙<span class=lt>∙∙∙∙∙</span>
</pre>
<div class=caption>Good diagonal vision</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>@┼</span>∙∙∙∙∙∙∙∙
<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙
<span class=lt>∙┼∙∙∙</span>∙∙∙∙∙
<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙
<span class=lt>∙┼</span>∙<span class=lt>∙∙∙∙∙∙</span>∙
</pre>
<div class=caption>Here too</div>
</div>
<div class=sshotc>
<pre class=sshot>──<span class=lt>───────</span>──
∙∙∙<span class=lt>∙∙∙∙∙</span>∙∙∙
──┬┬<span class=lt>─@┌</span>┬───
  ├<span class=lt>┘∙∙└</span>┤   
 ┌<span class=lt>┘∙∙│∙</span>└┐  
</pre>
<div class=caption>No blind corners</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙</span>∙∙∙
<span class=lt>∙∙∙∙∙┼</span>∙∙<span class=lt>∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Fewer shadow gaps</div>
</div>
<div class=sshotc>
<pre class=sshot>         │∙∙∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>─────────┤</span>∙∙∙∙<span class=lt>∙∙∙┼</span>∙∙∙<span class=lt>┼</span>∙
<span class=lt>@∙∙∙∙∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>┬────────┤</span>∙∙∙∙<span class=lt>∙∙∙┼</span>∙∙∙<span class=lt>┼</span>∙
┤        │∙∙∙∙∙∙∙∙∙∙∙∙∙
</pre>
<div class=caption>Good behavior casting through narrow spaces</div>
</div>
<p></p>
<p>My algorithm has two symmetrical versions: one that's fully symmetrical and another that's symmetrical except for
some walls (i.e. symmetrical between monsters except sometimes against passwall monsters). Here's the version
that's mostly symmetrical. As you can see, it doesn't suffer from the same problems of other algorithms when made
symmetrical. Most importantly, it doesn't lose the expansive walls feature. This is the better of the two symmetrical
versions, unless you need symmetry versus passwall monsters.</p>
<p>
<div class=sshotc>
<pre class=sshot>           
<span class=lt>───────────</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>┬┬─</span>∙<span class=lt>┌┬─────</span>
├┘∙∙└┤     
</pre>
<div class=caption>Symmetrical non-walls,<br>expansive walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>──────────┐</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙│</span>
</pre>
<div class=caption>Expansive walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙∙∙┼</span>∙∙<span class=lt>∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>No shadow gaps</div>
</div>
<p></p>
<p>Here is the fully symmetrical version of my algorithm. It gains symmetry against all passwall monsters but loses
expansive walls as usual, although walls are no less expansive than other algorithms (except permissive FOV) and more
expansive than most. It is very similar but not identical to symmetrical diamond walls.</p>
<p>
<div class=sshotc>
<pre class=sshot>           
<span class=lt>───</span>────────
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>┬┬─</span>∙<span class=lt>┌</span>┬─────
├┘∙∙└┤     
</pre>
<div class=caption>Symmetrical,<br>no expansive walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>─────────</span>─┐
<span class=lt>∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙│</span>
</pre>
<div class=caption>No expansive walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙∙∙┼</span>∙∙<span class=lt>∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>No shadow gaps</div>
</div>
<p></p>
<p>Code to implement my algorithm is <a href=#mycode>below</a>.</p>
<a name=compare></a>
<h3>Comparison</h3>
Here's a comparison of my algorithm with the ray casting, shadow casting, diamond walls, and permissive field of view
algorithms. Unless otherwise stated, the comparison is done between the basic (usually asymmetrical) versions of the
algorithms. In some sections I've reduced the line height in order to make the height of a tile closer to its width,
allowing a better sense of symmetry on the two axes. Depending on your font and browser, this might look terrible,
especially in vertical walls. To toggle this effect,
<a href=http://www.adammil.net/blog/v125_Roguelike_Vision_Algorithms.html>click here</a>. (This requires Javascript, and the
effect is only enabled initially if Javascript is available.)<p></p>
<a name=cmpcorn></a>
<h4>Corner peeking</h4>
<p>
<div class=sshotc>
<pre class=sshot>──<span class=lt>───────</span>──
∙∙∙<span class=lt>∙∙∙∙∙</span>∙∙∙
──┬┬<span class=lt>─@┌</span>┬───
  ├<span class=lt>┘∙∙└</span>┤   
 ┌<span class=lt>┘∙∙│∙</span>└┐  
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>───<span class=lt>─────</span>───
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
──┬┬<span class=lt>─@┌</span>┬───
  ├┘<span class=lt>∙∙└</span>┤   
 ┌┘<span class=lt>∙∙│∙</span>└┐  
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>─<span class=lt>─────────</span>─
∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙∙
──┬┬<span class=lt>─@┌</span>┬───
  ├<span class=lt>┘∙∙└</span>┤   
 ┌<span class=lt>┘∙∙│∙</span>└┐  
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>──<span class=lt>───────</span>──
∙∙∙<span class=lt>∙∙∙∙∙</span>∙∙∙
──┬┬<span class=lt>─@┌</span>┬───
  ├<span class=lt>┘∙∙└</span>┤   
 ┌<span class=lt>┘∙∙│∙</span>└┐  
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>───────────</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
──┬┬<span class=lt>─@┌</span>┬───
  ├<span class=lt>┘∙∙└</span>┤   
 ┌<span class=lt>┘∙∙│∙</span>└┐  
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<a name=cmpcorr></a>
<h4>Corridor asymmetry</h4>
Red tiles are where a monster can see the player but the player can't see the monster.
<p>
<div class=sshotc>
<pre class=sshot>∙└─────<span class=lt>───────</span>───────
∙<span class=bddk>∙∙∙∙∙∙∙</span><span class=lt>∙∙∙∙∙</span><span class=bddk>∙∙∙</span>∙<span class=bddk>∙∙∙∙</span>
───────┬┬<span class=lt>─@┌</span>┬────────
       ├<span class=lt>┘∙∙└</span>┤        
      ┌<span class=lt>┘∙∙│∙</span>└┐       
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>∙└──────<span class=lt>─────</span>────────
<span class=bddk>∙∙∙∙∙∙∙∙∙</span><span class=lt>∙∙∙</span><span class=bddk>∙∙∙∙∙∙∙∙∙</span>
───────┬┬<span class=lt>─@┌</span>┬────────
       ├┘<span class=lt>∙∙└</span>┤        
      ┌┘<span class=lt>∙∙│∙</span>└┐       
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>∙└──────<span class=lt>─────</span>────────
<span class=bddk>∙∙∙∙∙∙∙∙</span><span class=lt>∙∙∙∙∙</span><span class=bddk>∙∙∙∙∙∙∙∙</span>
───────┬┬<span class=lt>─@┌</span>┬────────
       ├┘<span class=lt>∙∙└</span>┤        
      ┌┘<span class=lt>∙∙│∙</span>└┐       
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>∙└─────<span class=lt>───────</span>───────
∙∙∙∙∙∙∙<span class=bddk>∙</span><span class=lt>∙∙∙∙∙</span><span class=bddk>∙</span>∙∙∙∙∙∙∙
───────┬┬<span class=lt>─@┌</span>┬────────
       ├<span class=lt>┘∙∙└</span>┤        
      ┌<span class=lt>┘∙∙│∙</span>└┐       
</pre>
<div class=caption>My algorithm (1/2-width inner square)</div>
</div>
<div class=sshotc>
<pre class=sshot>∙└─────<span class=lt>───────</span>───────
∙∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙∙∙
───────┬┬<span class=lt>─@┌</span>┬────────
       ├<span class=lt>┘∙∙└</span>┤        
      ┌<span class=lt>┘∙∙│∙</span>└┐       
</pre>
<div class=caption>My algorithm (3/8-width inner square)</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙└───────────────────</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
───────┬┬<span class=lt>─@┌</span>┬────────
       ├<span class=lt>┘∙∙└</span>┤        
      ┌<span class=lt>┘∙∙│∙</span>└┐       
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<div id=lhContainer>
<a name=cmpnarrow></a>
<h4>Narrow spaces</h4>
In this and subsequent sections I've reduced the line height of some sections in order to make the height of a tile
closer to its width, allowing a better sense of symmetry on the two axes. Depending on your font and browser, this might
look terrible, especially in vertical walls. To toggle this effect,
<a href=http://www.adammil.net/blog/v125_Roguelike_Vision_Algorithms.html>click here</a>. (This requires Javascript, and
the effect is only enabled initially if Javascript is available.)
<p>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>
   │∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───┤∙∙∙∙∙∙∙+</span>∙∙<span class=lt>∙+</span>∙∙<span class=lt>∙</span>
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───┤∙∙∙∙∙∙∙+</span>∙∙<span class=lt>∙+</span>∙∙<span class=lt>∙</span>
   │∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙</span>∙
   │∙∙∙∙∙∙∙+∙∙∙+<span class=lt>∙∙∙</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>
   │∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙
<span class=lt>───┤∙∙∙∙∙∙∙+∙∙∙+∙∙∙</span>
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───┤∙∙∙∙∙∙∙+∙∙∙+∙∙∙</span>
   │∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙
   │∙∙∙∙∙∙∙+∙∙∙+∙∙<span class=lt>∙</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙∙∙∙∙∙<span class=lt>∙∙∙∙</span>
   │∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───┤∙∙∙∙∙∙∙+∙∙∙+∙∙∙</span>
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───┤∙∙∙∙∙∙∙+∙∙∙+∙∙∙</span>
   │∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙</span>
   │∙∙∙∙∙∙∙+∙∙∙<span class=lt>+∙∙∙</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙∙∙∙∙∙∙∙<span class=lt>∙∙</span>
   │∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙</span>∙∙
<span class=lt>───┤</span>∙<span class=lt>∙∙∙∙∙∙+</span>∙∙∙<span class=lt>+</span>∙∙∙
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───┤</span>∙<span class=lt>∙∙∙∙∙∙+</span>∙∙∙<span class=lt>+</span>∙∙∙
   │∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙</span>∙∙
   │∙∙∙∙∙∙∙+∙∙∙+∙<span class=lt>∙∙</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>
   │∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙
<span class=lt>───┤∙∙∙∙∙∙∙+∙∙∙+∙∙∙</span>
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───┤∙∙∙∙∙∙∙+∙∙∙+∙∙∙</span>
   │∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙
   │∙∙∙∙∙∙<span class=lt>∙+∙∙∙+∙∙∙</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>     │∙∙∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>─────┤∙∙∙∙∙∙∙+∙∙∙+</span>∙
<span class=lt>@∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┤∙∙∙∙∙∙∙+∙∙∙+</span>∙
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>     │∙∙∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>─────┤∙∙∙∙∙∙∙+∙∙∙+∙</span>
<span class=lt>@∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┤∙∙∙∙∙∙∙+∙∙∙+∙</span>
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>     │∙∙∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>─────┤∙∙∙∙∙∙∙+∙∙∙+∙</span>
<span class=lt>@∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┤∙∙∙∙∙∙∙+∙∙∙+∙</span>
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>     │∙∙∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>─────┤</span>∙∙<span class=lt>∙∙∙∙∙+</span>∙∙∙<span class=lt>+</span>∙
<span class=lt>@∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┤</span>∙∙<span class=lt>∙∙∙∙∙+</span>∙∙∙<span class=lt>+</span>∙
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>     │∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┤∙∙∙∙∙∙∙+∙∙∙+∙</span>
<span class=lt>@∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┤∙∙∙∙∙∙∙+∙∙∙+∙</span>
     │∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<a name=cmpdiag></a>
<h4>Diagonal spaces</h4>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙+</span>
<span class=lt>∙∙∙∙∙∙</span>+∙
<span class=lt>∙∙∙∙∙</span>+∙∙
<span class=lt>∙∙∙∙+</span>∙∙∙
<span class=lt>∙∙∙+</span>∙∙∙∙
<span class=lt>∙∙+</span>∙∙∙∙∙
<span class=lt>@+</span>∙∙∙∙∙∙
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙</span>+
<span class=lt>∙∙∙∙∙∙</span>+∙
<span class=lt>∙∙∙∙∙</span>+∙∙
<span class=lt>∙∙∙∙</span>+∙∙∙
<span class=lt>∙∙∙</span>+∙∙∙∙
<span class=lt>∙∙</span>+∙∙∙∙∙
<span class=lt>@+</span>∙∙∙∙∙∙
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙+</span>
<span class=lt>∙∙∙∙∙∙+</span>∙
<span class=lt>∙∙∙∙∙+</span>∙∙
<span class=lt>∙∙∙∙+</span>∙∙∙
<span class=lt>∙∙∙+</span>∙∙∙∙
<span class=lt>∙∙+</span>∙∙∙∙∙
<span class=lt>@+</span>∙∙∙∙∙∙
</pre>
<div class=caption>Others</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>┌───</span>────
<span class=lt>│∙∙∙</span>∙∙∙∙
<span class=lt>│∙∙∙∙</span>∙∙∙
<span class=lt>│∙∙∙∙∙</span>∙∙
│<span class=lt>∙∙∙∙∙</span>∙∙
│∙∙<span class=lt>∙∙∙∙</span>∙
┤∙∙∙∙<span class=lt>∙∙+</span>
■∙∙∙∙∙<span class=lt>+@</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌</span>───────
│<span class=lt>∙</span>∙∙∙∙∙∙
│∙<span class=lt>∙</span>∙∙∙∙∙
│∙∙<span class=lt>∙</span>∙∙∙∙
│∙∙∙<span class=lt>∙</span>∙∙∙
│∙∙∙∙<span class=lt>∙</span>∙∙
┤∙∙∙∙∙<span class=lt>∙+</span>
■∙∙∙∙∙<span class=lt>+@</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌────</span>───
<span class=lt>│∙∙∙∙</span>∙∙∙
<span class=lt>│∙∙∙∙∙</span>∙∙
<span class=lt>│∙∙∙∙∙</span>∙∙
<span class=lt>│∙∙∙∙∙∙</span>∙
│∙<span class=lt>∙∙∙∙∙</span>∙
┤∙∙∙<span class=lt>∙∙∙+</span>
■∙∙∙∙∙<span class=lt>+@</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌────</span>───
<span class=lt>│∙∙∙∙</span>∙∙∙
<span class=lt>│∙∙∙∙</span>∙∙∙
<span class=lt>│∙∙∙∙∙</span>∙∙
<span class=lt>│∙∙∙∙∙</span>∙∙
│∙∙<span class=lt>∙∙∙∙</span>∙
┤∙∙∙∙<span class=lt>∙∙+</span>
■∙∙∙∙∙<span class=lt>+@</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌──────</span>─
<span class=lt>│∙∙∙∙∙∙</span>∙
<span class=lt>│∙∙∙∙∙∙</span>∙
<span class=lt>│∙∙∙∙∙∙</span>∙
<span class=lt>│∙∙∙∙∙∙</span>∙
<span class=lt>│∙∙∙∙∙∙</span>∙
<span class=lt>┤∙∙∙∙∙∙+</span>
■∙∙∙∙∙<span class=lt>+@</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>┌───<span class=lt>─</span>───
│∙∙∙<span class=lt>∙∙</span>∙∙
│∙∙∙∙<span class=lt>∙</span>∙∙
│∙∙∙∙<span class=lt>∙∙</span>∙
<span class=lt>│∙</span>∙∙∙∙<span class=lt>∙</span>∙
<span class=lt>│∙∙∙</span>∙∙<span class=lt>∙+</span>
┤∙<span class=lt>∙∙∙∙+∙</span>
■∙∙∙∙<span class=lt>+∙@</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>┌────<span class=lt>─</span>──
│∙∙∙∙<span class=lt>∙</span>∙∙
│∙∙∙∙<span class=lt>∙</span>∙∙
│∙∙∙∙∙<span class=lt>∙</span>∙
│∙∙∙∙∙<span class=lt>∙</span>∙
<span class=lt>│∙∙</span>∙∙∙<span class=lt>∙+</span>
┤∙∙<span class=lt>∙∙∙+∙</span>
■∙∙∙∙<span class=lt>+∙@</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>┌──<span class=lt>───</span>──
│∙∙∙<span class=lt>∙∙∙</span>∙
│∙∙∙<span class=lt>∙∙∙</span>∙
<span class=lt>│</span>∙∙∙∙<span class=lt>∙∙</span>∙
<span class=lt>│∙∙</span>∙∙<span class=lt>∙∙</span>∙
<span class=lt>│∙∙∙∙</span>∙<span class=lt>∙+</span>
┤<span class=lt>∙∙∙∙∙+∙</span>
■∙∙∙∙<span class=lt>+∙@</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>┌───<span class=lt>──</span>──
│∙∙∙<span class=lt>∙∙</span>∙∙
│∙∙∙∙<span class=lt>∙∙</span>∙
│∙∙∙∙<span class=lt>∙∙</span>∙
<span class=lt>│∙</span>∙∙∙∙<span class=lt>∙</span>∙
<span class=lt>│∙∙∙</span>∙∙<span class=lt>∙+</span>
┤∙<span class=lt>∙∙∙∙+∙</span>
■∙∙∙∙<span class=lt>+∙@</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>┌─<span class=lt>─────</span>─
│∙<span class=lt>∙∙∙∙∙</span>∙
<span class=lt>│∙</span>∙<span class=lt>∙∙∙∙</span>∙
<span class=lt>│∙∙</span>∙<span class=lt>∙∙∙</span>∙
<span class=lt>│∙∙∙</span>∙<span class=lt>∙∙</span>∙
<span class=lt>│∙∙∙∙</span>∙<span class=lt>∙+</span>
<span class=lt>┤∙∙∙∙∙+∙</span>
■∙∙∙∙<span class=lt>+∙@</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>┌──</span>───<span class=lt>─</span>──
<span class=lt>│∙∙∙</span>∙∙<span class=lt>∙</span>∙∙
│<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙
│∙<span class=lt>∙∙∙</span>∙∙<span class=lt>∙</span>∙
│∙∙<span class=lt>∙∙∙</span>∙<span class=lt>∙</span>∙
│∙∙∙<span class=lt>∙∙∙∙+</span>
<span class=lt>│∙</span>∙∙∙<span class=lt>∙∙+∙</span>
<span class=lt>│∙∙∙∙∙+∙∙</span>
│∙∙∙∙<span class=lt>+∙∙@</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌</span>─────<span class=lt>─</span>──
│<span class=lt>∙</span>∙∙∙∙∙<span class=lt>∙</span>∙
│∙<span class=lt>∙</span>∙∙∙∙<span class=lt>∙</span>∙
│∙∙<span class=lt>∙</span>∙∙∙<span class=lt>∙</span>∙
│∙∙∙<span class=lt>∙</span>∙∙<span class=lt>∙</span>∙
│∙∙∙∙<span class=lt>∙</span>∙<span class=lt>∙+</span>
<span class=lt>│</span>∙∙∙∙∙<span class=lt>∙+∙</span>
│<span class=lt>∙∙∙∙∙+∙∙</span>
│∙∙∙∙<span class=lt>+∙∙@</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌──</span>───<span class=lt>──</span>─
<span class=lt>│∙∙∙</span>∙∙<span class=lt>∙∙</span>∙
<span class=lt>│∙∙∙∙</span>∙<span class=lt>∙∙</span>∙
│<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙</span>∙
│∙<span class=lt>∙∙∙∙</span>∙<span class=lt>∙</span>∙
│∙∙<span class=lt>∙∙∙∙∙+</span>
<span class=lt>│∙∙</span>∙∙<span class=lt>∙∙+∙</span>
<span class=lt>│∙∙∙∙∙+∙∙</span>
│∙∙∙∙<span class=lt>+∙∙@</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌──</span>───<span class=lt>──</span>─
<span class=lt>│∙∙∙</span>∙∙<span class=lt>∙∙</span>∙
<span class=lt>│∙∙∙</span>∙∙∙<span class=lt>∙</span>∙
│<span class=lt>∙∙∙∙</span>∙∙<span class=lt>∙</span>∙
│∙∙<span class=lt>∙∙∙</span>∙<span class=lt>∙</span>∙
│∙∙∙<span class=lt>∙∙∙∙+</span>
<span class=lt>│∙</span>∙∙∙<span class=lt>∙∙+∙</span>
<span class=lt>│∙∙∙∙∙+∙∙</span>
│∙∙∙∙<span class=lt>+∙∙@</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌───</span>─<span class=lt>───</span>─
<span class=lt>│∙∙∙∙∙∙∙</span>∙
<span class=lt>│∙∙∙∙</span>∙<span class=lt>∙∙</span>∙
<span class=lt>│∙∙∙∙∙∙∙</span>∙
│<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙</span>∙
<span class=lt>│∙</span>∙<span class=lt>∙∙∙∙∙+</span>
<span class=lt>│∙∙∙</span>∙<span class=lt>∙∙+∙</span>
<span class=lt>│∙∙∙∙∙+∙∙</span>
│∙∙∙∙<span class=lt>+∙∙@</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
</div> 
<a name=cmprooms></a>
<h4>Rooms</h4>
<p>
<div class=sshotc>
<pre class=sshot> ┌─<span class=lt>──</span>────────┐
 │<span class=lt>∙∙</span>∙∙∙∙∙∙∙∙∙│
┌┘<span class=lt>∙──┬</span>─────┐∙│
┤<span class=lt>∙∙∙∙│</span>     │∙│
<span class=lt>┘∙∙∙∙│</span>     │∙│
<span class=lt>@∙∙∙∙└</span>───┐ │∙│
<span class=lt>┐∙∙∙∙∙∙∙∙└</span>─┘∙│
│<span class=lt>∙∙∙∙┌─┐∙∙∙∙∙│</span>
│∙<span class=lt>∙∙∙│</span> └────<span class=lt>─┘</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot> ┌───────────┐
 │∙∙∙∙∙∙∙∙∙∙∙│
┌┘∙<span class=lt>──┬</span>─────┐∙│
┤∙<span class=lt>∙∙∙│</span>     │∙│
<span class=lt>┘∙∙∙∙│</span>     │∙│
<span class=lt>@∙∙∙∙└</span>───┐ │∙│
<span class=lt>┐∙∙∙∙∙∙∙∙└</span>─┘∙│
│∙<span class=lt>∙∙∙┌─┐∙∙∙∙∙│</span>
│∙∙<span class=lt>∙∙│</span> └─────<span class=lt>┘</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot> ┌<span class=lt>───</span>────────┐
 │<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙∙│
┌<span class=lt>┘∙──┬</span>─────┐∙│
┤<span class=lt>∙∙∙∙│</span>     │∙│
<span class=lt>┘∙∙∙∙│</span>     │∙│
<span class=lt>@∙∙∙∙└</span>───┐ │∙│
<span class=lt>┐∙∙∙∙∙∙∙∙└</span>─┘∙│
│<span class=lt>∙∙∙∙┌─┐∙∙∙∙∙│</span>
│<span class=lt>∙∙∙∙│</span> └────<span class=lt>─┘</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot> ┌<span class=lt>───</span>────────┐
 │<span class=lt>∙∙</span>∙∙∙∙∙∙∙∙∙│
┌┘<span class=lt>∙──┬</span>─────┐∙│
┤<span class=lt>∙∙∙∙│</span>     │∙│
<span class=lt>┘∙∙∙∙│</span>     │∙│
<span class=lt>@∙∙∙∙└</span>───┐ │∙│
<span class=lt>┐∙∙∙∙∙∙∙∙└</span>─┘∙│
│<span class=lt>∙∙∙∙┌─┐∙∙∙∙∙│</span>
│∙<span class=lt>∙∙∙│</span> └────<span class=lt>─┘</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot> ┌<span class=lt>──</span>─────────┐
 │<span class=lt>∙∙</span>∙∙∙∙∙∙∙∙∙│
┌<span class=lt>┘∙──┬</span>─────┐∙│
┤<span class=lt>∙∙∙∙│</span>     │∙│
<span class=lt>┘∙∙∙∙│</span>     │∙│
<span class=lt>@∙∙∙∙└</span>───┐ │∙│
<span class=lt>┐∙∙∙∙∙∙∙∙└</span>─┘∙│
│<span class=lt>∙∙∙∙┌─┐∙∙∙∙∙│</span>
│<span class=lt>∙∙∙∙│</span> └───<span class=lt>──┘</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>│   ┌─────────<span class=lt>──┐</span>
│   │∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>│
│  ┌┘∙──┬─────<span class=lt>┐∙│</span>
└─┬┤∙∙∙∙│     <span class=lt>│∙│</span>
∙∙└┘∙∙∙∙│     <span class=lt>│∙│</span>
<span class=lt>┐∙∙∙∙∙</span>∙∙└───┐ <span class=lt>│∙│</span>
└──<span class=lt>┐∙∙∙∙∙∙∙∙└─┘∙│</span>
   │∙∙∙∙┌─<span class=lt>┐∙∙∙∙@│</span>
   │∙∙∙∙│ <span class=lt>└─────┘</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>│   ┌─────────<span class=lt>──┐</span>
│   │∙∙∙∙∙∙∙∙∙<span class=lt>∙∙│</span>
│  ┌┘∙──┬─────<span class=lt>┐∙│</span>
└─┬┤∙∙∙∙│     <span class=lt>│∙│</span>
∙∙└┘∙∙∙∙│     <span class=lt>│∙│</span>
<span class=lt>┐∙∙∙∙</span>∙∙∙└───┐ <span class=lt>│∙│</span>
└──<span class=lt>┐∙∙∙∙∙∙∙∙└─┘∙│</span>
   │∙∙∙∙┌─<span class=lt>┐∙∙∙∙@│</span>
   │∙∙∙∙│ <span class=lt>└─────┘</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>│   ┌─────────<span class=lt>──┐</span>
│   │∙∙∙∙∙∙∙∙∙<span class=lt>∙∙│</span>
│  ┌┘∙──┬─────<span class=lt>┐∙│</span>
└─┬┤∙∙∙∙│     <span class=lt>│∙│</span>
<span class=lt>∙</span>∙└┘∙∙∙∙│     <span class=lt>│∙│</span>
<span class=lt>┐∙∙∙∙∙∙</span>∙└───┐ <span class=lt>│∙│</span>
└──<span class=lt>┐∙∙∙∙∙∙∙∙└─┘∙│</span>
   │∙∙∙∙┌─<span class=lt>┐∙∙∙∙@│</span>
   │∙∙∙∙│ <span class=lt>└─────┘</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>│   ┌─────────<span class=lt>──┐</span>
│   │∙∙∙∙∙∙∙∙∙∙<span class=lt>∙│</span>
│  ┌┘∙──┬─────<span class=lt>┐∙│</span>
└─┬┤∙∙∙∙│     <span class=lt>│∙│</span>
∙∙└┘∙∙∙∙│     <span class=lt>│∙│</span>
<span class=lt>┐∙∙∙∙</span>∙∙∙└───┐ <span class=lt>│∙│</span>
└──<span class=lt>┐∙∙∙∙∙∙∙</span>∙<span class=lt>└─┘∙│</span>
   │∙∙∙∙┌─<span class=lt>┐∙∙∙∙@│</span>
   │∙∙∙∙│ <span class=lt>└─────┘</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>│   ┌─────────<span class=lt>──┐</span>
│   │∙∙∙∙∙∙∙∙∙<span class=lt>∙∙│</span>
│  ┌┘∙──┬─────<span class=lt>┐∙│</span>
└─┬┤∙∙∙∙│     <span class=lt>│∙│</span>
<span class=lt>∙∙└┘∙</span>∙∙∙│     <span class=lt>│∙│</span>
<span class=lt>┐∙∙∙∙∙∙∙└</span>───┐ <span class=lt>│∙│</span>
└──<span class=lt>┐∙∙∙∙∙∙∙∙└─┘∙│</span>
   │∙∙∙∙┌─<span class=lt>┐∙∙∙∙@│</span>
   │∙∙∙∙│ <span class=lt>└─────┘</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>──────</span>─<span class=lt>─┬</span>
<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙</span>│
<span class=lt>∙∙∙∙</span>∙<span class=lt>∙∙</span>∙│
<span class=lt>∙∙∙+∙│</span>∙∙│
<span class=lt>∙∙∙∙∙│∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙└</span>
<span class=lt>@∙∙∙│</span>∙∙∙∙
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>──────</span>──<span class=lt>┬</span>
<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙</span>│
<span class=lt>∙∙∙∙</span>∙<span class=lt>∙∙</span>∙│
<span class=lt>∙∙∙+∙│</span>∙∙│
<span class=lt>∙∙∙∙∙│∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙└</span>
<span class=lt>@∙∙∙│</span>∙∙∙∙
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>──────</span>─<span class=lt>─┬</span>
<span class=lt>∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙</span>∙│
<span class=lt>∙∙∙+∙│</span>∙∙│
<span class=lt>∙∙∙∙∙│∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙└</span>
<span class=lt>@∙∙∙│</span>∙∙∙∙
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>──────</span>─<span class=lt>─┬</span>
<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙│</span>
<span class=lt>∙∙∙∙</span>∙<span class=lt>∙∙</span>∙│
<span class=lt>∙∙∙+∙│</span>∙∙│
<span class=lt>∙∙∙∙∙│∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙└</span>
<span class=lt>@∙∙∙│</span>∙∙∙∙
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>─────</span>───┬
<span class=lt>∙∙∙∙∙</span>∙∙∙│
<span class=lt>∙∙∙∙</span>∙∙∙∙│
<span class=lt>∙∙∙+∙│</span>∙∙│
<span class=lt>∙∙∙∙∙│∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙└</span>
<span class=lt>@∙∙∙│</span>∙∙∙∙
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>─<span class=lt>───</span>─┬
∙<span class=lt>∙∙</span>∙∙│
∙<span class=lt>∙∙</span>∙∙<span class=lt>│</span>
<span class=lt>+∙│</span>∙<span class=lt>∙│</span>
<span class=lt>∙∙│∙∙</span>│
<span class=lt>∙∙∙</span>∙∙└
<span class=lt>@│</span>∙∙∙∙
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>─<span class=lt>───</span>─┬
∙<span class=lt>∙∙</span>∙∙│
∙<span class=lt>∙∙</span>∙∙│
<span class=lt>+∙│</span>∙∙│
<span class=lt>∙∙│</span>∙∙│
<span class=lt>∙∙</span>∙∙∙└
<span class=lt>@│</span>∙∙∙∙
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>─<span class=lt>───</span>─┬
∙<span class=lt>∙∙∙</span>∙│
∙<span class=lt>∙∙</span>∙∙<span class=lt>│</span>
<span class=lt>+∙│∙∙│</span>
<span class=lt>∙∙│∙∙│</span>
<span class=lt>∙∙∙∙</span>∙└
<span class=lt>@│</span>∙∙∙∙
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>─<span class=lt>───</span>─┬
∙<span class=lt>∙∙</span>∙∙│
∙<span class=lt>∙∙</span>∙∙│
<span class=lt>+∙│</span>∙<span class=lt>∙│</span>
<span class=lt>∙∙│∙∙│</span>
<span class=lt>∙∙∙</span>∙∙└
<span class=lt>@│</span>∙∙∙∙
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>─<span class=lt>───</span>─┬
∙<span class=lt>∙∙∙</span>∙│
∙<span class=lt>∙∙</span>∙∙│
<span class=lt>+∙│</span>∙∙<span class=lt>│</span>
<span class=lt>∙∙│∙∙│</span>
<span class=lt>∙∙∙∙∙└</span>
<span class=lt>@│</span>∙∙∙∙
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─┐</span>   
<span class=lt>│@└</span>──┐
<span class=lt>│∙∙∙</span>∙│
<span class=lt>└──┐∙│</span>
   │∙<span class=lt>│</span>
   │∙└
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─┐</span>   
<span class=lt>│@└</span>──┐
<span class=lt>│∙∙</span>∙∙│
<span class=lt>└──┐</span>∙│
   │∙│
   │∙└
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─┐</span>   
<span class=lt>│@└</span>──┐
<span class=lt>│∙∙∙∙</span>│
<span class=lt>└──┐∙│</span>
   │<span class=lt>∙│</span>
   │∙└
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─┐</span>   
<span class=lt>│@└</span>──┐
<span class=lt>│∙∙∙</span>∙│
<span class=lt>└──┐∙│</span>
   │∙<span class=lt>│</span>
   │∙└
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─┐</span>   
<span class=lt>│@└</span>──┐
<span class=lt>│∙∙∙∙│</span>
<span class=lt>└──┐∙│</span>
   │∙│
   │∙└
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─┘∙</span>└┬─┐
<span class=lt>│∙∙∙</span>∙│<span class=lt>∙│</span>
<span class=lt>│∙∙+∙∙∙│</span>
<span class=lt>│∙@∙∙∙∙│</span>
<span class=lt>└─┬+┬──┘</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─┘∙</span>└┬─┐
<span class=lt>│∙∙∙</span>∙│∙<span class=lt>│</span>
<span class=lt>│∙∙+∙∙∙│</span>
<span class=lt>│∙@∙∙∙∙│</span>
<span class=lt>└─┬+┬──┘</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─┘∙└</span>┬─<span class=lt>┐</span>
<span class=lt>│∙∙∙</span>∙<span class=lt>│∙│</span>
<span class=lt>│∙∙+∙∙∙│</span>
<span class=lt>│∙@∙∙∙∙│</span>
<span class=lt>└─┬+┬──┘</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─┘∙└</span>┬─┐
<span class=lt>│∙∙∙</span>∙│<span class=lt>∙│</span>
<span class=lt>│∙∙+∙∙∙│</span>
<span class=lt>│∙@∙∙∙∙│</span>
<span class=lt>└─┬+┬──┘</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─┘∙└</span>┬─┐
<span class=lt>│∙∙∙</span>∙<span class=lt>│∙│</span>
<span class=lt>│∙∙+∙∙∙│</span>
<span class=lt>│∙@∙∙∙∙│</span>
<span class=lt>└─┬+┬──┘</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>┌─┘∙└<span class=lt>┬─┐</span>
│∙∙∙∙<span class=lt>│@│</span>
│∙∙+<span class=lt>∙∙∙│</span>
│∙<span class=lt>∙∙∙∙∙│</span>
└<span class=lt>─┬+┬──┘</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>┌─┘∙└<span class=lt>┬─┐</span>
│∙∙∙∙<span class=lt>│@│</span>
│∙∙+∙<span class=lt>∙∙│</span>
│∙∙∙<span class=lt>∙∙∙│</span>
└─┬<span class=lt>+┬──┘</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>┌─┘∙└<span class=lt>┬─┐</span>
│∙∙∙∙<span class=lt>│@│</span>
│∙∙<span class=lt>+∙∙∙│</span>
│<span class=lt>∙∙∙∙∙∙│</span>
<span class=lt>└─┬+┬──┘</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>┌─┘∙└<span class=lt>┬─┐</span>
│∙∙∙∙<span class=lt>│@│</span>
│∙∙+<span class=lt>∙∙∙│</span>
│∙<span class=lt>∙∙∙∙∙│</span>
└<span class=lt>─┬+┬──┘</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>┌─┘∙└<span class=lt>┬─┐</span>
│∙∙∙∙<span class=lt>│@│</span>
│∙∙<span class=lt>+∙∙∙│</span>
│<span class=lt>∙∙∙∙∙∙│</span>
└<span class=lt>─┬+┬──┘</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>│@└</span>─────────┐
<span class=lt>│∙∙∙</span>∙∙∙∙∙∙∙∙│
<span class=lt>├───∙─</span>──────┤
│∙∙∙∙<span class=lt>∙∙</span>∙∙∙∙∙│
│∙∙∙∙∙<span class=lt>+∙</span>+∙∙∙│
│∙∙∙∙∙∙∙<span class=lt>∙∙</span>∙∙│
│∙∙∙∙∙∙∙∙│<span class=lt>∙┌</span>┤
└────────┴─<span class=lt>┴</span>┘
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>│@└</span>─────────┐
<span class=lt>│∙∙</span>∙∙∙∙∙∙∙∙∙│
<span class=lt>├───</span>∙───────┤
│∙∙∙∙∙∙∙∙∙∙∙│
│∙∙∙∙∙+∙+∙∙∙│
│∙∙∙∙∙∙∙∙∙∙∙│
│∙∙∙∙∙∙∙∙│∙┌┤
└────────┴─┴┘
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>│@└</span>─────────┐
<span class=lt>│∙∙∙∙</span>∙∙∙∙∙∙∙│
<span class=lt>├───∙─</span>──────┤
│∙∙∙<span class=lt>∙∙∙∙</span>∙∙∙∙│
│∙∙∙∙∙<span class=lt>+∙+</span>∙∙∙│
│∙∙∙∙∙∙<span class=lt>∙∙∙∙</span>∙│
│∙∙∙∙∙∙∙∙<span class=lt>│∙┌</span>┤
└────────┴<span class=lt>─┴</span>┘
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>│@└</span>─────────┐
<span class=lt>│∙∙∙</span>∙∙∙∙∙∙∙∙│
<span class=lt>├───∙─</span>──────┤
│∙∙∙∙<span class=lt>∙∙</span>∙∙∙∙∙│
│∙∙∙∙∙<span class=lt>+∙+</span>∙∙∙│
│∙∙∙∙∙∙∙<span class=lt>∙∙</span>∙∙│
│∙∙∙∙∙∙∙∙<span class=lt>│∙┌</span>┤
└────────┴<span class=lt>─┴</span>┘
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>│@└</span>─────────┐
<span class=lt>│∙∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>├───∙───────┤</span>
│∙∙∙∙∙∙∙∙∙∙∙│
│∙∙∙∙∙+∙+∙∙∙│
│∙∙∙∙∙∙∙∙∙∙∙│
│∙∙∙∙∙∙∙∙│∙┌┤
└────────┴─┴┘
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>│∙│          
<span class=lt>│∙└</span>─────────┐
│∙<span class=lt>∙∙</span>∙∙∙∙∙∙∙∙│
├───<span class=lt>∙─</span>─<span class=lt>─────┤</span>
│∙∙∙∙<span class=lt>∙∙</span>∙<span class=lt>∙∙∙∙│</span>
│∙∙∙∙∙<span class=lt>+∙+∙∙∙│</span>
│∙∙∙∙∙∙∙<span class=lt>∙∙∙∙│</span>
│∙∙∙∙∙∙∙∙<span class=lt>│@┌</span>┤
└────────<span class=lt>┴─┴</span>┘
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>│∙│          
│∙└─────────┐
│∙∙∙∙∙∙∙∙∙∙∙│
├───∙──<span class=lt>─────┤</span>
│∙∙∙∙∙∙∙<span class=lt>∙∙∙∙│</span>
│∙∙∙∙∙+∙<span class=lt>+∙∙∙│</span>
│∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>│
│∙∙∙∙∙∙∙∙<span class=lt>│@┌</span>┤
└────────<span class=lt>┴─┴</span>┘
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>│∙</span>│          
<span class=lt>│∙└</span>─────────┐
│<span class=lt>∙∙∙∙</span>∙∙∙∙∙∙∙│
├──<span class=lt>─∙─</span>─<span class=lt>─────┤</span>
│∙∙∙<span class=lt>∙∙∙∙∙∙∙∙│</span>
│∙∙∙∙∙<span class=lt>+∙+∙∙∙│</span>
│∙∙∙∙∙∙<span class=lt>∙∙∙∙∙│</span>
│∙∙∙∙∙∙∙∙<span class=lt>│@┌</span>┤
└────────<span class=lt>┴─┴</span>┘
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>│</span>∙│          
<span class=lt>│∙└</span>─────────┐
│∙<span class=lt>∙∙</span>∙∙∙∙∙∙∙∙│
├──<span class=lt>─∙─</span>─<span class=lt>─────┤</span>
│∙∙∙∙<span class=lt>∙∙</span>∙<span class=lt>∙∙∙∙│</span>
│∙∙∙∙∙<span class=lt>+∙+∙∙∙│</span>
│∙∙∙∙∙∙∙<span class=lt>∙∙∙∙│</span>
│∙∙∙∙∙∙∙∙<span class=lt>│@┌</span>┤
└────────<span class=lt>┴─┴</span>┘
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>│∙│          
│∙└─────────┐
│∙∙∙∙∙∙∙∙∙∙∙│
├───∙───<span class=lt>────┤</span>
<span class=lt>│∙</span>∙∙∙∙∙∙<span class=lt>∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙+∙+∙∙∙│</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙∙∙│</span>
│∙∙∙∙∙∙∙∙<span class=lt>│@┌</span>┤
└────────<span class=lt>┴─┴</span>┘
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>────────
∙∙∙∙∙∙∙∙
┬<span class=lt>─</span>∙┌┬───
┘∙<span class=lt>∙└</span>┤   
∙∙<span class=lt>│∙└</span>┐  
∙┌┴<span class=lt>┐∙└</span>┐ 
┌┘ └<span class=lt>┐∙└┐</span>
┘   └<span class=lt>┐@│</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>────────
∙∙∙∙∙∙∙∙
┬<span class=lt>─</span>∙┌┬───
┘∙<span class=lt>∙</span>└┤   
∙∙│<span class=lt>∙</span>└┐  
∙┌┴┐<span class=lt>∙</span>└┐ 
┌┘ └┐<span class=lt>∙└┐</span>
┘   └<span class=lt>┐@│</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>─</span>───────
<span class=lt>∙∙</span>∙∙∙∙∙∙
<span class=lt>┬─∙</span>┌┬───
┘<span class=lt>∙∙└</span>┤   
∙∙<span class=lt>│∙└</span>┐  
∙┌┴<span class=lt>┐∙└</span>┐ 
┌┘ └<span class=lt>┐∙└┐</span>
┘   └<span class=lt>┐@│</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>─</span>───────
∙<span class=lt>∙</span>∙∙∙∙∙∙
┬<span class=lt>─∙</span>┌┬───
┘<span class=lt>∙∙└</span>┤   
∙∙<span class=lt>│∙└</span>┐  
∙┌┴<span class=lt>┐∙└</span>┐ 
┌┘ └<span class=lt>┐∙└┐</span>
┘   └<span class=lt>┐@│</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>────────
∙∙∙∙∙∙∙∙
┬<span class=lt>─</span>∙┌┬───
┘∙<span class=lt>∙</span>└┤   
∙∙│<span class=lt>∙</span>└┐  
∙┌┴┐<span class=lt>∙└</span>┐ 
┌┘ └<span class=lt>┐∙└┐</span>
┘   └<span class=lt>┐@│</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<div id=lhContainer2>
<a name=cmppillar></a>
<h4>Pillars</h4>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙
<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙
<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙∙
<span class=lt>@+</span>∙∙∙∙∙∙∙∙∙
<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙∙
<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙
<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙
<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙</span>∙∙∙∙∙
<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙
<span class=lt>∙∙∙∙</span>∙∙∙∙∙∙∙
<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙∙
<span class=lt>∙∙</span>∙∙∙∙∙∙∙∙∙
<span class=lt>@+</span>∙∙∙∙∙∙∙∙∙
<span class=lt>∙∙</span>∙∙∙∙∙∙∙∙∙
<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙∙
<span class=lt>∙∙∙∙</span>∙∙∙∙∙∙∙
<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙
<span class=lt>∙∙∙∙∙∙</span>∙∙∙∙∙
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙</span>∙
<span class=lt>∙∙∙∙∙∙∙∙</span>∙∙∙
<span class=lt>∙∙∙∙∙∙</span>∙∙∙∙∙
<span class=lt>∙∙∙∙</span>∙∙∙∙∙∙∙
<span class=lt>@+</span>∙∙∙∙∙∙∙∙∙
<span class=lt>∙∙∙∙</span>∙∙∙∙∙∙∙
<span class=lt>∙∙∙∙∙∙</span>∙∙∙∙∙
<span class=lt>∙∙∙∙∙∙∙∙</span>∙∙∙
<span class=lt>∙∙∙∙∙∙∙∙∙∙</span>∙
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙
<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙
<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙∙
<span class=lt>@+</span>∙∙∙∙∙∙∙∙∙
<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙∙
<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙
<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙
<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>@+</span>∙∙∙∙∙∙∙∙∙
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>┌────<span class=lt>──────</span>
│∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>
│∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>
│∙∙∙∙∙∙<span class=lt>∙∙∙∙</span>
│∙∙∙∙∙∙<span class=lt>∙∙∙∙</span>
<span class=lt>│</span>∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>
<span class=lt>│∙∙</span>∙∙∙∙∙<span class=lt>∙∙∙</span>
<span class=lt>│∙∙∙∙</span>∙∙∙∙<span class=lt>∙∙</span>
<span class=lt>│∙∙∙∙∙∙</span>∙∙<span class=lt>∙∙</span>
<span class=lt>│∙∙∙∙∙∙∙∙┼∙</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙@</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>┌──────<span class=lt>────</span>
│∙∙∙∙∙∙<span class=lt>∙∙∙∙</span>
│∙∙∙∙∙∙<span class=lt>∙∙∙∙</span>
│∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>
│∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>
│∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>
│∙∙∙∙∙∙∙∙<span class=lt>∙∙</span>
<span class=lt>│∙∙</span>∙∙∙∙∙∙<span class=lt>∙∙</span>
<span class=lt>│∙∙∙∙∙</span>∙∙∙<span class=lt>∙∙</span>
<span class=lt>│∙∙∙∙∙∙∙∙┼∙</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙@</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>┌────<span class=lt>──────</span>
│∙∙∙∙<span class=lt>∙∙∙∙∙∙</span>
│∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>
│∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>
│∙∙∙∙∙∙<span class=lt>∙∙∙∙</span>
<span class=lt>│∙</span>∙∙∙∙∙<span class=lt>∙∙∙∙</span>
<span class=lt>│∙∙∙</span>∙∙∙∙<span class=lt>∙∙∙</span>
<span class=lt>│∙∙∙∙∙</span>∙∙<span class=lt>∙∙∙</span>
<span class=lt>│∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙</span>
<span class=lt>│∙∙∙∙∙∙∙∙┼∙</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙@</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>┌────<span class=lt>──────</span>
│∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>
│∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>
│∙∙∙∙∙∙<span class=lt>∙∙∙∙</span>
│∙∙∙∙∙∙<span class=lt>∙∙∙∙</span>
<span class=lt>│</span>∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>
<span class=lt>│∙∙</span>∙∙∙∙∙<span class=lt>∙∙∙</span>
<span class=lt>│∙∙∙∙</span>∙∙∙∙<span class=lt>∙∙</span>
<span class=lt>│∙∙∙∙∙∙</span>∙∙<span class=lt>∙∙</span>
<span class=lt>│∙∙∙∙∙∙∙∙┼∙</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙@</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>┌─<span class=lt>─────────</span>
│∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>
<span class=lt>│∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙</span>
<span class=lt>│∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙</span>
<span class=lt>│∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙</span>
<span class=lt>│∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>
<span class=lt>│∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙</span>
<span class=lt>│∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙</span>
<span class=lt>│∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙</span>
<span class=lt>│∙∙∙∙∙∙∙∙┼∙</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙@</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙+</span>∙<span class=lt>∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙</span>∙∙∙
<span class=lt>∙∙∙∙∙+∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙+∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙</span>∙∙∙
<span class=lt>∙∙∙∙∙+</span>∙∙<span class=lt>∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙</span>∙
<span class=lt>∙∙∙∙∙+∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>∙
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙<span class=lt>∙</span>
<span class=lt>∙∙∙∙∙∙∙∙+∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙<span class=lt>∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙+∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>∙
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙+∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>∙∙
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙∙<span class=lt>∙</span>
<span class=lt>∙∙∙∙∙∙∙∙+</span>∙<span class=lt>∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙+∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─</span>───<span class=lt>───────────</span>───<span class=lt>─┐</span>
<span class=lt>│∙∙</span>∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙<span class=lt>∙∙│</span>
<span class=lt>│∙∙∙</span>∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙<span class=lt>∙∙∙│</span>
<span class=lt>│∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙│</span>
┤<span class=lt>∙∙∙∙∙∙∙+∙∙∙+∙∙∙∙∙∙∙</span>│
│∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙∙├
┤∙∙∙∙∙∙∙<span class=lt>+∙@∙+</span>∙∙∙∙∙∙∙│
│∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙∙├
│<span class=lt>∙∙∙∙∙∙∙+∙∙∙+∙∙∙∙∙∙∙</span>│
<span class=lt>│∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙│</span>
<span class=lt>│∙∙∙</span>∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙<span class=lt>∙∙∙│</span>
<span class=lt>│∙∙</span>∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙<span class=lt>∙∙│</span>
<span class=lt>┴─</span>───<span class=lt>───────────</span>───<span class=lt>─┴</span>
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>┌─────<span class=lt>─────────</span>─────┐
<span class=lt>│∙</span>∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙∙<span class=lt>∙│</span>
<span class=lt>│∙∙</span>∙∙∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙<span class=lt>∙∙│</span>
<span class=lt>│∙∙∙∙</span>∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙∙<span class=lt>∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙│</span>
┤∙∙<span class=lt>∙∙∙∙∙+∙∙∙+∙∙∙∙∙</span>∙∙│
│∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙∙∙├
┤∙∙∙∙∙∙∙<span class=lt>+∙@∙+</span>∙∙∙∙∙∙∙│
│∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙∙∙├
│∙∙<span class=lt>∙∙∙∙∙+∙∙∙+∙∙∙∙∙</span>∙∙│
<span class=lt>│∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙</span>∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙∙<span class=lt>∙∙∙∙│</span>
<span class=lt>│∙∙</span>∙∙∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙<span class=lt>∙∙│</span>
<span class=lt>│∙</span>∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙∙<span class=lt>∙│</span>
┴─────<span class=lt>─────────</span>─────┴
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─</span>───<span class=lt>───────────</span>───<span class=lt>─┐</span>
<span class=lt>│∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙│</span>
<span class=lt>│∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>┤∙∙∙∙∙∙∙+∙∙∙+∙∙∙∙∙∙∙│</span>
│∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙├
┤∙∙∙∙∙∙∙<span class=lt>+∙@∙+</span>∙∙∙∙∙∙∙│
│∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙├
<span class=lt>│∙∙∙∙∙∙∙+∙∙∙+∙∙∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙│</span>
<span class=lt>│∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙│</span>
<span class=lt>┴─</span>───<span class=lt>───────────</span>───<span class=lt>─┴</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌─</span>───<span class=lt>───────────</span>───<span class=lt>─┐</span>
<span class=lt>│∙∙</span>∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙<span class=lt>∙∙│</span>
<span class=lt>│∙∙∙</span>∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙<span class=lt>∙∙∙│</span>
<span class=lt>│∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙│</span>
<span class=lt>┤∙∙∙∙∙∙∙+∙∙∙+∙∙∙∙∙∙∙│</span>
│∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙∙├
┤∙∙∙∙∙∙∙<span class=lt>+∙@∙+</span>∙∙∙∙∙∙∙│
│∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙∙├
<span class=lt>│∙∙∙∙∙∙∙+∙∙∙+∙∙∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙│</span>
<span class=lt>│∙∙∙</span>∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙<span class=lt>∙∙∙│</span>
<span class=lt>│∙∙</span>∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙<span class=lt>∙∙│</span>
<span class=lt>┴─</span>───<span class=lt>───────────</span>───<span class=lt>─┴</span>
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>┌──</span>──<span class=lt>───────────</span>──<span class=lt>──┐</span>
<span class=lt>│∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙│</span>
<span class=lt>│∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙│</span>
<span class=lt>┤∙∙∙∙∙∙∙+∙∙∙+∙∙∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙├</span>
┤∙∙∙∙∙∙∙<span class=lt>+∙@∙+</span>∙∙∙∙∙∙∙│
<span class=lt>│∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>│∙∙∙∙∙∙∙+∙∙∙+∙∙∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙│</span>
<span class=lt>│∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙∙│</span>
<span class=lt>│∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙<span class=lt>∙∙∙│</span>
<span class=lt>┴──</span>──<span class=lt>───────────</span>──<span class=lt>──┴</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot><span class=lt>───</span>───<span class=lt>────</span>────┐
<span class=lt>∙∙</span>∙∙∙<span class=lt>∙∙∙∙</span>∙∙∙∙∙│
<span class=lt>∙∙+</span>∙<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙│
<span class=lt>∙∙∙∙∙∙</span>∙∙∙∙∙∙∙∙│
<span class=lt>∙∙+∙∙</span>∙∙∙∙∙∙<span class=lt>∙∙∙│</span>
<span class=lt>∙∙∙∙</span>∙∙∙<span class=lt>∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙+</span>
<span class=lt>∙∙+∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>∙∙∙∙</span>∙∙∙<span class=lt>∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙∙</span>∙∙∙∙∙∙<span class=lt>∙∙∙│</span>
<span class=lt>∙∙∙∙∙∙</span>∙∙∙∙∙∙∙∙│
<span class=lt>∙∙+</span>∙<span class=lt>∙∙∙∙</span>∙∙∙∙∙∙│
<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙∙∙</span>∙∙∙∙∙│
<span class=lt>───</span>───<span class=lt>────</span>────┤
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>───</span>────<span class=lt>─</span>──────┐
<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙∙∙∙∙∙∙│
<span class=lt>∙∙+</span>∙∙<span class=lt>∙</span>∙∙∙∙∙∙∙∙│
<span class=lt>∙∙∙</span>∙<span class=lt>∙</span>∙∙∙∙∙∙∙∙∙│
<span class=lt>∙∙+∙</span>∙∙∙∙∙∙∙∙∙<span class=lt>∙│</span>
<span class=lt>∙∙∙</span>∙∙∙∙∙<span class=lt>∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙+</span>
<span class=lt>∙∙+∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>∙∙∙</span>∙∙∙∙∙<span class=lt>∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙</span>∙∙∙∙∙∙∙∙∙<span class=lt>∙│</span>
<span class=lt>∙∙∙</span>∙<span class=lt>∙</span>∙∙∙∙∙∙∙∙∙│
<span class=lt>∙∙+</span>∙∙<span class=lt>∙</span>∙∙∙∙∙∙∙∙│
<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙∙∙∙∙∙∙│
<span class=lt>───</span>────<span class=lt>─</span>──────┤
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>───────────</span>───┐
<span class=lt>∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>∙∙∙∙│
<span class=lt>∙∙+∙∙∙∙∙</span>∙∙∙∙∙∙│
<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙∙∙∙<span class=lt>│</span>
<span class=lt>∙∙+∙∙∙</span>∙∙∙∙<span class=lt>∙∙∙∙│</span>
<span class=lt>∙∙∙∙</span>∙∙<span class=lt>∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙+</span>
<span class=lt>∙∙+∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>∙∙∙∙</span>∙∙<span class=lt>∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙∙∙</span>∙∙∙∙<span class=lt>∙∙∙∙│</span>
<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙∙∙∙<span class=lt>│</span>
<span class=lt>∙∙+∙∙∙∙∙</span>∙∙∙∙∙∙│
<span class=lt>∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙</span>∙∙∙∙│
<span class=lt>───────────</span>───┤
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>───</span>──<span class=lt>─────</span>────┐
<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙∙∙</span>∙∙∙∙∙│
<span class=lt>∙∙+</span>∙<span class=lt>∙∙∙∙</span>∙∙∙∙∙∙│
<span class=lt>∙∙∙∙∙∙</span>∙∙∙∙∙∙∙∙│
<span class=lt>∙∙+∙∙</span>∙∙∙∙∙∙<span class=lt>∙∙∙│</span>
<span class=lt>∙∙∙∙</span>∙∙∙<span class=lt>∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙+</span>
<span class=lt>∙∙+∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>∙∙∙∙</span>∙∙∙<span class=lt>∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙∙</span>∙∙∙∙∙∙<span class=lt>∙∙∙│</span>
<span class=lt>∙∙∙∙∙∙</span>∙∙∙∙∙∙∙∙│
<span class=lt>∙∙+</span>∙<span class=lt>∙∙∙∙</span>∙∙∙∙∙∙│
<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙∙∙</span>∙∙∙∙∙│
<span class=lt>───</span>──<span class=lt>─────</span>────┤
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>───</span>────<span class=lt>─────</span>──┐
<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙∙∙∙∙∙</span>∙<span class=lt>∙│</span>
<span class=lt>∙∙+</span>∙∙<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙∙│</span>
<span class=lt>∙∙∙</span>∙<span class=lt>∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙│</span>
<span class=lt>∙∙+∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>@∙∙∙∙∙∙∙∙∙∙∙∙∙+</span>
<span class=lt>∙∙+∙∙∙∙∙∙∙∙∙∙∙├</span>
<span class=lt>∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙∙∙</span>∙<span class=lt>∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙∙</span>∙<span class=lt>∙∙∙∙</span>∙<span class=lt>∙∙∙∙∙│</span>
<span class=lt>∙∙+</span>∙∙<span class=lt>∙∙∙∙∙</span>∙<span class=lt>∙∙∙│</span>
<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙∙∙∙∙∙</span>∙<span class=lt>∙│</span>
<span class=lt>───</span>────<span class=lt>─────</span>──┤
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
∙∙+∙+<span class=lt>∙</span>+∙+∙∙
∙∙∙∙∙<span class=lt>∙</span>∙∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
<span class=lt>+∙+∙+∙+∙+∙+</span>
<span class=lt>∙∙∙∙∙@∙∙∙∙∙</span>
<span class=lt>+∙+∙+∙+∙+∙+</span>
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
∙∙+∙<span class=lt>+∙+</span>∙+∙∙
∙∙∙∙∙<span class=lt>∙</span>∙∙∙∙∙
+∙∙∙+<span class=lt>∙</span>+∙∙∙+
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
∙∙+∙<span class=lt>+∙+</span>∙+∙∙
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
<span class=lt>+∙+∙+∙+∙+∙+</span>
<span class=lt>∙∙∙∙∙@∙∙∙∙∙</span>
<span class=lt>+∙+∙+∙+∙+∙+</span>
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
∙∙+∙<span class=lt>+∙+</span>∙+∙∙
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>+<span class=lt>∙∙</span>∙<span class=lt>+∙+</span>∙<span class=lt>∙∙</span>+
∙∙<span class=lt>∙</span>∙<span class=lt>∙∙∙</span>∙<span class=lt>∙</span>∙∙
∙∙<span class=lt>+∙+∙+∙+</span>∙∙
∙∙∙<span class=lt>∙∙∙∙∙</span>∙∙∙
<span class=lt>+</span>∙∙<span class=lt>∙+∙+∙</span>∙∙<span class=lt>+</span>
<span class=lt>∙∙∙</span>∙<span class=lt>∙∙∙</span>∙<span class=lt>∙∙∙</span>
<span class=lt>+∙+∙+∙+∙+∙+</span>
<span class=lt>∙∙∙∙∙@∙∙∙∙∙</span>
<span class=lt>+∙+∙+∙+∙+∙+</span>
<span class=lt>∙∙∙</span>∙<span class=lt>∙∙∙</span>∙<span class=lt>∙∙∙</span>
<span class=lt>+</span>∙∙<span class=lt>∙+∙+∙</span>∙∙<span class=lt>+</span>
∙∙∙<span class=lt>∙∙∙∙∙</span>∙∙∙
∙∙<span class=lt>+∙+∙+∙+</span>∙∙
∙∙<span class=lt>∙</span>∙<span class=lt>∙∙∙</span>∙<span class=lt>∙</span>∙∙
+<span class=lt>∙∙</span>∙<span class=lt>+∙+</span>∙<span class=lt>∙∙</span>+
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙∙<span class=lt>∙</span>∙∙∙∙∙
∙∙+∙<span class=lt>+∙+</span>∙+∙∙
∙∙∙∙∙<span class=lt>∙</span>∙∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
<span class=lt>+</span>∙<span class=lt>+∙+∙+∙+</span>∙<span class=lt>+</span>
<span class=lt>∙∙∙∙∙@∙∙∙∙∙</span>
<span class=lt>+</span>∙<span class=lt>+∙+∙+∙+</span>∙<span class=lt>+</span>
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙∙<span class=lt>∙</span>∙∙∙∙∙
∙∙+∙<span class=lt>+∙+</span>∙+∙∙
∙∙∙∙∙<span class=lt>∙</span>∙∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
∙∙+∙<span class=lt>+∙+</span>∙+∙∙
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
<span class=lt>+∙+∙+∙+∙+∙+</span>
<span class=lt>∙∙∙∙∙@∙∙∙∙∙</span>
<span class=lt>+∙+∙+∙+∙+∙+</span>
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
∙∙+∙<span class=lt>+∙+</span>∙+∙∙
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
+∙∙∙<span class=lt>+∙+</span>∙∙∙+
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙+∙+∙+∙+</span>∙
<span class=lt>∙+∙+∙+∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙@∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙+∙+∙+∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙+∙+∙+∙+</span>∙
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙+∙+∙+∙+∙</span>
<span class=lt>∙+∙+∙+∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙@∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙+∙+∙+∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙+∙+∙+∙+∙</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙+∙+∙+∙+∙</span>
<span class=lt>∙+∙+∙+∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙@∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙+∙+∙+∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙+∙+∙+∙+∙</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙+∙+∙+</span>∙<span class=lt>+</span>∙
∙<span class=lt>+</span>∙<span class=lt>+</span>∙<span class=lt>+∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙@∙∙∙∙∙∙∙∙∙∙∙</span>
∙<span class=lt>+</span>∙<span class=lt>+</span>∙<span class=lt>+∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙+∙+∙+</span>∙<span class=lt>+</span>∙
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙+∙+∙+∙+∙</span>
<span class=lt>∙+∙+∙+∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙∙∙∙∙∙∙∙∙@∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>∙+∙+∙+∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙+∙+∙+∙+∙</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙
∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
∙∙∙∙∙+<span class=lt>∙+</span>∙<span class=lt>+∙+</span>∙<span class=lt>+∙</span>+∙∙∙∙∙
∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙∙∙∙
∙+∙+∙+∙<span class=lt>+∙+∙+∙+</span>∙+∙+∙+∙
∙∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙∙∙
∙∙∙∙∙∙∙∙∙<span class=lt>+@+</span>∙∙∙∙∙∙∙∙∙
∙∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙∙∙
∙+∙+∙+∙<span class=lt>+∙+∙+∙+</span>∙+∙+∙+∙
∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙∙∙∙
∙∙∙∙∙<span class=lt>+∙+</span>∙<span class=lt>+∙+</span>∙<span class=lt>+∙+</span>∙∙∙∙∙
∙∙∙∙<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙∙∙∙∙
∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙</span>+∙∙∙
</pre>
<div class=caption>Ray casting</div>
</div>
<div class=sshotc>
<pre class=sshot>∙∙∙+<span class=lt>∙</span>+∙∙∙<span class=lt>+∙+</span>∙∙∙+<span class=lt>∙</span>+∙∙∙
∙∙∙∙∙<span class=lt>∙</span>∙∙∙<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙∙∙∙∙
∙∙∙∙∙+<span class=lt>∙</span>+∙<span class=lt>+∙+</span>∙+<span class=lt>∙</span>+∙∙∙∙∙
∙∙∙∙∙∙∙<span class=lt>∙</span>∙<span class=lt>∙∙∙</span>∙<span class=lt>∙</span>∙∙∙∙∙∙∙
∙+∙+∙+∙+<span class=lt>∙+∙+∙</span>+∙+∙+∙+∙
∙∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙∙∙
∙∙∙∙∙∙∙∙∙<span class=lt>+@+</span>∙∙∙∙∙∙∙∙∙
∙∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙∙∙∙∙∙
∙+∙+∙+∙+<span class=lt>∙+∙+∙</span>+∙+∙+∙+∙
∙∙∙∙∙∙∙<span class=lt>∙</span>∙<span class=lt>∙∙∙</span>∙<span class=lt>∙</span>∙∙∙∙∙∙∙
∙∙∙∙∙+<span class=lt>∙</span>+∙<span class=lt>+∙+</span>∙+<span class=lt>∙</span>+∙∙∙∙∙
∙∙∙∙∙<span class=lt>∙</span>∙∙∙<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙∙∙∙∙
∙∙∙+<span class=lt>∙</span>+∙∙∙<span class=lt>+∙+</span>∙∙∙+<span class=lt>∙</span>+∙∙∙
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>∙</span>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>│</span>
<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙│</span>
∙∙<span class=lt>∙∙∙</span>∙<span class=lt>+∙+</span>∙<span class=lt>+∙+</span>∙<span class=lt>+∙+</span>∙<span class=lt>∙∙∙</span>∙│
∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙│
∙∙+∙+∙<span class=lt>+∙+∙+∙+∙+∙+</span>∙+∙+∙│
∙∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙∙∙∙│
∙∙∙∙∙∙∙∙∙∙<span class=lt>+@+</span>∙∙∙∙∙∙∙∙∙│
∙∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙</span>∙∙∙∙∙∙∙│
∙∙+∙+∙<span class=lt>+∙+∙+∙+∙+∙+</span>∙+∙+∙│
∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>∙∙∙│
∙∙<span class=lt>∙∙∙</span>∙<span class=lt>+∙+</span>∙<span class=lt>+∙+</span>∙<span class=lt>+∙+</span>∙<span class=lt>∙∙∙</span>∙│
<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙∙</span>∙∙<span class=lt>∙∙│</span>
<span class=lt>∙</span>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>│</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>∙∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙│
∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙│
∙∙∙∙∙∙<span class=lt>+∙+</span>∙<span class=lt>+∙+</span>∙<span class=lt>+∙+</span>∙∙∙∙∙│
∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙∙∙∙│
∙∙+∙+∙+∙<span class=lt>+∙+∙+∙+</span>∙+∙+∙+∙│
∙∙∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙∙∙│
∙∙∙∙∙∙∙∙∙∙<span class=lt>+@+</span>∙∙∙∙∙∙∙∙∙│
∙∙∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙</span>∙∙∙∙∙∙∙∙│
∙∙+∙+∙+∙<span class=lt>+∙+∙+∙+</span>∙+∙+∙+∙│
∙∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>∙∙∙∙∙∙│
∙∙∙∙∙∙<span class=lt>+∙+</span>∙<span class=lt>+∙+</span>∙<span class=lt>+∙+</span>∙∙∙∙∙│
∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙│
∙∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙<span class=lt>+∙+</span>∙∙∙│
</pre>
<div class=caption>My algorithm</div>
</div>
<div class=sshotc>
<pre class=sshot>∙∙∙∙+<span class=lt>∙</span>+∙∙∙<span class=lt>+∙+</span>∙∙∙+<span class=lt>∙</span>+∙∙∙│
∙∙∙∙∙∙<span class=lt>∙</span>∙∙∙<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙∙∙∙∙│
∙∙∙∙∙∙+<span class=lt>∙</span>+∙<span class=lt>+∙+</span>∙+<span class=lt>∙</span>+∙∙∙∙∙│
∙∙∙∙∙∙∙∙<span class=lt>∙</span>∙<span class=lt>∙∙∙</span>∙<span class=lt>∙</span>∙∙∙∙∙∙∙│
<span class=lt>∙∙+∙+∙+∙+∙+∙+∙+∙+∙+∙+∙│</span>
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙│</span>
∙∙∙∙∙∙∙∙∙∙<span class=lt>+@+</span>∙∙∙∙∙∙∙∙∙│
<span class=lt>∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙│</span>
<span class=lt>∙∙+∙+∙+∙+∙+∙+∙+∙+∙+∙+∙│</span>
∙∙∙∙∙∙∙∙<span class=lt>∙</span>∙<span class=lt>∙∙∙</span>∙<span class=lt>∙</span>∙∙∙∙∙∙∙│
∙∙∙∙∙∙+<span class=lt>∙</span>+∙<span class=lt>+∙+</span>∙+<span class=lt>∙</span>+∙∙∙∙∙│
∙∙∙∙∙∙<span class=lt>∙</span>∙∙∙<span class=lt>∙∙∙</span>∙∙∙<span class=lt>∙</span>∙∙∙∙∙│
∙∙∙∙+<span class=lt>∙</span>+∙∙∙<span class=lt>+∙+</span>∙∙∙+<span class=lt>∙</span>+∙∙∙│
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
</div> 
<a name=cmpsymmetry></a>
<h4>Symmetrical versions</h4>
This is a comparison between the symmetrical versions of the algorithms. Ray casting is not included because it cannot
be made symmetrical with reasonable efficiency. My algorithm has two symmetrical versions: one that's fully symmetrical
and another that's symmetrical except for some walls (i.e. that's symmetrical between monsters except for some passwall
monsters).
<p>
<div class=sshotc>
<pre class=sshot>│∙└───────<span class=lt>───</span>─────────┤
<span class=lt>│∙∙∙∙∙∙∙∙∙∙@∙∙∙∙∙∙∙∙∙∙+</span>
└───────┬┬<span class=lt>─∙┌</span>┬────────┤
        ├┘∙<span class=lt>∙</span>└┤        │
       ┌┘∙<span class=lt>∙│</span>∙└┐       │
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>│∙└──────<span class=lt>─────</span>────────┤
<span class=lt>│∙∙∙∙∙∙∙∙∙∙@∙∙∙∙∙∙∙∙∙∙+</span>
└───────┬<span class=lt>┬─∙┌┬</span>────────┤
        ├┘<span class=lt>∙∙└</span>┤        │
       ┌┘∙<span class=lt>∙│</span>∙└┐       │
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>│∙└──────<span class=lt>─────</span>────────┤
<span class=lt>│∙∙∙∙∙∙∙∙∙∙@∙∙∙∙∙∙∙∙∙∙+</span>
└───────┬<span class=lt>┬─∙┌┬</span>────────┤
        ├┘<span class=lt>∙∙└</span>┤        │
       ┌┘∙<span class=lt>∙│</span>∙└┐       │
</pre>
<div class=caption>My algorithm (full symmetry)</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>│</span>∙<span class=lt>└───────────────────┤</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙∙@∙∙∙∙∙∙∙∙∙∙+</span>
<span class=lt>└───────┬┬─∙┌┬────────┤</span>
        ├┘<span class=lt>∙∙└</span>┤        │
       ┌┘∙<span class=lt>∙│</span>∙└┐       │
</pre>
<div class=caption>My algorithm (partial symmetry)</div>
</div>
<div class=sshotc>
<pre class=sshot><span class=lt>│∙└───────────────────┤</span>
<span class=lt>│∙∙∙∙∙∙∙∙∙∙@∙∙∙∙∙∙∙∙∙∙+</span>
<span class=lt>└───────┬┬─∙┌┬────────┤</span>
        ├┘<span class=lt>∙∙└</span>┤        │
       ┌┘<span class=lt>∙∙│∙</span>└┐       │
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙
   │∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>∙∙∙∙
<span class=lt>──</span>─┤∙∙∙<span class=lt>∙∙∙∙┼</span>∙∙∙┼∙∙∙
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>──</span>─┤∙∙∙<span class=lt>∙∙∙∙┼</span>∙∙∙┼∙∙∙
   │∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>∙∙∙∙
   │∙∙∙∙∙∙∙┼∙∙∙┼∙∙∙
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>
   │∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
<span class=lt>───</span>┤∙∙<span class=lt>∙∙∙∙∙┼</span>∙∙∙┼∙∙∙
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───</span>┤∙∙<span class=lt>∙∙∙∙∙┼</span>∙∙∙┼∙∙∙
   │∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
   │∙∙∙∙∙∙∙┼∙∙∙┼∙∙<span class=lt>∙</span>
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>
   │∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
<span class=lt>───</span>┤∙∙<span class=lt>∙∙∙∙∙┼</span>∙∙∙┼∙∙∙
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───</span>┤∙∙<span class=lt>∙∙∙∙∙┼</span>∙∙∙┼∙∙∙
   │∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
   │∙∙∙∙∙∙∙┼∙∙∙┼∙∙<span class=lt>∙</span>
</pre>
<div class=caption>My algorithm (full symmetry)</div>
</div>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>
   │∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
<span class=lt>───┤</span>∙∙<span class=lt>∙∙∙∙∙┼</span>∙∙∙<span class=lt>┼</span>∙∙∙
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───┤</span>∙∙<span class=lt>∙∙∙∙∙┼</span>∙∙∙<span class=lt>┼</span>∙∙∙
   │∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>∙∙∙∙
   │∙∙∙∙∙∙∙┼∙∙∙┼∙∙<span class=lt>∙</span>
</pre>
<div class=caption>My algorithm (partial symmetry)</div>
</div>
<div class=sshotc>
<pre class=sshot>   │∙∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙</span>
   │∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙
<span class=lt>───┤∙∙∙∙∙∙∙┼∙∙∙┼∙∙∙</span>
<span class=lt>@∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───┤∙∙∙∙∙∙∙┼∙∙∙┼∙∙∙</span>
   │∙∙∙<span class=lt>∙∙∙∙∙∙∙∙∙∙∙</span>∙
   │∙∙∙∙∙∙<span class=lt>∙┼∙∙∙┼∙∙∙</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>     │∙∙∙∙∙∙∙∙∙∙∙∙∙
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>──</span>───┤∙∙∙∙∙<span class=lt>∙∙┼</span>∙∙∙┼∙
<span class=lt>@∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>──</span>───┤∙∙∙∙∙<span class=lt>∙∙┼</span>∙∙∙┼∙
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
     │∙∙∙∙∙∙∙┼∙∙∙┼∙
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>     │∙∙∙∙∙∙∙∙∙∙∙∙∙
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>───</span>──┤∙∙∙∙<span class=lt>∙∙∙┼</span>∙∙∙┼∙
<span class=lt>@∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───</span>──┤∙∙∙∙<span class=lt>∙∙∙┼</span>∙∙∙┼∙
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
     │∙∙∙∙∙∙∙┼∙∙∙┼∙
</pre>
<div class=caption>Diamond walls</div>
</div>
<div class=sshotc>
<pre class=sshot>     │∙∙∙∙∙∙∙∙∙∙∙∙∙
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>───</span>──┤∙∙∙∙<span class=lt>∙∙∙┼</span>∙∙∙┼∙
<span class=lt>@∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>───</span>──┤∙∙∙∙<span class=lt>∙∙∙┼</span>∙∙∙┼∙
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
     │∙∙∙∙∙∙∙┼∙∙∙┼∙
</pre>
<div class=caption>My algorithm (full symmetry)</div>
</div>
<div class=sshotc>
<pre class=sshot>     │∙∙∙∙∙∙∙∙∙∙∙∙∙
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
<span class=lt>─────┤</span>∙∙∙∙<span class=lt>∙∙∙┼</span>∙∙∙<span class=lt>┼</span>∙
<span class=lt>@∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┤</span>∙∙∙∙<span class=lt>∙∙∙┼</span>∙∙∙<span class=lt>┼</span>∙
     │∙∙∙∙∙∙∙∙∙∙∙∙∙
     │∙∙∙∙∙∙∙┼∙∙∙┼∙
</pre>
<div class=caption>My algorithm (partial symmetry)</div>
</div>
<div class=sshotc>
<pre class=sshot>     │∙∙∙∙∙∙∙∙∙∙<span class=lt>∙∙∙</span>
     │∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┤∙∙∙∙∙∙∙┼∙∙∙┼∙</span>
<span class=lt>@∙∙∙∙■∙∙∙∙∙∙∙∙∙∙∙∙∙</span>
<span class=lt>─────┤∙∙∙∙∙∙∙┼∙∙∙┼∙</span>
     │∙∙∙∙∙<span class=lt>∙∙∙∙∙∙∙∙</span>
     │∙∙∙∙∙∙∙┼∙∙<span class=lt>∙┼∙</span>
</pre>
<div class=caption>Permissive FOV</div>
</div>
<p></p>
<p>
<div class=sshotc>
<pre class=sshot>│   ┌──────────<span class=lt>─</span>┐
│   │∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>│
│  ┌┘∙──┬─────┐<span class=lt>∙</span>│
└─┬┤∙∙∙∙│     │<span class=lt>∙</span>│
∙∙└┘∙∙∙∙│     │<span class=lt>∙</span>│
<span class=lt>┐∙</span>∙∙∙∙∙∙└───┐ │<span class=lt>∙</span>│
└──┐∙∙<span class=lt>∙∙∙</span>∙∙∙└─<span class=lt>┘∙│</span>
   │∙∙∙∙┌─<span class=lt>┐∙∙∙∙@│</span>
   │∙∙∙∙│ └───<span class=lt>──┘</span>
</pre>
<div class=caption>Shadow casting</div>
</div>
<div class=sshotc>
<pre class=sshot>│   ┌──────────<span class=lt>─</span>┐
│   │∙∙∙∙∙∙∙∙∙∙<span class=lt>∙</span>│
│  ┌┘∙──┬─────┐<span class=lt>∙</span>│
└─┬┤∙∙∙∙│     │<span class=lt>∙</span>│
∙∙└┘∙∙∙∙│     │<span class=lt>∙</span>│
<span class=lt>┐∙∙∙</span>∙∙∙∙└───┐ <span class=lt>│∙│</span>
└──┐∙<span class=lt>∙∙∙∙∙</span>∙∙└<span class=lt>─┘∙│</span>