developers/zcash-zf-frost-dag.html

255 lines
17 KiB
HTML
Raw Normal View History

<!DOCTYPE html>
<html>
<head>
<title>Zcash zf-frost DAG</title>
<!-- Pan/zoom SVGs -->
<script src="https://bumbu.me/svg-pan-zoom/dist/svg-pan-zoom.min.js"></script>
<link rel="stylesheet" href="zcash-dag.css">
<style>
@media (prefers-color-scheme: dark) {
body {
/* Material dark theme surface colour */
background-color: #121212;
}
}
</style>
</head>
<body>
<div id="dag"><svg width="783pt" height="935pt"
viewBox="0.00 0.00 783.00 934.50" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<g id="graph0" class="graph" transform="scale(1 1) rotate(0) translate(4 930.5)">
<polygon fill="#ffffff" stroke="transparent" points="-4,4 -4,-930.5 779,-930.5 779,4 -4,4"/>
<g id="clust1" class="cluster">
<title>cluster_0</title>
<polygon fill="none" stroke="#0000ff" points="289,-175.5 289,-282.5 522,-282.5 522,-175.5 289,-175.5"/>
<text text-anchor="middle" x="405.5" y="-267.3" font-family="Times,serif" font-size="14.00" fill="#000000">Epic: FROST Audit</text>
</g>
<g id="clust2" class="cluster">
<title>cluster_1</title>
<polygon fill="none" stroke="#0000ff" points="18,-347.5 18,-825.5 775,-825.5 775,-347.5 18,-347.5"/>
<text text-anchor="middle" x="396.5" y="-810.3" font-family="Times,serif" font-size="14.00" fill="#000000">Epic: FROST Proof of Concept/Prototype and Documentation</text>
</g>
<g id="clust3" class="cluster">
<title>cluster_2</title>
<polygon fill="none" stroke="#0000ff" points="18,-833.5 18,-926.5 252,-926.5 252,-833.5 18,-833.5"/>
<text text-anchor="middle" x="135" y="-911.3" font-family="Times,serif" font-size="14.00" fill="#000000">Epic: Re&#45;randomizable FROST</text>
</g>
<g id="clust4" class="cluster">
<title>cluster_3</title>
<polygon fill="none" stroke="#0000ff" points="0,-62.5 0,-339.5 269,-339.5 269,-62.5 0,-62.5"/>
<text text-anchor="middle" x="134.5" y="-324.3" font-family="Times,serif" font-size="14.00" fill="#000000">Epic: Prep crates / APIs for release</text>
</g>
<!-- ZcashFoundation/frost#235 -->
<g id="node1" class="node open">
<title>ZcashFoundation/frost#235</title>
<g id="a_node1"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/235" xlink:title="ZcashFoundation/frost#235&#10;Tag a `frost` release&#10;based on the final&#10;version of the spec" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" points="514,-251.5 297,-251.5 297,-183.5 514,-183.5 514,-251.5"/>
<text text-anchor="middle" x="405.5" y="-236.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#235</text>
<text text-anchor="middle" x="405.5" y="-221.3" font-family="Times,serif" font-size="14.00" fill="#000000">Tag a `frost` release</text>
<text text-anchor="middle" x="405.5" y="-206.3" font-family="Times,serif" font-size="14.00" fill="#000000">based on the final</text>
<text text-anchor="middle" x="405.5" y="-191.3" font-family="Times,serif" font-size="14.00" fill="#000000">version of the spec</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#238 -->
<g id="node2" class="node open">
<title>ZcashFoundation/frost#238</title>
<g id="a_node2"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/238" xlink:title="ZcashFoundation/frost#238&#10;Demo for Trusted Dealer&#10;key share generation" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-794 26,-794 26,-741 243,-741 243,-794"/>
<text text-anchor="middle" x="134.5" y="-778.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#238</text>
<text text-anchor="middle" x="134.5" y="-763.8" font-family="Times,serif" font-size="14.00" fill="#000000">Demo for Trusted Dealer</text>
<text text-anchor="middle" x="134.5" y="-748.8" font-family="Times,serif" font-size="14.00" fill="#000000">key share generation</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#239 -->
<g id="node3" class="node open">
<title>ZcashFoundation/frost#239</title>
<g id="a_node3"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/239" xlink:title="ZcashFoundation/frost#239&#10;Demo for Signature&#10;generation: Participant&#10;CLI" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" points="514,-794.5 297,-794.5 297,-726.5 514,-726.5 514,-794.5"/>
<text text-anchor="middle" x="405.5" y="-779.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#239</text>
<text text-anchor="middle" x="405.5" y="-764.3" font-family="Times,serif" font-size="14.00" fill="#000000">Demo for Signature</text>
<text text-anchor="middle" x="405.5" y="-749.3" font-family="Times,serif" font-size="14.00" fill="#000000">generation: Participant</text>
<text text-anchor="middle" x="405.5" y="-734.3" font-family="Times,serif" font-size="14.00" fill="#000000">CLI</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#238&#45;&gt;ZcashFoundation/frost#239 -->
<g id="edge1" class="edge">
<title>ZcashFoundation/frost#238&#45;&gt;ZcashFoundation/frost#239</title>
<path fill="none" stroke="#000000" d="M243.16,-764.69C257.52,-764.32 272.3,-763.94 286.81,-763.57"/>
<polygon fill="#000000" stroke="#000000" points="286.9044,-767.0688 296.81,-763.31 286.7224,-760.0712 286.9044,-767.0688"/>
</g>
<!-- ZcashFoundation/frost#249 -->
<g id="node4" class="node open">
<title>ZcashFoundation/frost#249</title>
<g id="a_node4"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/249" xlink:title="ZcashFoundation/frost#249&#10;Demo for Signature&#10;generation: Coordinator&#10;CLI" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" points="767,-794.5 550,-794.5 550,-726.5 767,-726.5 767,-794.5"/>
<text text-anchor="middle" x="658.5" y="-779.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#249</text>
<text text-anchor="middle" x="658.5" y="-764.3" font-family="Times,serif" font-size="14.00" fill="#000000">Demo for Signature</text>
<text text-anchor="middle" x="658.5" y="-749.3" font-family="Times,serif" font-size="14.00" fill="#000000">generation: Coordinator</text>
<text text-anchor="middle" x="658.5" y="-734.3" font-family="Times,serif" font-size="14.00" fill="#000000">CLI</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#239&#45;&gt;ZcashFoundation/frost#249 -->
<g id="edge2" class="edge">
<title>ZcashFoundation/frost#239&#45;&gt;ZcashFoundation/frost#249</title>
<path fill="none" stroke="#000000" d="M514.26,-760.5C522.64,-760.5 531.13,-760.5 539.57,-760.5"/>
<polygon fill="#000000" stroke="#000000" points="539.83,-764.0001 549.83,-760.5 539.83,-757.0001 539.83,-764.0001"/>
</g>
<!-- ZcashFoundation/frost#240 -->
<g id="node5" class="node open">
<title>ZcashFoundation/frost#240</title>
<g id="a_node5"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/240" xlink:title="ZcashFoundation/frost#240&#10;Demo for Signature&#10;verification" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-723 26,-723 26,-670 243,-670 243,-723"/>
<text text-anchor="middle" x="134.5" y="-707.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#240</text>
<text text-anchor="middle" x="134.5" y="-692.8" font-family="Times,serif" font-size="14.00" fill="#000000">Demo for Signature</text>
<text text-anchor="middle" x="134.5" y="-677.8" font-family="Times,serif" font-size="14.00" fill="#000000">verification</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#252 -->
<g id="node6" class="node open">
<title>ZcashFoundation/frost#252</title>
<g id="a_node6"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/252" xlink:title="ZcashFoundation/frost#252&#10;Demo for Distributed Key&#10;Generation (DKG)" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-652 26,-652 26,-599 243,-599 243,-652"/>
<text text-anchor="middle" x="134.5" y="-636.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#252</text>
<text text-anchor="middle" x="134.5" y="-621.8" font-family="Times,serif" font-size="14.00" fill="#000000">Demo for Distributed Key</text>
<text text-anchor="middle" x="134.5" y="-606.8" font-family="Times,serif" font-size="14.00" fill="#000000">Generation (DKG)</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#242 -->
<g id="node7" class="node open">
<title>ZcashFoundation/frost#242</title>
<g id="a_node7"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/242" xlink:title="ZcashFoundation/frost#242&#10;Implement broadcast&#10;channel for FROST PoC" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-581 26,-581 26,-528 243,-528 243,-581"/>
<text text-anchor="middle" x="134.5" y="-565.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#242</text>
<text text-anchor="middle" x="134.5" y="-550.8" font-family="Times,serif" font-size="14.00" fill="#000000">Implement broadcast</text>
<text text-anchor="middle" x="134.5" y="-535.8" font-family="Times,serif" font-size="14.00" fill="#000000">channel for FROST PoC</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#251 -->
<g id="node8" class="node open">
<title>ZcashFoundation/frost#251</title>
<g id="a_node8"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/251" xlink:title="ZcashFoundation/frost#251&#10;Publish FROST API&#10;reference docs to&#10;doc.frost.zfnd.org" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-509.5 26,-509.5 26,-441.5 243,-441.5 243,-509.5"/>
<text text-anchor="middle" x="134.5" y="-494.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#251</text>
<text text-anchor="middle" x="134.5" y="-479.3" font-family="Times,serif" font-size="14.00" fill="#000000">Publish FROST API</text>
<text text-anchor="middle" x="134.5" y="-464.3" font-family="Times,serif" font-size="14.00" fill="#000000">reference docs to</text>
<text text-anchor="middle" x="134.5" y="-449.3" font-family="Times,serif" font-size="14.00" fill="#000000">doc.frost.zfnd.org</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#241 -->
<g id="node9" class="node open">
<title>ZcashFoundation/frost#241</title>
<g id="a_node9"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/241" xlink:title="ZcashFoundation/frost#241&#10;Generate and publish&#10;documentation for&#10;`frost&#45;*` crates" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-423.5 26,-423.5 26,-355.5 243,-355.5 243,-423.5"/>
<text text-anchor="middle" x="134.5" y="-408.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#241</text>
<text text-anchor="middle" x="134.5" y="-393.3" font-family="Times,serif" font-size="14.00" fill="#000000">Generate and publish</text>
<text text-anchor="middle" x="134.5" y="-378.3" font-family="Times,serif" font-size="14.00" fill="#000000">documentation for</text>
<text text-anchor="middle" x="134.5" y="-363.3" font-family="Times,serif" font-size="14.00" fill="#000000">`frost&#45;*` crates</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#216 -->
<g id="node10" class="node open">
<title>ZcashFoundation/frost#216</title>
<g id="a_node10"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/216" xlink:title="ZcashFoundation/frost#216&#10;Write security proof for&#10;Rerandomized FROST" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-895 26,-895 26,-842 243,-842 243,-895"/>
<text text-anchor="middle" x="134.5" y="-879.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#216</text>
<text text-anchor="middle" x="134.5" y="-864.8" font-family="Times,serif" font-size="14.00" fill="#000000">Write security proof for</text>
<text text-anchor="middle" x="134.5" y="-849.8" font-family="Times,serif" font-size="14.00" fill="#000000">Rerandomized FROST</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#189 -->
<g id="node11" class="node open">
<title>ZcashFoundation/frost#189</title>
<g id="a_node11"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/189" xlink:title="ZcashFoundation/frost#189&#10;Updated release drafter&#10;config to match zebrad&#39;s" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-308 26,-308 26,-255 243,-255 243,-308"/>
<text text-anchor="middle" x="134.5" y="-292.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#189</text>
<text text-anchor="middle" x="134.5" y="-277.8" font-family="Times,serif" font-size="14.00" fill="#000000">Updated release drafter</text>
<text text-anchor="middle" x="134.5" y="-262.8" font-family="Times,serif" font-size="14.00" fill="#000000">config to match zebrad&#39;s</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#189&#45;&gt;ZcashFoundation/frost#235 -->
<g id="edge3" class="edge">
<title>ZcashFoundation/frost#189&#45;&gt;ZcashFoundation/frost#235</title>
<path fill="none" stroke="#000000" d="M243.16,-255.84C257.52,-252.45 272.3,-248.96 286.81,-245.53"/>
<polygon fill="#000000" stroke="#000000" points="287.8813,-248.8734 296.81,-243.17 286.2734,-242.0606 287.8813,-248.8734"/>
</g>
<!-- ZcashFoundation/frost#190 -->
<g id="node12" class="node open">
<title>ZcashFoundation/frost#190</title>
<g id="a_node12"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/190" xlink:title="ZcashFoundation/frost#190&#10;Write a release checklist" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-236.5 26,-236.5 26,-198.5 243,-198.5 243,-236.5"/>
<text text-anchor="middle" x="134.5" y="-221.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#190</text>
<text text-anchor="middle" x="134.5" y="-206.3" font-family="Times,serif" font-size="14.00" fill="#000000">Write a release checklist</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#190&#45;&gt;ZcashFoundation/frost#235 -->
<g id="edge4" class="edge">
<title>ZcashFoundation/frost#190&#45;&gt;ZcashFoundation/frost#235</title>
<path fill="none" stroke="#000000" d="M243.16,-217.5C257.38,-217.5 272.01,-217.5 286.39,-217.5"/>
<polygon fill="#000000" stroke="#000000" points="286.81,-221.0001 296.81,-217.5 286.81,-214.0001 286.81,-221.0001"/>
</g>
<!-- ZcashFoundation/frost#79 -->
<g id="node13" class="node open">
<title>ZcashFoundation/frost#79</title>
<g id="a_node13"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/79" xlink:title="ZcashFoundation/frost#79&#10;Publish `frost&#45;` crates" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="238.5,-180.5 30.5,-180.5 30.5,-142.5 238.5,-142.5 238.5,-180.5"/>
<text text-anchor="middle" x="134.5" y="-165.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#79</text>
<text text-anchor="middle" x="134.5" y="-150.3" font-family="Times,serif" font-size="14.00" fill="#000000">Publish `frost&#45;` crates</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#166 -->
<g id="node14" class="node open">
<title>ZcashFoundation/frost#166</title>
<g id="a_node14"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/166" xlink:title="ZcashFoundation/frost#166&#10;Squat crate names on&#10;crates.io" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-124 26,-124 26,-71 243,-71 243,-124"/>
<text text-anchor="middle" x="134.5" y="-108.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#166</text>
<text text-anchor="middle" x="134.5" y="-93.8" font-family="Times,serif" font-size="14.00" fill="#000000">Squat crate names on</text>
<text text-anchor="middle" x="134.5" y="-78.8" font-family="Times,serif" font-size="14.00" fill="#000000">crates.io</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#215 -->
<g id="node15" class="node open">
<title>ZcashFoundation/frost#215</title>
<g id="a_node15"><a xlink:href="https://github.com/ZcashFoundation/frost/pull/215" xlink:title="ZcashFoundation/frost#215&#10;Update p256 requirement&#10;from 0.11.1 to 0.12.0" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="243,-53 26,-53 26,-49 22,-49 22,-45 26,-45 26,-8 22,-8 22,-4 26,-4 26,0 243,0 243,-53"/>
<polyline fill="none" stroke="#000000" stroke-width="2" points="26,-49 30,-49 30,-45 26,-45 "/>
<polyline fill="none" stroke="#000000" stroke-width="2" points="26,-8 30,-8 30,-4 26,-4 "/>
<text text-anchor="middle" x="134.5" y="-37.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#215</text>
<text text-anchor="middle" x="134.5" y="-22.8" font-family="Times,serif" font-size="14.00" fill="#000000">Update p256 requirement</text>
<text text-anchor="middle" x="134.5" y="-7.8" font-family="Times,serif" font-size="14.00" fill="#000000">from 0.11.1 to 0.12.0</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#215&#45;&gt;ZcashFoundation/frost#235 -->
<g id="edge5" class="edge">
<title>ZcashFoundation/frost#215&#45;&gt;ZcashFoundation/frost#235</title>
<path fill="none" stroke="#000000" d="M243.01,-45.86C252.11,-49.391 260.9,-53.565 269,-58.5 316.45,-87.428 355.87,-138.44 379.96,-174.89"/>
<polygon fill="#000000" stroke="#000000" points="377.0739,-176.8722 385.45,-183.36 382.9479,-173.0648 377.0739,-176.8722"/>
</g>
</g>
</svg>
</div>
<script>
svgPanZoom('#dag > svg', {
zoomScaleSensitivity: 0.4
});
</script>
</body>
</html>