developers/zcash-zf-frost-dag.html

168 lines
10 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="702pt" height="562pt"
viewBox="0.00 0.00 702.00 562.00" 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 558)">
<polygon fill="white" stroke="transparent" points="-4,4 -4,-558 698,-558 698,4 -4,4"/>
<g id="clust1" class="cluster">
<title>cluster_0</title>
<polygon fill="none" stroke="blue" points="109,-258 109,-351 341,-351 341,-258 109,-258"/>
<text text-anchor="middle" x="225" y="-335.8" font-family="Times,serif" font-size="14.00">Epic: Re&#45;randomizable FROST</text>
</g>
<g id="clust2" class="cluster">
<title>cluster_1</title>
<polygon fill="none" stroke="blue" points="0,0 0,-250 450,-250 450,0 0,0"/>
<text text-anchor="middle" x="225" y="-234.8" font-family="Times,serif" font-size="14.00">Epic: FROST Proof of Concept/Prototype and Documentation</text>
</g>
<!-- ZcashFoundation/frost#216 -->
<g id="node1" class="node open">
<title>ZcashFoundation/frost#216</title>
<g id="a_node1"><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="black" stroke-width="2" points="333,-319.5 117,-319.5 117,-266.5 333,-266.5 333,-319.5"/>
<text text-anchor="middle" x="225" y="-304.3" font-family="Times,serif" font-size="14.00">ZcashFoundation/frost#216</text>
<text text-anchor="middle" x="225" y="-289.3" font-family="Times,serif" font-size="14.00">Write security proof for</text>
<text text-anchor="middle" x="225" y="-274.3" font-family="Times,serif" font-size="14.00">Rerandomized FROST</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#239 -->
<g id="node2" class="node open">
<title>ZcashFoundation/frost#239</title>
<g id="a_node2"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/239" xlink:title="ZcashFoundation/frost#239&#10;Epic: Demo for Signature&#10;generation &#45; Participant&#10;CLI" target="_blank">
<polygon fill="#c2e0c6" stroke="black" stroke-width="2" points="333,-219 117,-219 117,-151 333,-151 333,-219"/>
<text text-anchor="middle" x="225" y="-203.8" font-family="Times,serif" font-size="14.00">ZcashFoundation/frost#239</text>
<text text-anchor="middle" x="225" y="-188.8" font-family="Times,serif" font-size="14.00">Epic: Demo for Signature</text>
<text text-anchor="middle" x="225" y="-173.8" font-family="Times,serif" font-size="14.00">generation &#45; Participant</text>
<text text-anchor="middle" x="225" y="-158.8" font-family="Times,serif" font-size="14.00">CLI</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#240 -->
<g id="node3" class="node open">
<title>ZcashFoundation/frost#240</title>
<g id="a_node3"><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="black" stroke-width="2" points="333,-132.5 117,-132.5 117,-79.5 333,-79.5 333,-132.5"/>
<text text-anchor="middle" x="225" y="-117.3" font-family="Times,serif" font-size="14.00">ZcashFoundation/frost#240</text>
<text text-anchor="middle" x="225" y="-102.3" font-family="Times,serif" font-size="14.00">Demo for Signature</text>
<text text-anchor="middle" x="225" y="-87.3" font-family="Times,serif" font-size="14.00">verification</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#242 -->
<g id="node4" class="node open">
<title>ZcashFoundation/frost#242</title>
<g id="a_node4"><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="black" stroke-width="2" points="333,-61.5 117,-61.5 117,-8.5 333,-8.5 333,-61.5"/>
<text text-anchor="middle" x="225" y="-46.3" font-family="Times,serif" font-size="14.00">ZcashFoundation/frost#242</text>
<text text-anchor="middle" x="225" y="-31.3" font-family="Times,serif" font-size="14.00">Implement broadcast</text>
<text text-anchor="middle" x="225" y="-16.3" font-family="Times,serif" font-size="14.00">channel for FROST PoC</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#235 -->
<g id="node5" class="node closed">
<title>ZcashFoundation/frost#235</title>
<g id="a_node5"><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="#fad8c7" stroke="black" points="694,-440 478,-440 478,-372 694,-372 694,-440"/>
<text text-anchor="middle" x="586" y="-424.8" font-family="Times,serif" font-size="14.00">ZcashFoundation/frost#235</text>
<text text-anchor="middle" x="586" y="-409.8" font-family="Times,serif" font-size="14.00">Tag a `frost` release</text>
<text text-anchor="middle" x="586" y="-394.8" font-family="Times,serif" font-size="14.00">based on the final</text>
<text text-anchor="middle" x="586" y="-379.8" font-family="Times,serif" font-size="14.00">version of the spec</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#189 -->
<g id="node6" class="node open">
<title>ZcashFoundation/frost#189</title>
<g id="a_node6"><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="black" stroke-width="2" points="333,-468.5 117,-468.5 117,-415.5 333,-415.5 333,-468.5"/>
<text text-anchor="middle" x="225" y="-453.3" font-family="Times,serif" font-size="14.00">ZcashFoundation/frost#189</text>
<text text-anchor="middle" x="225" y="-438.3" font-family="Times,serif" font-size="14.00">Updated release drafter</text>
<text text-anchor="middle" x="225" y="-423.3" font-family="Times,serif" font-size="14.00">config to match zebrad&#39;s</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#189&#45;&gt;ZcashFoundation/frost#235 -->
<g id="edge1" class="edge">
<title>ZcashFoundation/frost#189&#45;&gt;ZcashFoundation/frost#235</title>
<path fill="none" stroke="black" d="M333.23,-431.25C375.59,-427 424.4,-422.11 467.69,-417.76"/>
<polygon fill="black" stroke="black" points="468.11,-421.24 477.71,-416.76 467.41,-414.27 468.11,-421.24"/>
</g>
<!-- ZcashFoundation/frost#190 -->
<g id="node7" class="node open">
<title>ZcashFoundation/frost#190</title>
<g id="a_node7"><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="black" stroke-width="2" points="333,-397 117,-397 117,-359 333,-359 333,-397"/>
<text text-anchor="middle" x="225" y="-381.8" font-family="Times,serif" font-size="14.00">ZcashFoundation/frost#190</text>
<text text-anchor="middle" x="225" y="-366.8" font-family="Times,serif" font-size="14.00">Write a release checklist</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#190&#45;&gt;ZcashFoundation/frost#235 -->
<g id="edge2" class="edge">
<title>ZcashFoundation/frost#190&#45;&gt;ZcashFoundation/frost#235</title>
<path fill="none" stroke="black" d="M333.23,-386.36C375.59,-389.67 424.4,-393.47 467.69,-396.85"/>
<polygon fill="black" stroke="black" points="467.47,-400.34 477.71,-397.63 468.01,-393.36 467.47,-400.34"/>
</g>
<!-- ZcashFoundation/frost#480 -->
<g id="node8" class="node open">
<title>ZcashFoundation/frost#480</title>
<g id="a_node8"><a xlink:href="https://github.com/ZcashFoundation/frost/pull/480" xlink:title="ZcashFoundation/frost#480&#10;check number of&#10;commitments in sign()" target="_blank">
<polygon fill="#c2e0c6" stroke="black" stroke-width="2" points="333,-546.5 117,-546.5 117,-542.5 113,-542.5 113,-538.5 117,-538.5 117,-501.5 113,-501.5 113,-497.5 117,-497.5 117,-493.5 333,-493.5 333,-546.5"/>
<polyline fill="none" stroke="black" stroke-width="2" points="117,-542.5 121,-542.5 121,-538.5 117,-538.5 "/>
<polyline fill="none" stroke="black" stroke-width="2" points="117,-501.5 121,-501.5 121,-497.5 117,-497.5 "/>
<text text-anchor="middle" x="225" y="-531.3" font-family="Times,serif" font-size="14.00">ZcashFoundation/frost#480</text>
<text text-anchor="middle" x="225" y="-516.3" font-family="Times,serif" font-size="14.00">check number of</text>
<text text-anchor="middle" x="225" y="-501.3" font-family="Times,serif" font-size="14.00">commitments in sign()</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#482 -->
<g id="node9" class="node open">
<title>ZcashFoundation/frost#482</title>
<g id="a_node9"><a xlink:href="https://github.com/ZcashFoundation/frost/pull/482" xlink:title="ZcashFoundation/frost#482&#10;change reconstruct() to&#10;take KeyPackages;&#10;validate size" target="_blank">
<polygon fill="#c2e0c6" stroke="black" points="694,-554 478,-554 478,-550 474,-550 474,-546 478,-546 478,-494 474,-494 474,-490 478,-490 478,-486 694,-486 694,-554"/>
<polyline fill="none" stroke="black" points="478,-550 482,-550 482,-546 478,-546 "/>
<polyline fill="none" stroke="black" points="478,-494 482,-494 482,-490 478,-490 "/>
<text text-anchor="middle" x="586" y="-538.8" font-family="Times,serif" font-size="14.00">ZcashFoundation/frost#482</text>
<text text-anchor="middle" x="586" y="-523.8" font-family="Times,serif" font-size="14.00">change reconstruct() to</text>
<text text-anchor="middle" x="586" y="-508.8" font-family="Times,serif" font-size="14.00">take KeyPackages;</text>
<text text-anchor="middle" x="586" y="-493.8" font-family="Times,serif" font-size="14.00">validate size</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#480&#45;&gt;ZcashFoundation/frost#482 -->
<g id="edge3" class="edge">
<title>ZcashFoundation/frost#480&#45;&gt;ZcashFoundation/frost#482</title>
<path fill="none" stroke="black" d="M333.23,-520C375.59,-520 424.4,-520 467.69,-520"/>
<polygon fill="black" stroke="black" points="467.71,-523.5 477.71,-520 467.71,-516.5 467.71,-523.5"/>
</g>
</g>
</svg>
</div>
<script>
svgPanZoom('#dag > svg', {
zoomScaleSensitivity: 0.4
});
</script>
</body>
</html>