Sliding block memory: Difference between revisions

From LifeWiki
Jump to navigation Jump to search
LinkCallahan
Confocal (talk | contribs)
links, formatting
Line 1: Line 1:
{{Glossary}}
{{Glossary}}
A '''sliding block memory''' is a memory register whose value is stored as the position of a [[block]]. The block can be moved by means of [[glider]] collisions. See [[block pusher]] for an example.
A '''sliding block memory''' is a memory register whose value is stored as the position of a [[block]]. The block can be moved by means of [[glider]] collisions. See [[block pusher]] for an example.


In Conway's original formulation, as part of his proof of the existence of a [[universal computer]] in Life, two gliders were used to pull the block inwards by three diagonal spaces as shown below, and thirty gliders were used to push it out by the same amount.
In Conway's original formulation, as part of his proof of the existence of a [[universal computer]] in Life, two gliders were used to [[pull]] the block inwards by three diagonal spaces as shown below, and thirty gliders were used to [[push]] it out by the same amount.


{{EmbedViewer
{{EmbedViewer
Line 10: Line 10:
}}
}}


Dean Hickerson later greatly improved on this, finding a way to pull a block inwards by one diagonal space using 2 gliders, and push it out the same distance using 3 gliders. In order for the memory to be of any use there also has to be a way to read the value held. It suffices to be able to check whether the value is zero (as Conway did), or to be able to detect the transition from one to zero (as Hickerson did).
Dean Hickerson later greatly improved on this, finding a way to pull a block inwards by one diagonal space using 2 gliders, and push it out the same distance using 3 gliders. In order for the memory to be of any use there also has to be a way to read the value held. It suffices to be able to check whether the value is zero (as Conway did), or to be able to detect the transition from one to zero (as Hickerson did).


Dean Hickerson's sliding block memory is used in Paul Chapman's [[URM]], and several other complex constructions such as Adam P. Goucher's [[pi calculator]] and [[Spartan]] [[universal computer]]-constructor, and David Bell's [[Collatz 5N+1 simulator]].
Dean Hickerson's sliding block memory is used in Paul Chapman's [[URM]], and several other complex constructions such as Adam P. Goucher's [[pi calculator]] and [[Spartan universal computer-constructor]], and David Bell's [[Collatz 5N+1 simulator]].


== External links ==
== External links ==
{{LinkLexicon|lex_s.htm#slidingblockmemory}}
*{{LinkLexicon|lex_s.htm#slidingblockmemory}}
{{LinkCallahan|patterns/sbm/sbm.html|patternname=Sliding block memory}}
*{{LinkCallahan|patterns/sbm/sbm.html|patternname=Sliding block memory}}

Revision as of 13:58, 2 June 2022

A sliding block memory is a memory register whose value is stored as the position of a block. The block can be moved by means of glider collisions. See block pusher for an example.

In Conway's original formulation, as part of his proof of the existence of a universal computer in Life, two gliders were used to pull the block inwards by three diagonal spaces as shown below, and thirty gliders were used to push it out by the same amount.

x = 12, y = 9, rule = B3/S23 2o$2o4$9b3o$3o6bo$o9bo$bo! #C [[ THUMBSIZE 2 THEME 6 GRID GRIDMAJOR 0 SUPPRESS THUMBLAUNCH ]] #C [[ THUMBNAIL THUMBSIZE 2 THEME 6 GRID GPS 10 LOOP 40 ZOOM 20 PAUSE 2 AUTOSTART ]]
(click above to open LifeViewer)
RLE: here Plaintext: here

Dean Hickerson later greatly improved on this, finding a way to pull a block inwards by one diagonal space using 2 gliders, and push it out the same distance using 3 gliders. In order for the memory to be of any use there also has to be a way to read the value held. It suffices to be able to check whether the value is zero (as Conway did), or to be able to detect the transition from one to zero (as Hickerson did).

Dean Hickerson's sliding block memory is used in Paul Chapman's URM, and several other complex constructions such as Adam P. Goucher's pi calculator and Spartan universal computer-constructor, and David Bell's Collatz 5N+1 simulator.