-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathethereum_research_records.json
484 lines (484 loc) · 20.8 KB
/
ethereum_research_records.json
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
{
"sharding": {
"summary": "",
"description": "",
"improves": ["throughput", "transaction cost"],
"worsen": ["complexity"],
"layer": 1,
"tags": ["sharding", "architecture"],
"comments": [
"Validator - a participant in the Casper/sharding consensus system. You can become one by depositing 32 ETH into the Casper mechanism.",
"Active validator set - those validators who are currently participating, and which the Casper mechanism looks to produce and attest to blocks, cross-links and other consensus objects.",
"Committee - a (pseudo-) randomly sampled subset of the active validator set. When a committee is referred to collectively, as in \"this committee attests to X\", this is assumed to mean \"some subset of that committee that contains enough validators that the protocol recognizes it as representing the committee\".",
"Proposer - the validator that creates a block",
"Attester - a validator that is part of a committee that needs to sign off on a block.",
"Beacon chain - the central PoS chain that is the base of the sharding system.",
"Shard chain - one of the chains on which transactions take place and account data is stored.",
"Cross-link - a set of signatures from a committee attesting to a block in a shard chain, which can be included into the beacon chain. Cross-links are the main means by which the beacon chain “learns about” the updated state of shard chains.",
"Epoch - a period of 64 blocks.",
"Finalized, justified - see Casper FFG finalization here: https://arxiv.org/abs/1710.09437"
],
"resources": [
{"https://docs.google.com/presentation/d/1mdmmgQlRFUvznq1jdmRwkwEyQB0YON5yAg4ArxtanE4": "Sharding introduction by EF"},
{"https://notes.ethereum.org/9MMuzWeFTTSg-3Tz_YeiBA?view": "Ethereum 2.0 Devs Handbook and FAQs"},
{"https://github.com/ethereum/wiki/wiki/Sharding-FAQs": "Official FAQ"},
{"https://vitalik.ca/files/Ithaca201807_Sharding.pdf": "Sharding presentation slides by Vitalik"},
{"https://medium.com/prysmatic-labs/how-to-scale-ethereum-sharding-explained-ba2e283b7fce": "Sharding high level overview by Prysmatic labs"},
{"https://notes.ethereum.org/s/B1-7aivmX": "ECDC Berlin, July 1st Sharding Meeting"},
{"https://www.youtube.com/playlist?list=PLaM7G4Llrb7zEHK2UzQo3kxadPyeUy2sZ": "ECDC Berlin videos"},
{"https://notes.ethereum.org/SCIg8AH5SA-O4C1G1LYZHQ": "WIP Specification of Casper + Sharding chain"},
{"https://ethresear.ch/t/convenience-link-to-full-casper-chain-v2-spec/2332/12": "Ongoing discussion on the Casper + Sharding spec"},
{"https://ethresear.ch/t/offchain-collation-headers/1679/6": "Offchain collation headers proposal"},
{"https://docs.google.com/presentation/d/1aqU1gK8B_sozm6orNVqqyvBTC2u2_13Re0Fi99rFhjg/edit#slide=id.g413fdd60fc_1_233": "oblique hashes explanation"}
],
"status": "research",
"last_update": "",
"implementations": [""],
"dependencies": ["beacon chain", "shard chain", "Casper FFG", "Proof of Stake"],
"required_by": [""]
},
"beacon chain": {
"summary": "The central PoS chain that is the base of the sharding system.",
"description": "",
"improves": [""],
"layer": 1,
"tags": ["sharding"],
"comments": [
"In charge a generating a heartbeat: a strong random number generated at regular intervals",
"In charge of cross-links, slashing conditions, accounting, Casper FFG"
],
"resources": [
{"https://notes.ethereum.org/SCIg8AH5SA-O4C1G1LYZHQ#Beacon-chain": "Beacon chain specification (WIP)"},
{"https://www.mindomo.com/mindmap/beacon-chain-state-fcf0e883590443328356ad19bb83103e": "Mind map of the beacon chain"}
],
"status": "proof-of-concept",
"last_update": "2018-07-18",
"implementations": [
"https://github.com/ethereum/beacon_chain",
"https://github.com/prysmaticlabs/beacon-chain",
"https://github.com/sigp/rust_beacon_chain",
"https://github.com/ChainSafeSystems/lodestar_chain",
"https://github.com/ethereum/research/tree/1830ae20915ea9bfb0363793ff3eec06ffbd9889/beacon_chain_impl",
"https://github.com/status-im/nim-beacon-chain"
],
"dependencies": ["RANDAO", "Blake2"],
"required_by": [""]
},
"RANDAO": {
"summary": "A random number generator based on participants organized in a decentralized autonomous organization",
"description": "",
"improves": [""],
"layer": 1,
"tags": ["sharding", "cryptography", "random number generator"],
"comments": [
"It should be completely deterministic given a blockchain state so that client can sync in a deferred manner.",
"It should not be predictable, so that it can be used as a strong PRNG (or even cryptographic RNG.",
"VDFs: Verifiable Delay Functions"
],
"resources": [
{"https://docs.google.com/presentation/d/13OAGL42yzOvQUKvJJ0EBsAAne25yA7sv9RC8FfPhtyo/edit#slide=id.p": "Ethereum 2.0 randomness presentation"},
{"https://notes.ethereum.org/SCIg8AH5SA-O4C1G1LYZHQ#Beacon-chain": "Beacon chain specification (WIP)"},
{"https://ethresear.ch/t/making-the-randao-less-influenceable-using-a-random-1-bit-clock/2566/17": "Proposal on reducing influence of validator on the final number generated"},
{"https://ethresear.ch/t/rng-exploitability-analysis-assuming-pure-randao-based-main-chain/1825": "Exploitability analysis of the RANDAO RNG"},
{"https://blog.ethereum.org/2015/08/28/on-anti-pre-revelation-games/": "2015 article on collusion in a RANDAO"},
{"http://swende.se/blog/Breaking_the_house.html": "2015 article on breaking casino smart-contract random number generator"},
{"https://forum.ethereum.org/discussion/2031/randao-a-dao-working-as-rng": "RANDAO announcement and discussion"},
{"https://ethresear.ch/t/fork-free-randao/1835/3": "Fork-free RANDAO proposition"},
{"https://medium.com/ultrayolo/ultrayolos-random-number-generation-rng-on-the-blockchain-proof-of-randomness-c8e35d538d5a": "Overview of RNG techniques on the blockchain"},
{"https://blog.positive.com/predicting-random-numbers-in-ethereum-smart-contracts-e5358c6b8620?gi=9d3d46afbaec": "Blockchain PRNGs vulnerabilities"}
],
"status": "research",
"last_update": "2018-07-18",
"implementations": [
"https://github.com/randao/randao"
],
"dependencies": ["RANDAO"],
"required_by": [""]
},
"shard chain": {
"summary": "One of the chains on which transactions take place and account data is stored.",
"description": "",
"improves": ["throughput", "transaction cost"],
"layer": 1,
"tags": ["sharding"],
"comments": [""],
"resources": [
{}
],
"status": "proof-of-concept",
"last_update": "2018-07-18",
"implementations": [
],
"dependencies": [""],
"required_by": [""]
},
"BLS signature aggregation": {
"summary": "",
"description": "",
"improves": ["throughput"],
"layer": 1,
"tags": ["cryptography"],
"use-cases": [
"Solve the signature verification bottleneck. ECDSA would take a day when BLS aggregation would take a couple of minutes"
],
"comments": [
"Not quantum secure",
"Will be replaced by STARKs",
"Milagro-crypto is a professionally-written crypto primitive library in C, C++, Java, Rust, Go with BLS primitives and proper constant time bignum implementation"
],
"resources": [
{"https://orbs.com/wp-content/uploads/2018/07/Threshold-Cryptography-and-Digital-Key-Distribution.pdf": "Elliptic Curve, pairing curve and BLS presentation"},
{"https://crypto.stanford.edu/~dabo/pubs/papers/BLSmultisig.html": "BLS aggregation spec"},
{"https://github.com/zkcrypto/pairing/tree/master/src/bls12_381#bls12-381-instantiation": "Less math symbols, more specs"},
{"https://ethresear.ch/t/pragmatic-signature-aggregation-with-bls/2105": "EthResearch intrduction"},
{"https://eprint.iacr.org/2018/483.pdf": "Paper: Compact Multi-Signatures for Smaller Blockchains"},
{"https://github.com/zcash/zcash/issues/2502": "Zcash team presentation of BLS12-381, perf, security, implementation"},
{"https://medium.com/@VitalikButerin/exploring-elliptic-curve-pairings-c73c1864e627": "Explanation of Elliptic Curve pairings"},
{"https://www.maximintegrated.com/en/app-notes/index.mvp/id/5767": "ECDSA explanation"}
],
"status": "research",
"last_update": "2018-07-30",
"implementations": [
{"https://github.com/lovesh/signature-schemes": "Rust: based on Milagro Crypto"},
{"https://github.com/zkcrypto/pairing": "Rust: official Zcash curve implementation"},
{"https://github.com/str4d/bls": "Rust: (Zcash dev) complement to Zcash for key generation, signature and aggregate"},
{"https://github.com/leishman/bls_lib": "C++ by Alexander Leishmann, crypto researcher @ Stanford U"},
"https://github.com/dis2/bls12",
"https://github.com/terenc3t/go-bls/blob/master/bls.go",
"https://github.com/milagro-crypto/amcl/tree/master/version3/c",
"https://github.com/milagro-crypto/amcl/issues/29",
"https://github.com/relic-toolkit/relic/blob/master/src/cp/relic_cp_bls.c",
"https://github.com/blynn/pbc/blob/master/example/bls.c",
"https://github.com/herumi/bls",
"https://github.com/status-im/nim-milagro-crypto",
"https://github.com/Chia-Network/bls-signatures",
{"https://github.com/opporty-com/Plasma-Cash/tree/master/bls": "JavaScript: implementation wih aggregate sig by Opporty.com"},
{"https://github.com/dfinity/bn": "Dfinity BN and BLS curve implementation"}
],
"dependencies": [""],
"required_by": ["sharding"]
},
"Constant-time bignum": {
"summary": "If we want side-channel resistant custom implementation of cryptographic curves, we need constant-time bignum library",
"description": "",
"improves": [""],
"layer": 1,
"tags": ["cryptography"],
"use-cases": [
""
],
"comments": [
"Comments on BearSSL bignum implementation: https://crypto.stackexchange.com/a/59852"
],
"resources": [
{"https://bearssl.org/constanttime.html": "Constant Time cryptography"},
{"https://bearssl.org/ctmul.html": "Hardware multiplication is not always constant-time"}
],
"status": "research",
"last_update": "2018-07-23",
"implementations": [
"https://bearssl.org/gitweb/?p=BearSSL;a=tree;f=src/int;hb=HEAD",
"https://github.com/milagro-crypto/amcl/tree/master/version3/c"
],
"dependencies": [""],
"required_by": ["sharding"]
},
"Blake2": {
"summary": "Hashing algorithm",
"description": "",
"improves": [""],
"layer": 1,
"tags": ["cryptography"],
"use-cases": [
""
],
"comments": [
""
],
"resources": [
{}
],
"status": "implemented",
"last_update": "2018-07-20",
"implementations": [
"https://github.com/cheatfate/nimcrypto"
],
"dependencies": [""],
"required_by": ["beacon chain"]
},
"zk-stark": {
"summary": "ZK-STARK allows a party to prove validity of a claim (knowledge, ownership, transaction, ...) without disclosing non-public information.",
"description": "",
"improves": ["throughput", "privacy"],
"layer": 1,
"tags": ["cryptography"],
"use-cases": [
"Initial full node syncing",
"Decentralized banks: smart-contracts that pools funds which uses zk-stark to prove ownership and transfer money within the pool. Total value owned within the pool is kept private."
],
"comments": [
"Compared to ZK-SNARK, ZK-STARK does not rely on a thrid-party and is completely transparent",
"A ZK-STARK/ZK-SNARK proof is faster to compute than naively checking the claim its proving",
"ZK-STARK stands for Zero-Knowledge Succinct, Transparent, ARguments of Knowlegde",
"ZK-SNARK stands for Zero-Knowledge Succinct, Non-interactive, ARguments of Knowlegde"
],
"resources": [
{"https://cyber.stanford.edu/sites/default/files/elibensasson.pdf": "Zcash slides"},
{"https://eprint.iacr.org/2018/046.pdf": "Zcash paper"},
{"https://blog.ethereum.org/2016/12/05/zksnarks-in-a-nutshell/": "Overview of ZK-SNARK"},
{"https://medium.com/@VitalikButerin/zk-snarks-under-the-hood-b33151a013f6": "Overview of ZK-SNARK"},
{"https://vitalik.ca/general/2017/11/09/starks_part_1.html": "Overview of ZK-STARK"},
{"https://www.youtube.com/watch?v=VUN35BC11Qw": "Introduction video to ZK-SNARK"},
{"pending": "ECDC Berlin Starkware presentation"},
{"https://notes.ethereum.org/s/B1-7aivmX#⟠-6-Discussion-STARKs-in-sharding-with-Eli-Ben-Sasson-Uri-Kolodny-Avihu-Levy-StarkWare-and-Justin-Drake-Ethereum-Foundation": "Stark & sharding, ECDC Berlin"}
],
"status": "research",
"last_update": "2018-07-18",
"implementations": [""],
"dependencies": [""],
"required_by": [""]
},
"Proof-of-Stake": {
"summary": "",
"description": "",
"improves": ["energy consumption", "decentralization"],
"layer": 1,
"tags": ["proof of stake"],
"comments": [
"Currently 2 ways of doing PoS: 1. Chain-based PoS, similar to PoW. Stakers pseudo-randomly have the right to produce blocks.\n2. Byzantine Fault Tolerant (BFT) PoS."
],
"resources": [
{"https://github.com/ethereum/wiki/wiki/Proof-of-Stake-FAQs": "Official PoS FAQ"},
{"https://medium.com/@jonchoi/ethereum-casper-101-7a851a4f1eb0": "Proof of Stake design philosophy"},
{"https://medium.com/@tuurdemeester/critique-of-buterins-a-proof-of-stake-design-philosophy-49fc9ebb36c6": "Critique of PoS design philosophy"},
{"https://medium.com/@VitalikButerin/minimal-slashing-conditions-20f0b500fc6c": "Slashing and economic finality"},
{"https://ethresear.ch/t/pos-fork-choice-rule-desiderata/2636": "PoS fork choice rules (Recursive proximity to justification (RPJ)"}
],
"status": "research",
"last_update": "2018-07-18",
"implementations": [
""
],
"dependencies": [""],
"required_by": [""]
},
"Casper": {
"summary": "PoW to PoS transition research projects: Casper FFG by Vitalik and CBC-Casper by Vlad",
"description": "",
"improves": ["throughput"],
"layer": 1,
"tags": ["proof of stake", "architecture"],
"comments": [
""
],
"resources": [
{"https://blockgeeks.com/guides/ethereum-casper/": "In-depth dive in Caspers"},
{"https://medium.com/@jonchoi/ethereum-casper-101-7a851a4f1eb0": "Casper 101: introduction, goal, design, resources"},
{"https://ethereum.stackexchange.com/questions/332/what-is-the-difference-between-casper-and-tendermint": "Casper vs Tendermint"}
],
"status": "research",
"last_update": "2018-07-18",
"implementations": [
""
],
"dependencies": [""],
"required_by": [""]
},
"Casper CBC": {
"summary": "Casper the Friendly GHOST: Correct-by-Construction",
"description": "",
"improves": ["throughput"],
"layer": 1,
"tags": ["proof of stake"],
"comments": ["Though silent, as of July 2018, CBC-Casper is still ongoing: https://ethresear.ch/t/cbc-casper-in-the-face-of-the-new-pos-sharding-plans-on-ethereum/2444"],
"resources": [
{"https://github.com/ethereum/research/blob/master/papers/cbc-consensus/AbstractCBC.pdf": "Correct by Construction Consensus protocols"},
{"https://github.com/ethereum/research/blob/master/papers/CasperTFG/CasperTFG.pdf": "Casper CBC spec"}
],
"status": "research",
"last_update": "2018-07-18",
"implementations": [
""
],
"dependencies": [""],
"required_by": [""]
},
"Casper FFG": {
"summary": "Casper the Friendly Finality Gadget: a PoS finality system built on top of PoW",
"description": "",
"improves": ["throughput"],
"layer": 1,
"tags": ["proof of stake"],
"comments": [""],
"resources": [
{"https://arxiv.org/abs/1710.09437": "Casper FFG Paper"}
],
"status": "research",
"last_update": "2018-07-18",
"implementations": [
"https://notes.ethereum.org/zazJPIQSQL2u0pI0K1RShg"
],
"dependencies": [""],
"required_by": [""]
},
"state channel": {
"summary": "",
"description": "",
"improves": ["latency", "transaction cost"],
"worsen": [""],
"layer": 2,
"tags": [""],
"comments": [""],
"resources": [
{"https://medium.com/l4-media/making-sense-of-ethereums-layer-2-scaling-solutions-state-channels-plasma-and-truebit-22cb40dcc2f4": "overview of layer 2 solutions"}
],
"status": "research",
"last_update": "2018-07-18",
"implementations": [
""
],
"dependencies": [""],
"required_by": [""]
},
"Plasma": {
"summary": "",
"description": "",
"improves": ["throughput", "transaction cost"],
"worsen": [""],
"layer": 2,
"tags": [""],
"comments": [""],
"resources": [
{"https://medium.com/chain-cloud-company-blog/plasma-in-10-minutes-c856da94e339": "Plasma at a glance"},
{"https://medium.com/l4-media/making-sense-of-ethereums-layer-2-scaling-solutions-state-channels-plasma-and-truebit-22cb40dcc2f4": "overview of layer 2 solutions"},
{"https://ethresear.ch/t/minimal-viable-plasma/426": "Draft of minimum viable Plasma implementation"},
{"https://karl.tech/plasma-cash-simple-spec/": "Plasma Cash spec"},
{"https://ethresear.ch/t/pos-plasma-cash-with-sharded-validation/1486": "Plasma Cash + Sharded Validation"},
{"https://medium.com/chain-cloud-company-blog/plasma-in-10-minutes-c856da94e339": "Comparison of Plasma and Liquidity.Network offchain scaling solution"},
{"https://raiden.network/faq.html": "Raiden, an offchain transfer network using state channels (i.e. complements Plasma/Liquidity.Network"}
],
"status": "research",
"last_update": "2018-07-18",
"implementations": [
""
],
"dependencies": [""],
"required_by": [""]
},
"Truebit": {
"summary": "Offload complex/costly computation off-chain to a third party solver, with a challenge system to keep solver honest",
"description": "",
"improves": ["computation power"],
"worsen": [""],
"layer": 2,
"tags": [""],
"comments": [""],
"resources": [
{"https://medium.com/l4-media/making-sense-of-ethereums-layer-2-scaling-solutions-state-channels-plasma-and-truebit-22cb40dcc2f4": "Overview of layer 2 solutions"},
{"https://medium.com/@simondlr/an-intro-to-truebit-a-scalable-decentralized-computational-court-1475531400c3": "Introduction to Truebit"},
{"https://people.cs.uchicago.edu/~teutsch/papers/truebit.pdf": "Truebit paper"}
],
"status": "research",
"last_update": "2018-07-18",
"implementations": [
""
],
"dependencies": [""],
"required_by": [""]
},
"Kademlia": {
"summary": "Peer discovery",
"description": "",
"improves": ["decentralization"],
"worsen": [""],
"layer": 1,
"tags": ["networking", "protocol"],
"comments": [""],
"resources": [
""
],
"status": "poc",
"last_update": "2018-07-19",
"implementations": [
""
],
"dependencies": [""],
"required_by": [""]
},
"libp2p": {
"summary": "",
"description": "",
"improves": [""],
"worsen": [""],
"layer": 1,
"tags": ["networking", "library"],
"comments": [""],
"resources": [
""
],
"status": "poc",
"last_update": "2018-07-19",
"implementations": [
""
],
"dependencies": [""],
"required_by": [""]
},
"devp2p": {
"summary": "",
"description": "",
"improves": [""],
"worsen": [""],
"layer": 1,
"tags": ["networking"],
"comments": [""],
"resources": [
{"https://github.com/ethereum/wiki/wiki/ÐΞVp2p-Wire-Protocol": "Official wiki"}
],
"status": "poc",
"last_update": "2018-07-19",
"implementations": [
""
],
"dependencies": [""],
"required_by": [""]
},
"PubSub": {
"summary": "PubSub specifies how to subscribe to or publish events on the blockchain",
"description": "",
"improves": [""],
"worsen": [""],
"layer": 1,
"tags": ["networking", "protocol"],
"comments": [""],
"resources": [
{"https://github.com/ethereum/go-ethereum/wiki/RPC-PUB-SUB": "Geth wiki"}
],
"status": "draft",
"last_update": "2018-07-19",
"implementations": [
""
],
"dependencies": ["Floodsub", "GossipSub"],
"required_by": [""]
},
"GossipSub": {
"summary": "",
"description": "",
"improves": [""],
"worsen": [""],
"layer": 1,
"tags": ["networking", "protocol"],
"comments": [""],
"resources": [
{"https://github.com/libp2p/specs/blob/master/pubsub/gossipsub/README.md": "Spec - GossipSub: Proximity Aware Epidemic PubSub for libp2p"}
],
"status": "draft",
"last_update": "2018-07-19",
"implementations": [
""
],
"dependencies": [""],
"required_by": ["PubSub"]
}
}