Toggle search
Search
Toggle menu
notifications
Toggle personal menu
Editing
Level/Counter
From Turing Complete
Views
Read
Edit
Edit source
View history
associated-pages
Page
Discussion
More actions
Warning:
You are not logged in. Your IP address will be publicly visible if you make any edits. If you
log in
or
create an account
, your edits will be attributed to your username, along with other benefits.
Anti-spam check. Do
not
fill this in!
{{Header Nav|game=Turing Complete}} For this level you have to create a component that either increments by one each tick or loads a new value. [[File:Turing Complete Counter.png]] Since you need to store a value between ticks, place a Register component. Add an Always On component and wire it to both the Load and Store pins of the Register. Hook up a Mux component to the Save value pin of the register. Wire the numerical input pin to the Input 2 pin of the Mux. Wire the bit input pin to the Select 1/2 pin on the Mux. Finally add an Add component. Wire the Carry IN pin to the Always On component and the Input 1 pin to the Output pin of the Register. Wire the Result pin of the Add component to the Input 1 pin on the Mux. And to complete it, wire the Output pin of the Register to the output pin. == Optimizations == {{achievement |name=Binary Counter |image=Turing Complete achievement Binary Counter.jpg |description=Complete the Counter level with a 65 gate score or less }} While this circuit works, it is somewhat ineffective. By specializing the used components, it is possible to reduce both the delay and gate scores. The register is being used as a delay line. There is no need to pay for the extra features, so it can be replaced with an actual delay line. Since the 8bit component isn't allowed in this level, use eight 1bit delay lines instead. The second optimization is to special case the adder for the task of incrementing by one. By assuming the hardcoded input of 00000001 and looking at individual full adder implementations it becomes obvious that many gates are pointless. The ones bit always toggles, so a simple bit inverter can be used. The twos bit toggles if the ones bit was set. This can be generalized as a bit toggling only if all previous bits were set. A simple chain of AND gates can be used to detect which bits need to be toggled. [[File:Turing Complete Counter Optimized.png]] {{Footer Nav|game=Turing Complete|prevpage=Little Box|nextpage=Arithmetic Engine}}
Summary:
Please note that all contributions to Turing Complete are considered to be released under the Creative Commons Attribution-ShareAlike (see
TuringComplete:Copyrights
for details). If you do not want your writing to be edited mercilessly and redistributed at will, then do not submit it here.
You are also promising us that you wrote this yourself, or copied it from a public domain or similar free resource.
Do not submit copyrighted work without permission!
Cancel
Editing help
(opens in new window)
Templates used on this page:
Table of Contents
(
view source
)
Template:-
(
edit
)
Template:Achievement
(
view source
)
Template:Footer Nav
(
edit
)
Template:Header Nav
(
edit
)