Pages:
Author

Topic: Mechanical hashing (Read 531 times)

newbie
Activity: 3
Merit: 1
December 15, 2024, 05:51:11 AM
#30
I don't see it as thing much more complicated than how the original mechanical pull-the-handle tabulators/comptometers worked. They could add, subtract, multiply & divide. Just need more entry keys and associated mechanisms along with a register to hold intermediate results and apply them to the next sequence of the math. Considering they were 1st built back in 1887 and made thru the mid 1970's, odds are that there are old mechanical drawings of their mechanisms *somewhere* on the web.
Quote
Although the comptometer was primarily an adding machine, it could also do subtractions, multiplication and division. Its keyboard consisted of eight or more columns of nine keys each. Special comptometers with varying key arrays were produced for a variety of special purposes, including calculating currency exchanges, times and Imperial weights. The name comptometer was formerly in wide use as a generic name for this class of calculating machine.

hi, I love these in terms of archaic low-tech fallback systems

the problem with these though is that they were built from bottom to top for general purpose

there are a lot of optimizations by building top-to-bottom is you make a task-specific machine (think mechanical ASIC, as I write in my linked substack post above perhaps jokingly but not so far from the truth)

for example, in my case of this spiral hashing system I developed over the last 5+ years, instead of rotating a binary string to the right »6, right »11 and then to the left »25, we do the rotation of clockwise »6, then »5 and then counter-clockwise «2, while just keeping track of the mean-result of the XOR

similar things are happening with calculating the w16 part of the input based on the block header, where instead of doing rotations to the right »16, right »17 and then a shift to the right »10, you're doing this algorithm:
- if not in the last 10 bits (which corresponds to the last 10 bottom segments of the spiral), then do: right »6, left »7, left »2
- if in the last 10 bits, then do: up »0, left »1, left »2
- each first rotation to the (right ») requires you to simply "change floors" of the spiral (which equates to changing from the higher order part of the binary string to the lower order part, or vice versa)

I believe this system is a great start for buliding such a machine, which is why I spent so much time on it. it could most likely be optimized even more, but so far its' just me working on it, and I am most definitely not the brightest of minds that can be found in this area

edit: the optimizations I mention are in the amount of work a human or mechanical device needs to do, think more in "joules" and less in high-level lines of code
legendary
Activity: 3822
Merit: 2703
Evil beware: We have waffles!
December 14, 2024, 08:00:17 PM
#29
I don't see it as thing much more complicated than how the original mechanical pull-the-handle tabulators/comptometers worked. They could add, subtract, multiply & divide. Just need more entry keys and associated mechanisms along with a register to hold intermediate results and apply them to the next sequence of the math. Considering they were 1st built back in 1887 and made thru the mid 1970's, odds are that there are old mechanical drawings of their mechanisms *somewhere* on the web.
Quote
Although the comptometer was primarily an adding machine, it could also do subtractions, multiplication and division. Its keyboard consisted of eight or more columns of nine keys each. Special comptometers with varying key arrays were produced for a variety of special purposes, including calculating currency exchanges, times and Imperial weights. The name comptometer was formerly in wide use as a generic name for this class of calculating machine.
newbie
Activity: 3
Merit: 1
December 14, 2024, 02:04:18 PM
#28
To explain better, how crypto works, for less-technical and less-digital people, there is a need to explain hash functions mechanically, without involving any electricity. I think it should be technically possible to make a mechanical device, where any user could set any Initialization Vector for SHA-256, set any 512-bit message, and see the result of hashing this block once by SHA-256. That could be used to better explain, how mining works. If someone will make something like that, I will buy it for Bitcoin. I saw some interesting projects here, maybe this idea could inspire someone to make something like that for some hash functions, for example SHA-256.

hey man, I created a prototype for exactly this thing, if you're interested read here:

https://substack.com/home/post/p-151596504

it's a pen & paper prototype but I envisioned it as a mechanical device where the spirals are rotated and the 1s and 0s are something like rotating beads that have one side black and the other white, or something like that, it could be done in a number of ways, but the bottomline is all you have to do is have the input vector written down somewhere and then to feed it word by word (32-bit word) into the "outer edge" part of the spiral as you go through the hash algorithm

there is also a separate process through which one calculates the w16-w63 parts of the input vector using the same setup without overwriting the current state of ABCDEFGH values

I'm currently testing the paper prototype to see if I can perform a hashing of the full block, it's pretty tedious with pencil & paper but with a mechanical version and knowing the process by heart (and practicing it) I think it can be done pretty quickly in human terms - like currently I need like 1 hour per 1 round of hashing, I think it can be reduced a lot with some mechanical engineering and pure muscle memory Smiley
copper member
Activity: 909
Merit: 2301
June 30, 2022, 01:10:54 AM
#27
Quote
+ mod 2^32
It is simpler than you think. If you can implement addition, getting it modulo 2^32 means simply rejecting the highest bit. And addition can be handled just as a combination of XOR and the majority function. First, you use the lowest bit from "a", the lowest bit from "b", and zero as a carry, and execute a XOR on that to get the lowest bit of the result of addition. Then, using the same input, you execute the majority function: if there are at least 2-of-3 bits set to one, then there is a carry equal to one, otherwise zero. And you can go through it bit-by-bit, then you can save the last carry, if you want to produce 33-bit result for your addition, or just skip it, and then you will have it modulo 2^32, just by dropping one bit.

Another thing is that "modulo addition" and "modulo subtraction" is like rotating a clock: if you have modulo 60, then you can represent seconds. If you add 45 and 50, then you will get 95, but modulo 60 it will be 35. So, modulo addition is like rotating a huge wheel, where after 0xffffffff, you will get 0x00000000 (and the same in the opposite direction is true when you have subtraction). So, I can imagine for example 8 wheels with numbers from 0 to f, when they can be rotated to handle addition, and when each next wheel will tick only when the previous one was rotated by 360 degrees, and jumped from "f" to "0".
sr. member
Activity: 1190
Merit: 469
June 29, 2022, 09:14:08 PM
#26
So, this said, and as I also said, to pull something like this out, we would need multiple people thinking, writing, modeling parts, drawing parts, manufacturing parts, not to even mention all the theoretical part before all the hardware work, right?
Well it seems like the key thing would be to break this device down into functional subunits that each performs a certain type of task. like XOR, AND,Rightrotate, + mod 2^32. then you can manufacture these subunits in quantity and assemble them into larger subunits that perform any general task.
hero member
Activity: 1274
Merit: 681
I rather die on my feet than to live on my knees
June 29, 2022, 05:05:58 PM
#25

Check this thing: Enigma machine used by Germans to encrypt messages
https://www.youtube.com/watch?v=G2_Q9FoD-oQ
a mechanical sha-256 hashing machine would probably be more complex than this enigma thing.  keep in mind too that the enigma was not purely mechanical. it was really electronic in nature.


Yes, I know. I just wanted to have an idea if these hashing machine would be anything like that concept of the Enigma machine! Other than that, yes, it would probably be even more complex as the mathematical processes that take part in the hashing functions are also complex (I have the idea, not the actual knowledge).
So, this said, and as I also said, to pull something like this out, we would need multiple people thinking, writing, modeling parts, drawing parts, manufacturing parts, not to even mention all the theoretical part before all the hardware work, right?
sr. member
Activity: 1190
Merit: 469
June 29, 2022, 05:04:06 PM
#24
The electrical part of the Enigma was purely used for current flow to highlight the result of the purely mechanical change of rewirering of characters. The encryption process ie. the change of character to character wirering is completely mechanical.
yeah but the electrical part was how it operated. based on making and breaking different circuits. if the battery ran out of juice there is no way that thing would have operated.
hero member
Activity: 714
Merit: 1010
Crypto Swap Exchange
June 29, 2022, 12:19:27 AM
#23
The electrical part of the Enigma was purely used for current flow to highlight the result of the purely mechanical change of rewirering of characters. The encryption process ie. the change of character to character wirering is completely mechanical.
sr. member
Activity: 1190
Merit: 469
June 28, 2022, 08:13:50 PM
#22

Check this thing: Enigma machine used by Germans to encrypt messages
https://www.youtube.com/watch?v=G2_Q9FoD-oQ
a mechanical sha-256 hashing machine would probably be more complex than this enigma thing.  keep in mind too that the enigma was not purely mechanical. it was really electronic in nature.
hero member
Activity: 1274
Merit: 681
I rather die on my feet than to live on my knees
June 28, 2022, 05:03:49 PM
#21
Quote
Is anything like that, people is talking about here?
Well, there is one main requirement: it should require no external power supply. If there is power outage, that device should still work. Someone proposed chemical hashing, I thought more about mechanical hashing, because it seems to be easier to compute than using paper and pencil, and it should be easier to learn, how to operate that. I thought about something simple, like constructing some tables for basic operations, like addition, rotation, xor, then it could be possible to compute hash functions manually, just by rotating a crank, or providing needed energy to the system in other simple ways. For example, it could be possible to paint squares in different colours to represent zeroes and ones, then negating the whole number could be done by simply rotating some wheels inside it by 180 degrees.

I thought about many different ways of doing that, but it seems some mechanical engineer is needed to make it real. It could use some buttons, some magnets, some rotating wheels with hex digits from "0" to "f", there are many options. Each state can be represented in many different ways, you could also place something here, like a marble (when it is present, it could represent "logical one", and when it is empty, it could represent "logical zero"). It could use gravity to implement logical gates. I don't know exactly how to make it, because I didn't find anything like that anywhere, maybe just nobody needed it yet.

To put it simply, it should be better than paper and pencil, and should work in cases, where no electricity is available, or if there is power outage, that's the general idea behind it. And I think making it in a mechanical way would be the simplest solution to that, but maybe there is something better available, I don't know (but I am not convinced for example to the chemical solution, that could be hard to do in a typical home, I think building a physical machine, or passing a ready-to-assemble project for some manufacturer, would be easier).

Edit: some visualization, how it could look like: https://upload.wikimedia.org/wikipedia/commons/4/44/Grant_mechanical_calculating_machine_1877.jpg
Of course it is just an example, because hash functions are more complex than that.

Well, I don't even have all the knowledge present in memory to at least make a mental sketch of what would be needed. I am an electrical engineer but I am not even close to be able to put up something like this. This is something probably to be put up as a project with several stages an probably multiple teams working on each stage! Or someone really bright/smart/intelligent capable of pulling this off alone! I'm not that one for sure!

You need to know exactly about bits and bytes, cryptography, probabbly mechanical engineering, learn or find someone to design components in 3D software with great precision, think about probably thousands of details in each stage of the project etc.

If you are really into this, maybe we should start by making a statement and say: I have this goal. I want to do this and that. Whoever is interested and whoever has any type of skills, feel free to onbard. After that, we would need to start laying down the stages, tasks for each stage, what knowledge and skills are needed in each stage, etc. I can't see this done by simply throwing ideas in the air like we are doing!

If this machine is anything like the Turing machine, I can't imagine how many thousands of hours were spent by those 2 guys and probably by a bunch of other unknown people in the background!

Check this thing: Enigma machine used by Germans to encrypt messages
https://www.youtube.com/watch?v=G2_Q9FoD-oQ

xD

And then check the craking machine here, at aroun 5:30. Machine Turing built to decrypt Enigma machine encryption!
https://www.youtube.com/watch?v=Hb44bGY2KdU
copper member
Activity: 909
Merit: 2301
June 28, 2022, 12:46:11 PM
#20
Quote
the thing about using marbles and gravity well it's an interesting idea but if you want it to be robust, then it can't make errors
How it could be much worse than with using electricity? You have two marbles in a row. You release all gates, all marbles fall down, because of the gravity, and you collect the lowest row, if you want "logical or", or you collect the second row, if you want "logical and". It is that simple. Logical "or" means that there is at least one marble, logical "and" means that there are two of them, so they could be physically grabbed just by taking the second row, if they have the same size, then you will get one above the other if (and only if) both of them are present.

Quote
if the machine was somehow damaged and some marble wasn't falling correctly because of that then it would just be duplicating the same error and you would be none the wiser
I think it is just a matter of using the right materials, the right proportions, things like that. The whole world is physical, why using electricity is that important to make things tick? Another thing is that as long as we can use computers, it is just some interesting project that could be done "for fun", or maybe "for demonstration", it could be serious only if the whole world would be forced to abandon electricity altogether, because of some nuclear war, or other serious world-scale problems, but then, Bitcoin will be less important than having something to eat. I think crypto adoption is still too low to allow surviving in hard times, we are not there yet.
sr. member
Activity: 1190
Merit: 469
June 27, 2022, 09:26:18 PM
#19
I thought about many different ways of doing that, but it seems some mechanical engineer is needed to make it real. It could use some buttons, some magnets, some rotating wheels with hex digits from "0" to "f", there are many options. Each state can be represented in many different ways, you could also place something here, like a marble (when it is present, it could represent "logical one", and when it is empty, it could represent "logical zero"). It could use gravity to implement logical gates. I don't know exactly how to make it, because I didn't find anything like that anywhere, maybe just nobody needed it yet.


the thing about using marbles and gravity well it's an interesting idea but if you want it to be robust, then it can't make errors. it has to compute things correctly 100% of the time especially if it was used in some type of device that computed a bitcoin address. a mechanical device using marbles and gravity sounds like it might not be at that level. yes you could redo the same computation multiple times but that just adds to the complexity of the situation and unfortunately if the machine was somehow damaged and some marble wasn't falling correctly because of that then it would just be duplicating the same error and you would be none the wiser.

you could run a test vector through it every time first to make sure it was working correctly though. but still, a mechanical device seems like it could have some type of error rate. i'd say the error rate would need to be less than 1 in 1 million. maybe less than 1 in 1 billion. ideally even less than that.
copper member
Activity: 909
Merit: 2301
June 27, 2022, 11:40:25 AM
#18
Quote
Is anything like that, people is talking about here?
Well, there is one main requirement: it should require no external power supply. If there is power outage, that device should still work. Someone proposed chemical hashing, I thought more about mechanical hashing, because it seems to be easier to compute than using paper and pencil, and it should be easier to learn, how to operate that. I thought about something simple, like constructing some tables for basic operations, like addition, rotation, xor, then it could be possible to compute hash functions manually, just by rotating a crank, or providing needed energy to the system in other simple ways. For example, it could be possible to paint squares in different colours to represent zeroes and ones, then negating the whole number could be done by simply rotating some wheels inside it by 180 degrees.

I thought about many different ways of doing that, but it seems some mechanical engineer is needed to make it real. It could use some buttons, some magnets, some rotating wheels with hex digits from "0" to "f", there are many options. Each state can be represented in many different ways, you could also place something here, like a marble (when it is present, it could represent "logical one", and when it is empty, it could represent "logical zero"). It could use gravity to implement logical gates. I don't know exactly how to make it, because I didn't find anything like that anywhere, maybe just nobody needed it yet.

To put it simply, it should be better than paper and pencil, and should work in cases, where no electricity is available, or if there is power outage, that's the general idea behind it. And I think making it in a mechanical way would be the simplest solution to that, but maybe there is something better available, I don't know (but I am not convinced for example to the chemical solution, that could be hard to do in a typical home, I think building a physical machine, or passing a ready-to-assemble project for some manufacturer, would be easier).

Edit: some visualization, how it could look like: https://upload.wikimedia.org/wikipedia/commons/4/44/Grant_mechanical_calculating_machine_1877.jpg
Of course it is just an example, because hash functions are more complex than that.
hero member
Activity: 1274
Merit: 681
I rather die on my feet than to live on my knees
June 27, 2022, 09:20:39 AM
#17
Just wondering about this mechanical device and I cannot picture anything unless we're talking about something like it was used by the Americans in WWII to decrypt German messages? That Turing machine and Bombe machine developed by Alan Turing and Welchman? Is anything like that, people is talking about here?
copper member
Activity: 909
Merit: 2301
June 27, 2022, 07:10:44 AM
#16
Quote
but then you have to go to a computer to generate its address
Not really. If you can add and double points, you can handle ECDSA. If you can do that, you have private to public key conversion (and in general, you can multiply any number by any point). Then, if you need Taproot, it is more than enough to handle that, because no hashing is needed to sign a message, you need hashing only to compute the hash of the message you want to sign. To generate Taproot address alone, having a public key is sufficient, you can just encode it in bech32m.

Quote
I guess a machine that could perform sha-256 would be much more complex in construction with so many more parts.
Even if it will be quite large, like a Wintergatan Marble Machine, it may still be useful in places, where there is no electricity. But I think hash function has just a few functions, that are constantly repeated. I think having some parts should be enough to do that, for example one part can handle rotation, another part can handle addition, something else for xoring, there is not that many functions as you expect, you can read my description in a separate topic, it is just a few simple functions working on uint32 values, and a few constants here and there, for example a table with 64 k-values for SHA-256.

Quote
then crank it 500+ times. i guess it's still ok since it is not something you would do all the time just for demonstration purposes or similar
It is acceptable, as long as it will be simpler and faster than doing that by paper and pencil.
sr. member
Activity: 1190
Merit: 469
June 26, 2022, 06:46:12 PM
#15
Well, ECDSA is more complicated, but yes, if someone would be interested in making such physical devices, that could be the next step, to provide point addition/doubling (and point subtraction/halving by rotating it backwards).
I think a device like that would have a use case you can generate a private key by rolling dice but then you have to go to a computer to generate its address. if it could all be done mechanically that would be safer than having to use a computer.

Quote
It is a matter of construction: having it bidirectional can be easier to mount than making unidirectional device. And if going in one direction will be simpler, then the constructor can also make it that way, that would be also a good start. But I prefer having it bidirectional, because then it is easier to demonstrate some attacks, like meet-in-the-middle attack.
i'm aware of a mechanical calculator called the Curta but it seems that it's a pretty complex device and all it does is add, subtract, multiply 2 numbers together. I guess a machine that could perform sha-256 would be much more complex in construction with so many more parts. and the curta itself is pretty complicated as it is. but this would be taking things to a whole new level. not only that but adding two numbers on the curta you just rotate the crank a couple times and it spits out the answer. with this sha-256 machine, you probably have to crank it over 100 times to get the hash output for a single chunk. have 5 chunks? then crank it 500+ times. i guess it's still ok since it is not something you would do all the time just for demonstration purposes or similar.


copper member
Activity: 909
Merit: 2301
June 26, 2022, 12:46:12 AM
#14
Quote
if your machine could operate on messages with more than one chunk then it might be more interesting
First, let's get anything that could work on one chunk. Then, expanding it, is just a matter of passing many chunks as an input in some fast way. I think to explain mining, a single chunk is more than enough. The block header itself has 80 bytes, so 640 bits, that would mean two chunks. The hash of the hash means hashing the 256-bit result, so also one chunk. To demonstrate mining, it is needed to hash three chunks, and I think it would be a good start, definitely easier and faster than doing everything with paper and pencil.

Quote
a more useful mechanical machine would be one that you could input a bitcoin private key and turn the crank and it would tell you the associated bitcoin address
Well, ECDSA is more complicated, but yes, if someone would be interested in making such physical devices, that could be the next step, to provide point addition/doubling (and point subtraction/halving by rotating it backwards).

Quote
cranking your mechanical machine in reverse wouldn't do any useful work it would just get you back the original 8 hash values which are already hardcoded into the algorithm so what would be the point?
It is a matter of construction: having it bidirectional can be easier to mount than making unidirectional device. And if going in one direction will be simpler, then the constructor can also make it that way, that would be also a good start. But I prefer having it bidirectional, because then it is easier to demonstrate some attacks, like meet-in-the-middle attack.
sr. member
Activity: 1190
Merit: 469
June 25, 2022, 08:23:41 PM
#13

Then, it could be possible to reverse everything, just by mechanically rotating it backwards, it would be an equivalent of starting with some fixed last round, taking the last 16 w-values, and computing it backwards, to get Initialization Vector again. I demonstrated it is possible for SHA-1, I think it could work in pretty much the same way for other hash functions, like SHA-256.
i think that is actually correct. you can do that with sha-256. the thing is, if you just have one single 512-bit chunk, then you don't really need to reverse anything if you know the 16 w-values since those hold the original message. cranking your mechanical machine in reverse wouldn't do any useful work it would just get you back the original 8 hash values which are already hardcoded into the algorithm so what would be the point?

if your machine could operate on messages with more than one chunk then it might be more interesting.

a more useful mechanical machine would be one that you could input a bitcoin private key and turn the crank and it would tell you the associated bitcoin address.

copper member
Activity: 909
Merit: 2301
June 25, 2022, 04:06:34 AM
#12
Quote
That is not what reversing is though. Real reversing is when you only have c and want to compute both a and b otherwise you are just using modular arithmetic properties namely compatibility with translation.
Exactly. And that's all needed to make a physical device for it. I can imagine starting from Initialization Vector and w-values from w[0] to w[15], then by rotating it mechanically, like in a mechanical calculator, next rounds could be computed, round by round, that would tweak w-values one-by-one, and finally there will be Exit Hash, and the last 16 w-values, for example from w[48] to w[63], in case of SHA-256 and 64 rounds. Then, it could be possible to reverse everything, just by mechanically rotating it backwards, it would be an equivalent of starting with some fixed last round, taking the last 16 w-values, and computing it backwards, to get Initialization Vector again. I demonstrated it is possible for SHA-1, I think it could work in pretty much the same way for other hash functions, like SHA-256.

Quote
In reality (such as hash digests) you don't have a or b.
Yes, in reality you know the Initialization Vector, and the Exit Hash, but not the message in-between. And that is of course irreversible. But on the other hand, hash functions can be executed forwards and backwards, going from the Initialization Vector, by taking message, and reaching Exit Hash is as possible, as it is to start with the Exit Hash, take tweaked w-values, and compute everything backwards, to reach Initialization Vector. It is bidirectional, and that property is enough to make a physical device for such algorithm.
legendary
Activity: 3472
Merit: 10611
June 25, 2022, 01:10:15 AM
#11
See? Addition modulo 2^32 is perfectly reversible.
That is not what reversing is though. Real reversing is when you only have c and want to compute both a and b otherwise you are just using modular arithmetic properties namely compatibility with translation.
In reality (such as hash digests) you don't have a or b.
Pages:
Jump to: