Efficiency or Security

2022, Oct 21    

race-conditions Optimistic rollups are a type of rollup that uses an on-chain validator to commit data to the mainchain. This validator is responsible for validating the data that is being committed, and if the data is invalid, the validator can be punished. Zk-starks are a type of rollup that uses a zk-SNARK to verify the data that is being committed. This verification is done off-chain, and if the data is invalid, the zk-SNARK will not verify it.

There is no definitive answer to the question of which is better. Each type of rollup has its own advantages and disadvantages. Optimistic rollups are more efficient because they do not require data to be verified off-chain. However, zk-starks are more secure because they cannot be tricked into verifying invalid data.

Optimistic Rollups are less secure than Zk-Starks because they rely on fraud proofs, which can be expensive to generate and may not be entirely effective. However, Optimistic Rollups are much more efficient than Zk-Starks, which can be prohibitively expensive for large data sets. There is even more of a trade-off between efficiency and security when considering Optimistic Rollups vs Zk-Starks vs Zk-Rollups. Simply put, Zk-Rollups provide the highest security, but are the most inefficient. Zk-Starks provide high security and are more efficient than Zk-Rollups, but are less efficient than Optimistic Rollups. Optimistic Rollups provide the highest efficiency, but are the least secure.

Eternal Compromise

Therein lies the truth of the situation. There is an eternal push and pull between efficiency and security. In fact, we need only look at human history to find example after example of this apparent struggle and the dominant or preferred winner.

In one example, the Enigma machine was a machine used to encrypt and decrypt messages during World War II. The machine was designed to be as efficient as possible, and as a result, it was not very secure.

Fun fact, this was due to the Enigma machine rotors were not random. Instead, the machine used a set of rotors that were designed to follow a specific pattern. This meant that if someone knew the pattern, they could easily decipher the messages that were being sent!

In this case efficiency was deemed more valuable than security, and indeed the Enigma machine was important to the war effort. It was used by the Germans to encode their messages, and it was quite difficult for the Allies to break the code.

On the other hand, those who proclaim security would point to the Manhattan Project, a top secret project during World War II to develop the atomic bomb. Here security was of the utmost importance, and as a result, the project was not very efficient. This seems obvious with one reasoning the sheer size, a massive undertaking that involved a lot of people and resources. Also the project was conducted in secret, which made coordination and communication difficult. And ultimately, the project was rushed, which led to mistakes and waste. Clearly an inefficient process, and yet, a secure one.

So which is better? Perhaps it depends on timing? Or maybe situation, or a myriad of other external variables. Is there a pattern or framework to be formed by which we can identify when to select efficiency and when to select security? In the case of the blockchain is one better than the other? What do you think? Which offers the best future for on-chain activity?