Toy: Binary to Decimal

90 views
Skip to first unread message

Iván Nieto

unread,
Jul 3, 2011, 8:13:45 PM7/3/11
to Tile Factory
Input in the third row, maximum 524287. It needs heavy optimization:
for a number N, it takes a little more than N seconds to start the
output, so don't try huge numbers.

Example with 42:

eNod1geyrDgSQFGEkUlZZNB7v2z37Gk2O5ubyw/ilAClKEwqQS
3Lz3/U//SiRS8uhEVsXILEJbLtRSvv9ZKCqJBFxfy7RhlrEN23
oDfsOKBh4GDhERAhSMgoW3B9EbdhxwENAwsHgQcn4yISMgpOVL
RF9MnxKtoWzFjFDIVFzHpjfWWfwoIL827pmzf6F9qFVtEq2kvJ
topsSpIol8PmfN4dMRv9WDFwYW5cg+IacEDDwMJB4BEQkZBRcK
KioSsJu7fBIqCgY48uWAQU9OjSHiRZBBR0nsMmSCLGO8lomLdo
pSHDw0QbDc/VI6MFEfEuSuAahGuAhoGFAxGOMII4f2QUnKho6B
i4MLEnjgUNAwsGO26p8wiISMgoOFHR0DFwYSbZloITFQ1d1Jp5
JkaUuvuHqI3U3HFAw8Dm+xHyFPLf1HXLLstycMxd1nmkZcnJqV
OWtciyYccBDQMLLnYRhPscLgnr6cPa0DFQcXnlsyyeG6NKiCoz
Z66QtlPSVtHQMcAxjupIWhcMLBwEHgERCRkFJyoaOgau6sZ1yh
joaKg4UZCREBHgIeDBDQsDjYMHeXXHQcgbdJwoyEg4oGFg4SDw
CIio3cVjSNQwsCApqBTkGwIiEjIKTlQ0dAxcg9xp5A4MLEgyTo
7cQUBERkHCiYqGjoGriV4/eOMPHnjiJUH9SUE98MQLb3zSWD4y
ljf+4IEnXiLpkyS98QcPPPFKevt1escBDQMLBw9B+GV6/RPFQ+
BgYaBxYMf2DxP8yzVC4GBhoHFgx/bleb65n/9yXyFwsDDQOLBj
Q37hiQf+4IO3rDv3Wf3KVt5ylA//e3vjhSce5P0HL7zxxIP4l6
zXJetAR0PFiYyChIgADwHFYbUw0DguWcaUpaOh4kRBRkJEgIeA
4rJYGGgcU7aderD3tG0/tDMt+48cO8de6dumxBk452eKbSXfkF
dqx4+s/6VlWdJSlpOlsjQWavHiVbopT53IS1/GQsVHIoazBW+v
Q7as6TcS8jKMR6QQ0XraTJtpG22jnbQzLvtysOjJ79z5HUtmKa
zxGwqFDrzjioWBxoEdG9ay5rVseSt73suRj6KzLiabYrMtLlOu
spSQORZvQVwsnPPmOH/H6BPXRouKgWtnHe1gPzoGLs02Khouwz
YqGjoGLst+dMd+dGEbFQ3dcp+cUJ65V6R+zrR70vlIJut0ZJM4
Yzl4F2jqlsnUeeZ3yIVxHeQquWXJi5At4xzjJK3Z3+NoeZnkzL
rPnnvkWSjT/H9KPhf6T+IrbSOm0w62L/53sq1OlTZ11F3peihT
tbLVKFd5iVenfOXVUb2KNahUqew1qVIZVIuq9VStVtVrU6N2dd
Wj7UPDwMJB4BEQkZBRcKKioWPggvpVH7zxwhMP/Cnvlf3hVz6U
tY/6MHlvb7zwwJOJ+5A3Ze6t3kzqB5544d7+MMkf/o5jDN5M+A
eeeDHxH3jKi1L5UuylbD4VeymhD/Uo/MvVrq6bvkwzl232cs1d
R2M6N7l881do4YotXqmlK7d8lVaus51XbfVqjcGtX6ONi+Pc7b
yuAxoGFg4Cj4CIhIyCExUNHWMOjjE4xuAYg2MMjkGBgkdAREJG
wYmKhj474zvjO2M7Yyls8AiISMgoOFHRZmNcY1zjfxtjG2MpiA
iI8MhIKDhRZ2VcZUxlbGVcZRxFFB4BEQkZBec8GXMSfzLuZMzJ
GIouPAIiEjLKLMQX4gvxhfhCPMUZHgERCXlmYjOxmdhMbCaWCQ
ePgIg0E3GJuERcIi4RR7GHR0CckZhITCQmEhOJ4WUAjzAD/YH+
QH+gP9DPiwJ+evo8fZ4+T5+njxfIFPYL+4X9wn5hP1kHDQM7Ld
uWbcu2Yd2wru/nM1vnjndm3Ifcm+TgJBcnOTnJzUmOTnJ1krOT
3J3k8CSXJ3k9ye9Jnk/yfZLjc297ZxksP/vEz/YT8jq3n21ukw
r+3f32tX7/Br90vjG/xetv9+a7R/vlU/4bonxL9N8eydpO5nWe
bOdpdZ5C5w537mDnLnXuRufKO1faubrOVXWuqB/z6Mya2ic1h7
b9RRmZvTIrMHCvt8pMAd+FbJ9/t2tlBmGgo+Hed1ZmFwY6Giru
/aUy+zDQ0VBx4u7LlRmKgY6GihMFd3+qzGQMdDRUnCjIuGNiZd
ZjoKOh4kRBRsIdFypVAgMdDRUnCniNEEvm4Y7l85p4KgP4jCae
WQc+r4kn48FnN/FkJO54qVQkDHQ0VJwoSMiICPC4x7hKNcNAR0
PFiYKMhIgAD8E9zlaqIQY6GipOFGQkRAR4CBzusaZSUTHQ0VBx
oiAjISLAQ+BgcY/XtTzLiwy/1p/wu/54CBwsDDQO7Nh+18nvz/
rDN853+T8ugeGy

CJ

unread,
Jul 4, 2011, 4:56:29 AM7/4/11
to tile-f...@googlegroups.com
Ah yes! Combine this, binary adder/subtracter, and the binary multiplier, and we can make a calculator! We still don't have the binary divider though.

CJ

unread,
Jul 4, 2011, 4:57:06 AM7/4/11
to tile-f...@googlegroups.com

steve42

unread,
Jul 4, 2011, 9:54:14 PM7/4/11
to Tile Factory
On Jul 4, 1:13 am, Iván Nieto <ivan.niet...@gmail.com> wrote:
> Input in the third row, maximum 524287. It needs heavy optimization:
> for a number N, it takes a little more than N seconds to start the
> output, so don't try huge numbers.

My version - avoids the operator having to scroll the level, so it's
"easier to see what's going on" because it's all on the screen at the
same time!
It processes a number up to 1599999 as binary input on the top row.
The time taken is constant, whatever number is entered. As there is
only space for 6 digits on the output, a black dot is painted at the
end to indicate an overflow (i.e. a first digit of 1). There's a bug I
couldn't be bothered to fix (as I only noticed it as I was writing
this, having already copy-pasted the level into the message box) which
causes it to crash if you ask it to process a number equal or greater
than 1600000. Easiest fix would be to put some other object over where
the highest bit would go, and declare the maximum input to be 1048575.

Example shown has input 1234567.

The intermediate representation is BCD ("binary coded decimal"). It
takes more time to get the "human-readable" version than to convert
the number to a form of decimal in the first place....

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
==

steve42

unread,
Jul 5, 2011, 4:45:22 PM7/5/11
to Tile Factory
On Jul 5, 2:54 am, steve42 <googlegro...@banoffee.co.uk> wrote:
> There's a bug I
> couldn't be bothered to fix (as I only noticed it as I was writing
> this, having already copy-pasted the level into the message box) which
> causes it to crash if you ask it to process a number equal or greater
> than 1600000.

As well as this bug, there's also a couple of "deliberate" errors for
you to find, which only show up when there are certain digits in
certain places... (a couple of wires missing from the central "None")
Reply all
Reply to author
Forward
0 new messages