Currency Name: | Algorand |
Image 1: | Algorand mark.svg |
Ticker Symbol: | ALGO |
Symbol: | ALGO |
White Paper: | https://arxiv.org/abs/1607.01341 https://eprint.iacr.org/2017/454 https://eprint.iacr.org/2018/377 |
Initial Release Date: | April 2019 |
Code Repository: | https://github.com/algorand |
Status: | Active |
Programming Languages: | Python, TypeScript (smart contract programming languages); Go (implementation language) |
Author: | Silvio Micali |
Developer: | Algorand, Inc. |
Ledger Start: | June 2019 |
Supply Limit: | 10,000,000,000 ALGO |
Algorand is a proof-of-stake blockchain and cryptocurrency.[1] Algorand's native cryptocurrency is called ALGO.
The SEC has filed several lawsuits[2] [3] [4] [5] alleging ALGO is a security which is subject to regulation under U.S. securities laws, along with a few other crypto assets.
Algorand may also refer to the private corporation based in Boston,[6] [7] as well as to the nonprofit Algorand Foundation Ltd., incorporated in Singapore.[8] [9] [10]
Algorand was founded in 2017 by Silvio Micali, a computer scientist and professor at the Massachusetts Institute of Technology (MIT).[11] [12]
Algorand's test network was launched to the public in April 2019.[13]
Following successful testing and refinements, the main Algorand network was officially launched in June 2019.[14]
Algorand Foundation Ltd. manages award funding, cryptographic research, on-chain governance, and decentralization of the Algorand network including nodes. The Algorand protocol specifications are maintained by the Algorand Foundation.[15] The development of the Algorand protocol reference implementation is overseen by Algorand Technologies. The foundation is led by CEO Staci Warden.[16] The foundation also conducts developer programmes, accelerators and other activities in Africa[17] and India.[18]
Algorand Foundation Ltd. issues quarterly votes for the stakes of ALGO to vote on.[19] These proposals include implementation of DeFi.[20] [21] [22] [23]
Algorand can only be forked intentionally through soft forks and source code forks.[24] [25]
Algorand uses a Byzantine agreement protocol that leverages proof of stake,[26] [27] [28] which contributes to its energy efficiency.[29] [30] It is a competitor to blockchains such as Ethereum.[31] Researchers have found its protocol to be highly secure.[32]
The core principle of Algorand consensus is the cryptographic "self" sortition. The sortition procedure runs locally and privately, on each node of the network participating in the consensus protocol, without a centralized coordination.[33] The goal of the sortition algorithm is randomly selecting a subset of users participating in the consensus protocol (committees) ensuring two properties: the sortition's result can be easily verified once it is published, while it can not be determined ahead of time by malicious adversaries. The number of selected users in the sortition (committee size) is defined as a statistical expectation on the outcome of a pseudo-random process. The likelihood that a given user will be selected (in the committee) is influenced by the number of ALGO tokens held by that user (the stake).[34] [35]
The cryptographic sortition implementation relies on the verifiable random function (VRF) cryptographic primitive. The VRF consists of two algorithms: generation and verification. When each user participating in the Algorand consensus protocol runs the VRF, the VRF acts on a safe public seed[36] (Q, system wide parameter, published in past blocks) to generate a uniform pseudo-random number (h), along with a proof ('), using a user's secret key (of a public / secret key pair, Pk / Sk). The result can then be easily and publicly verified (as true or false) using the public seed (Q), the result (h), the proof (') and the user public key (Pk).
The consensus protocol requires users to generate the VRF key pairs before the safe public seed Q has been agreed, ensuring that the cryptographic sortition is robust with respect to brute force attacks (both on the safe public seed Q and users' secret keys Sk). The cryptographic sortition is also robust with respect to Sybil attacks (splitting users' ALGO tokens in multiple fake users gives no advantage in the sortition).
Consensus on Algorand requires three steps to propose, confirm, and write the block to the blockchain.[37] The steps are: block proposal, proposals filtering (soft vote) and committing the block (certify vote). Each step relies on an independent run of the cryptographic "self" sortition, to elect a voting committee with different sizes (statistical expectations on the sortition outcome) and voting thresholds.[38]
In the first step the cryptographic sortition selects a subset of users (proposal committee) which assemble and propose a block for the next round of the protocol. At the end of the step there will be a few block proposals (the protocol is tuned with a statistical expectation of 20 proposals) with different random priorities. After determining if a user is on the proposal committee, that user can build a proposed block and gossip it to the network for review/analysis during the second phase. The user includes the result of the VRF (h) and cryptographic proof in their block proposal to demonstrate committee membership.[34] [35]
In the second step the nodes in the networks wait for an adaptive period of time, measured by nodes' local clocks, to be sure that the block proposals gossiped in the previous steps have been observed.
A new cryptographic sortition selects a subset of users (soft vote committee) to vote and reach a Byzantine Agreement (called "BA*") on the proposal with highest priority. When users have determined that they are in this second-phase voting committee, they analyze the block proposals they have received (including verification of first-phase committee membership) and vote on the highest priority one.[34] [35]
Once a threshold of votes is reached in the previous proposals filtering step, the third and last step of the protocol begins. A new cryptographic sortition selects a subset of users (certify committee) to vote and reach a Byzantine Agreement on the content of the proposed block with respect to the state of the ledger (e.g. the block does not contain double spending, overspending or any other invalid state transition between accounts).
If the certify committee achieves consensus on a new block, then the new block is disseminated across the network and appended to the ledger.[39] [40]
Within the Algorand consensus protocol, membership in all the committees changes every time a new step is run. This protects users against targeted attacks, as an attacker will not know in advance which users are going to be on a committee. According to an external security audit, the model also accounts for timing issues and adversary actions, e.g., when the adversary has control over message delivery.[41]
The Algorand consensus protocol privileges consistency over availability (CAP theorem).[42] If the network is unable to reach consensus over the next step (or block), within a certain time, the protocol enters in a recovery mode, suspending the block production to prevent forks (contrary to what would happen in blockchains based on the "longest-chain principle", such as Bitcoin). The recovery mode of the protocol ensures that the block production resumes immediately, with no need of reconciliations or reorganization, as soon as a Byzantine Agreement is reached again.
An Algorand network is a distributed system of nodes, each maintaining a local state based on validating the blockchain and the transactions therein. Nodes are spread geographically, communicating with each other over the Internet. The integrity and the consistency of the global network state and distributed ledger is maintained by the consensus protocol. Algorand nodes communicate through message gossiping (broadcasting) either in peer-to-peer or via relay nodes (which facilitate efficient broadcasting with minimal message hops and low latency).[43]
In 2024, Algorand Foundation launched an open-source standard for more secure communications between wallets.[44]
Algorand uses the post-quantum signature scheme Falcon (signature scheme).[45]
The unit of account of the Algorand protocol is the ALGO. The protocol's supply of ALGO is limited to 10 billion units. One ALGO is divisible to six decimal places, the smallest unit is called microALGO (ALGO), equal to 1/1,000,000 (one millionth) ALGO.[46]
Since 2019, Algorand has been a partner of World Chess.[47]
In 2021, Italia Olivicola, Italy's largest olive and olive oil producers' organization, partnered with Euranet to implement blockchain technology based on Algorand.[48] SIAE, the Italian Society of Authors and Publishers, also announced a project on copyright management using Algorand in the same year.[49]
In 2022, Algorand's blockchain was used by Robert Irwin and the Australia Zoo for a series of NFTs.[50] [51]
In 2023, Italy's 'Fideiussioni Digitali' initiative to reduce fraud in bank and insurance guarantees, selected Algorand as its blockchain.[52]
In 2024, CNBC-TV18 reported that Algorand's blockchain was being tested for use in a digital identification to help women in India access public health programs.[53]
The Algorand blockchain had its first tokenized money market fund launch in June 2024.[54]