developers/zcash-zf-frost-dag.html

361 lines
26 KiB
HTML

<!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="733pt" height="1389pt"
viewBox="0.00 0.00 733.00 1389.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 1385)">
<polygon fill="#ffffff" stroke="transparent" points="-4,4 -4,-1385 729,-1385 729,4 -4,4"/>
<g id="clust1" class="cluster">
<title>cluster_0</title>
<polygon fill="none" stroke="#0000ff" points="2,0 2,-193 725,-193 725,0 2,0"/>
<text text-anchor="middle" x="363.5" y="-177.8" font-family="Times,serif" font-size="14.00" fill="#000000">Epic: v8</text>
</g>
<g id="clust2" class="cluster">
<title>cluster_1</title>
<polygon fill="none" stroke="#0000ff" points="0,-201 0,-1140 481,-1140 481,-201 0,-201"/>
<text text-anchor="middle" x="240.5" y="-1124.8" font-family="Times,serif" font-size="14.00" fill="#000000">Epic: Zcon&#45;ready FROST</text>
</g>
<!-- ZcashFoundation/frost#97 -->
<g id="node1" class="node open">
<title>ZcashFoundation/frost#97</title>
<g id="a_node1"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/97" xlink:title="ZcashFoundation/frost#97&#10;frost&#45;core: update to&#10;spec v8" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" points="473,-73.5 265,-73.5 265,-20.5 473,-20.5 473,-73.5"/>
<text text-anchor="middle" x="369" y="-58.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#97</text>
<text text-anchor="middle" x="369" y="-43.3" font-family="Times,serif" font-size="14.00" fill="#000000">frost&#45;core: update to</text>
<text text-anchor="middle" x="369" y="-28.3" font-family="Times,serif" font-size="14.00" fill="#000000">spec v8</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#99 -->
<g id="node2" class="node open">
<title>ZcashFoundation/frost#99</title>
<g id="a_node2"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/99" xlink:title="ZcashFoundation/frost#99&#10;frost&#45;p256: update to use&#10;frost&#45;core v8" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" points="717,-70.5 509,-70.5 509,-17.5 717,-17.5 717,-70.5"/>
<text text-anchor="middle" x="613" y="-55.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#99</text>
<text text-anchor="middle" x="613" y="-40.3" font-family="Times,serif" font-size="14.00" fill="#000000">frost&#45;p256: update to use</text>
<text text-anchor="middle" x="613" y="-25.3" font-family="Times,serif" font-size="14.00" fill="#000000">frost&#45;core v8</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#97&#45;&gt;ZcashFoundation/frost#99 -->
<g id="edge1" class="edge">
<title>ZcashFoundation/frost#97&#45;&gt;ZcashFoundation/frost#99</title>
<path fill="none" stroke="#000000" d="M473.19,-45.719C481.57,-45.616 490.06,-45.512 498.51,-45.408"/>
<polygon fill="#000000" stroke="#000000" points="498.8141,-48.9046 508.77,-45.281 498.7274,-41.9051 498.8141,-48.9046"/>
</g>
<!-- ZcashFoundation/frost#98 -->
<g id="node3" class="node open">
<title>ZcashFoundation/frost#98</title>
<g id="a_node3"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/98" xlink:title="ZcashFoundation/frost#98&#10;frost&#45;ristretto255:&#10;update to use frost&#45;core&#10;v8" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" points="717,-157 509,-157 509,-89 717,-89 717,-157"/>
<text text-anchor="middle" x="613" y="-141.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#98</text>
<text text-anchor="middle" x="613" y="-126.8" font-family="Times,serif" font-size="14.00" fill="#000000">frost&#45;ristretto255:</text>
<text text-anchor="middle" x="613" y="-111.8" font-family="Times,serif" font-size="14.00" fill="#000000">update to use frost&#45;core</text>
<text text-anchor="middle" x="613" y="-96.8" font-family="Times,serif" font-size="14.00" fill="#000000">v8</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#97&#45;&gt;ZcashFoundation/frost#98 -->
<g id="edge2" class="edge">
<title>ZcashFoundation/frost#97&#45;&gt;ZcashFoundation/frost#98</title>
<path fill="none" stroke="#000000" d="M454.34,-73.581C468.77,-78.076 483.95,-82.805 498.98,-87.484"/>
<polygon fill="#000000" stroke="#000000" points="498.2214,-90.9136 508.81,-90.549 500.3052,-84.2309 498.2214,-90.9136"/>
</g>
<!-- ZcashFoundation/frost#102 -->
<g id="node4" class="node open">
<title>ZcashFoundation/frost#102</title>
<g id="a_node4"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/102" xlink:title="ZcashFoundation/frost#102&#10;frost&#45;core: add and use C&#10;iphersuite.identifier_to_&#10;scalar()" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="227,-162 10,-162 10,-94 227,-94 227,-162"/>
<text text-anchor="middle" x="118.5" y="-146.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#102</text>
<text text-anchor="middle" x="118.5" y="-131.8" font-family="Times,serif" font-size="14.00" fill="#000000">frost&#45;core: add and use C</text>
<text text-anchor="middle" x="118.5" y="-116.8" font-family="Times,serif" font-size="14.00" fill="#000000">iphersuite.identifier_to_</text>
<text text-anchor="middle" x="118.5" y="-101.8" font-family="Times,serif" font-size="14.00" fill="#000000">scalar()</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#102&#45;&gt;ZcashFoundation/frost#97 -->
<g id="edge3" class="edge">
<title>ZcashFoundation/frost#102&#45;&gt;ZcashFoundation/frost#97</title>
<path fill="none" stroke="#000000" d="M224.01,-93.88C241.72,-88.156 259.97,-82.254 277.3,-76.651"/>
<polygon fill="#000000" stroke="#000000" points="278.3823,-79.9795 286.82,-73.572 276.2282,-73.3192 278.3823,-79.9795"/>
</g>
<!-- ZcashFoundation/frost#101 -->
<g id="node5" class="node open">
<title>ZcashFoundation/frost#101</title>
<g id="a_node5"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/101" xlink:title="ZcashFoundation/frost#101&#10;frost&#45;core: support H4&#10;and H5 domain&#45;separated&#10;hashes per&#45;ciphersuite" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="227,-76 10,-76 10,-8 227,-8 227,-76"/>
<text text-anchor="middle" x="118.5" y="-60.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#101</text>
<text text-anchor="middle" x="118.5" y="-45.8" font-family="Times,serif" font-size="14.00" fill="#000000">frost&#45;core: support H4</text>
<text text-anchor="middle" x="118.5" y="-30.8" font-family="Times,serif" font-size="14.00" fill="#000000">and H5 domain&#45;separated</text>
<text text-anchor="middle" x="118.5" y="-15.8" font-family="Times,serif" font-size="14.00" fill="#000000">hashes per&#45;ciphersuite</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#101&#45;&gt;ZcashFoundation/frost#97 -->
<g id="edge4" class="edge">
<title>ZcashFoundation/frost#101&#45;&gt;ZcashFoundation/frost#97</title>
<path fill="none" stroke="#000000" d="M227.28,-44.171C236.3,-44.351 245.43,-44.534 254.49,-44.714"/>
<polygon fill="#000000" stroke="#000000" points="254.6019,-48.2168 264.67,-44.918 254.7422,-41.2183 254.6019,-48.2168"/>
</g>
<!-- ZcashFoundation/frost#86 -->
<g id="node6" class="node open">
<title>ZcashFoundation/frost#86</title>
<g id="a_node6"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/86" xlink:title="ZcashFoundation/frost#86&#10;frost&#45;core: update for&#10;spec version 6&amp;7" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" points="473,-814.5 265,-814.5 265,-761.5 473,-761.5 473,-814.5"/>
<text text-anchor="middle" x="369" y="-799.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#86</text>
<text text-anchor="middle" x="369" y="-784.3" font-family="Times,serif" font-size="14.00" fill="#000000">frost&#45;core: update for</text>
<text text-anchor="middle" x="369" y="-769.3" font-family="Times,serif" font-size="14.00" fill="#000000">spec version 6&amp;7</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#95 -->
<g id="node7" class="node open">
<title>ZcashFoundation/frost#95</title>
<g id="a_node7"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/95" xlink:title="ZcashFoundation/frost#95&#10;Flesh out all rustdoc in&#10;frost&#45;p256 public API" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-1108.5 14.5,-1108.5 14.5,-1055.5 222.5,-1055.5 222.5,-1108.5"/>
<text text-anchor="middle" x="118.5" y="-1093.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#95</text>
<text text-anchor="middle" x="118.5" y="-1078.3" font-family="Times,serif" font-size="14.00" fill="#000000">Flesh out all rustdoc in</text>
<text text-anchor="middle" x="118.5" y="-1063.3" font-family="Times,serif" font-size="14.00" fill="#000000">frost&#45;p256 public API</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#79 -->
<g id="node8" class="node open">
<title>ZcashFoundation/frost#79</title>
<g id="a_node8"><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" points="473,-1022 265,-1022 265,-984 473,-984 473,-1022"/>
<text text-anchor="middle" x="369" y="-1006.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#79</text>
<text text-anchor="middle" x="369" y="-991.8" font-family="Times,serif" font-size="14.00" fill="#000000">Publish `frost&#45;` crates</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#95&#45;&gt;ZcashFoundation/frost#79 -->
<g id="edge5" class="edge">
<title>ZcashFoundation/frost#95&#45;&gt;ZcashFoundation/frost#79</title>
<path fill="none" stroke="#000000" d="M202.61,-1055.5C233.77,-1045.6 268.75,-1034.6 298.56,-1025.2"/>
<polygon fill="#000000" stroke="#000000" points="299.971,-1028.4259 308.47,-1022.1 297.8811,-1021.7452 299.971,-1028.4259"/>
</g>
<!-- ZcashFoundation/frost#55 -->
<g id="node9" class="node open">
<title>ZcashFoundation/frost#55</title>
<g id="a_node9"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/55" xlink:title="ZcashFoundation/frost#55&#10;Rename participant&#10;indexes to participant&#10;identifiers or IDs" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-1037 14.5,-1037 14.5,-969 222.5,-969 222.5,-1037"/>
<text text-anchor="middle" x="118.5" y="-1021.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#55</text>
<text text-anchor="middle" x="118.5" y="-1006.8" font-family="Times,serif" font-size="14.00" fill="#000000">Rename participant</text>
<text text-anchor="middle" x="118.5" y="-991.8" font-family="Times,serif" font-size="14.00" fill="#000000">indexes to participant</text>
<text text-anchor="middle" x="118.5" y="-976.8" font-family="Times,serif" font-size="14.00" fill="#000000">identifiers or IDs</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#55&#45;&gt;ZcashFoundation/frost#79 -->
<g id="edge6" class="edge">
<title>ZcashFoundation/frost#55&#45;&gt;ZcashFoundation/frost#79</title>
<path fill="none" stroke="#000000" d="M222.56,-1003C233.15,-1003 243.96,-1003 254.65,-1003"/>
<polygon fill="#000000" stroke="#000000" points="254.86,-1006.5001 264.86,-1003 254.86,-999.5001 254.86,-1006.5001"/>
</g>
<!-- ZcashFoundation/frost#61 -->
<g id="node10" class="node open">
<title>ZcashFoundation/frost#61</title>
<g id="a_node10"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/61" xlink:title="ZcashFoundation/frost#61&#10;Flesh out all rustdoc in&#10;`frost&#45;ristretto255`&#10;public API" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-951 14.5,-951 14.5,-883 222.5,-883 222.5,-951"/>
<text text-anchor="middle" x="118.5" y="-935.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#61</text>
<text text-anchor="middle" x="118.5" y="-920.8" font-family="Times,serif" font-size="14.00" fill="#000000">Flesh out all rustdoc in</text>
<text text-anchor="middle" x="118.5" y="-905.8" font-family="Times,serif" font-size="14.00" fill="#000000">`frost&#45;ristretto255`</text>
<text text-anchor="middle" x="118.5" y="-890.8" font-family="Times,serif" font-size="14.00" fill="#000000">public API</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#61&#45;&gt;ZcashFoundation/frost#79 -->
<g id="edge7" class="edge">
<title>ZcashFoundation/frost#61&#45;&gt;ZcashFoundation/frost#79</title>
<path fill="none" stroke="#000000" d="M217.86,-951.11C246.69,-961.01 277.43,-971.56 303.61,-980.55"/>
<polygon fill="#000000" stroke="#000000" points="302.8154,-983.9775 313.41,-983.91 305.0857,-977.3559 302.8154,-983.9775"/>
</g>
<!-- ZcashFoundation/frost#92 -->
<g id="node11" class="node open">
<title>ZcashFoundation/frost#92</title>
<g id="a_node11"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/92" xlink:title="ZcashFoundation/frost#92&#10;v6/v7: Use per&#45;signer&#10;values of rho to mitigate&#10;protocol malleability" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-865 14.5,-865 14.5,-797 222.5,-797 222.5,-865"/>
<text text-anchor="middle" x="118.5" y="-849.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#92</text>
<text text-anchor="middle" x="118.5" y="-834.8" font-family="Times,serif" font-size="14.00" fill="#000000">v6/v7: Use per&#45;signer</text>
<text text-anchor="middle" x="118.5" y="-819.8" font-family="Times,serif" font-size="14.00" fill="#000000">values of rho to mitigate</text>
<text text-anchor="middle" x="118.5" y="-804.8" font-family="Times,serif" font-size="14.00" fill="#000000">protocol malleability</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#92&#45;&gt;ZcashFoundation/frost#86 -->
<g id="edge8" class="edge">
<title>ZcashFoundation/frost#92&#45;&gt;ZcashFoundation/frost#86</title>
<path fill="none" stroke="#000000" d="M222.56,-813.14C233.26,-811.3 244.18,-809.43 254.98,-807.57"/>
<polygon fill="#000000" stroke="#000000" points="255.5933,-811.016 264.86,-805.88 254.413,-804.1162 255.5933,-811.016"/>
</g>
<!-- ZcashFoundation/frost#91 -->
<g id="node12" class="node open">
<title>ZcashFoundation/frost#91</title>
<g id="a_node12"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/91" xlink:title="ZcashFoundation/frost#91&#10;v6/v7: Make verification&#10;a per&#45;ciphersuite&#10;functionality" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-779 14.5,-779 14.5,-711 222.5,-711 222.5,-779"/>
<text text-anchor="middle" x="118.5" y="-763.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#91</text>
<text text-anchor="middle" x="118.5" y="-748.8" font-family="Times,serif" font-size="14.00" fill="#000000">v6/v7: Make verification</text>
<text text-anchor="middle" x="118.5" y="-733.8" font-family="Times,serif" font-size="14.00" fill="#000000">a per&#45;ciphersuite</text>
<text text-anchor="middle" x="118.5" y="-718.8" font-family="Times,serif" font-size="14.00" fill="#000000">functionality</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#91&#45;&gt;ZcashFoundation/frost#86 -->
<g id="edge9" class="edge">
<title>ZcashFoundation/frost#91&#45;&gt;ZcashFoundation/frost#86</title>
<path fill="none" stroke="#000000" d="M222.56,-762.86C233.26,-764.7 244.18,-766.57 254.98,-768.43"/>
<polygon fill="#000000" stroke="#000000" points="254.413,-771.8838 264.86,-770.12 255.5933,-764.984 254.413,-771.8838"/>
</g>
<!-- ZcashFoundation/frost#47 -->
<g id="node13" class="node open">
<title>ZcashFoundation/frost#47</title>
<g id="a_node13"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/47" xlink:title="ZcashFoundation/frost#47&#10;Note in Ristretto255 near&#10;PublicKeyPackage where we&#10;impl&#10;`derive_group_info()` for&#10;v05" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="229,-693 8,-693 8,-595 229,-595 229,-693"/>
<text text-anchor="middle" x="118.5" y="-677.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#47</text>
<text text-anchor="middle" x="118.5" y="-662.8" font-family="Times,serif" font-size="14.00" fill="#000000">Note in Ristretto255 near</text>
<text text-anchor="middle" x="118.5" y="-647.8" font-family="Times,serif" font-size="14.00" fill="#000000">PublicKeyPackage where we</text>
<text text-anchor="middle" x="118.5" y="-632.8" font-family="Times,serif" font-size="14.00" fill="#000000">impl</text>
<text text-anchor="middle" x="118.5" y="-617.8" font-family="Times,serif" font-size="14.00" fill="#000000">`derive_group_info()` for</text>
<text text-anchor="middle" x="118.5" y="-602.8" font-family="Times,serif" font-size="14.00" fill="#000000">v05</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#59 -->
<g id="node14" class="node open">
<title>ZcashFoundation/frost#59</title>
<g id="a_node14"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/59" xlink:title="ZcashFoundation/frost#59&#10;Rename&#10;`frost::keys::{Secret,&#10;Public}`to indicate&#10;signing participants&#39;&#10;shares, not full keys." target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-577 14.5,-577 14.5,-479 222.5,-479 222.5,-577"/>
<text text-anchor="middle" x="118.5" y="-561.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#59</text>
<text text-anchor="middle" x="118.5" y="-546.8" font-family="Times,serif" font-size="14.00" fill="#000000">Rename</text>
<text text-anchor="middle" x="118.5" y="-531.8" font-family="Times,serif" font-size="14.00" fill="#000000">`frost::keys::{Secret,</text>
<text text-anchor="middle" x="118.5" y="-516.8" font-family="Times,serif" font-size="14.00" fill="#000000">Public}`to indicate</text>
<text text-anchor="middle" x="118.5" y="-501.8" font-family="Times,serif" font-size="14.00" fill="#000000">signing participants&#39;</text>
<text text-anchor="middle" x="118.5" y="-486.8" font-family="Times,serif" font-size="14.00" fill="#000000">shares, not full keys.</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#81 -->
<g id="node15" class="node open">
<title>ZcashFoundation/frost#81</title>
<g id="a_node15"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/81" xlink:title="ZcashFoundation/frost#81&#10;Start rerandomized repo" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-461 14.5,-461 14.5,-423 222.5,-423 222.5,-461"/>
<text text-anchor="middle" x="118.5" y="-445.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#81</text>
<text text-anchor="middle" x="118.5" y="-430.8" font-family="Times,serif" font-size="14.00" fill="#000000">Start rerandomized repo</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#71 -->
<g id="node16" class="node open">
<title>ZcashFoundation/frost#71</title>
<g id="a_node16"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/71" xlink:title="ZcashFoundation/frost#71&#10;Add Ed448 support" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-405 14.5,-405 14.5,-367 222.5,-367 222.5,-405"/>
<text text-anchor="middle" x="118.5" y="-389.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#71</text>
<text text-anchor="middle" x="118.5" y="-374.8" font-family="Times,serif" font-size="14.00" fill="#000000">Add Ed448 support</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#74 -->
<g id="node17" class="node open">
<title>ZcashFoundation/frost#74</title>
<g id="a_node17"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/74" xlink:title="ZcashFoundation/frost#74&#10;Port fresh keygen test&#10;from `frost&#45;core` to&#10;`frost&#45;ristretto` and&#10;other dependent crates" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-348.5 14.5,-348.5 14.5,-265.5 222.5,-265.5 222.5,-348.5"/>
<text text-anchor="middle" x="118.5" y="-333.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#74</text>
<text text-anchor="middle" x="118.5" y="-318.3" font-family="Times,serif" font-size="14.00" fill="#000000">Port fresh keygen test</text>
<text text-anchor="middle" x="118.5" y="-303.3" font-family="Times,serif" font-size="14.00" fill="#000000">from `frost&#45;core` to</text>
<text text-anchor="middle" x="118.5" y="-288.3" font-family="Times,serif" font-size="14.00" fill="#000000">`frost&#45;ristretto` and</text>
<text text-anchor="middle" x="118.5" y="-273.3" font-family="Times,serif" font-size="14.00" fill="#000000">other dependent crates</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#70 -->
<g id="node18" class="node open">
<title>ZcashFoundation/frost#70</title>
<g id="a_node18"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/70" xlink:title="ZcashFoundation/frost#70&#10;Add Ed25519 support" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-247 14.5,-247 14.5,-209 222.5,-209 222.5,-247"/>
<text text-anchor="middle" x="118.5" y="-231.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#70</text>
<text text-anchor="middle" x="118.5" y="-216.8" font-family="Times,serif" font-size="14.00" fill="#000000">Add Ed25519 support</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#35 -->
<g id="node19" class="node open">
<title>ZcashFoundation/frost#35</title>
<g id="a_node19"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/35" xlink:title="ZcashFoundation/frost#35&#10;frost&#45;core: Implement the&#10;generic DKG" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-1208.5 14.5,-1208.5 14.5,-1155.5 222.5,-1155.5 222.5,-1208.5"/>
<text text-anchor="middle" x="118.5" y="-1193.3" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#35</text>
<text text-anchor="middle" x="118.5" y="-1178.3" font-family="Times,serif" font-size="14.00" fill="#000000">frost&#45;core: Implement the</text>
<text text-anchor="middle" x="118.5" y="-1163.3" font-family="Times,serif" font-size="14.00" fill="#000000">generic DKG</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#63 -->
<g id="node20" class="node open">
<title>ZcashFoundation/frost#63</title>
<g id="a_node20"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/63" xlink:title="ZcashFoundation/frost#63&#10;frost&#45;ristretto255:&#10;implement `frost&#45;core`&#39;s&#10;DKG concretely" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" points="473,-1216 265,-1216 265,-1148 473,-1148 473,-1216"/>
<text text-anchor="middle" x="369" y="-1200.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#63</text>
<text text-anchor="middle" x="369" y="-1185.8" font-family="Times,serif" font-size="14.00" fill="#000000">frost&#45;ristretto255:</text>
<text text-anchor="middle" x="369" y="-1170.8" font-family="Times,serif" font-size="14.00" fill="#000000">implement `frost&#45;core`&#39;s</text>
<text text-anchor="middle" x="369" y="-1155.8" font-family="Times,serif" font-size="14.00" fill="#000000">DKG concretely</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#35&#45;&gt;ZcashFoundation/frost#63 -->
<g id="edge10" class="edge">
<title>ZcashFoundation/frost#35&#45;&gt;ZcashFoundation/frost#63</title>
<path fill="none" stroke="#000000" d="M222.56,-1182C233.15,-1182 243.96,-1182 254.65,-1182"/>
<polygon fill="#000000" stroke="#000000" points="254.86,-1185.5001 264.86,-1182 254.86,-1178.5001 254.86,-1185.5001"/>
</g>
<!-- ZcashFoundation/frost#39 -->
<g id="node21" class="node open">
<title>ZcashFoundation/frost#39</title>
<g id="a_node21"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/39" xlink:title="ZcashFoundation/frost#39&#10;Migrate/port `redjubjub`&#10;to frost&#45;core / FROST&#10;spec v05+" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-1295 14.5,-1295 14.5,-1227 222.5,-1227 222.5,-1295"/>
<text text-anchor="middle" x="118.5" y="-1279.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#39</text>
<text text-anchor="middle" x="118.5" y="-1264.8" font-family="Times,serif" font-size="14.00" fill="#000000">Migrate/port `redjubjub`</text>
<text text-anchor="middle" x="118.5" y="-1249.8" font-family="Times,serif" font-size="14.00" fill="#000000">to frost&#45;core / FROST</text>
<text text-anchor="middle" x="118.5" y="-1234.8" font-family="Times,serif" font-size="14.00" fill="#000000">spec v05+</text>
</a>
</g>
</g>
<!-- ZcashFoundation/frost#40 -->
<g id="node22" class="node open">
<title>ZcashFoundation/frost#40</title>
<g id="a_node22"><a xlink:href="https://github.com/ZcashFoundation/frost/issues/40" xlink:title="ZcashFoundation/frost#40&#10;Migrate/port `redpallas`&#10;to frost&#45;core / FROST&#10;spec v05+" target="_blank">
<polygon fill="#c2e0c6" stroke="#000000" stroke-width="2" points="222.5,-1381 14.5,-1381 14.5,-1313 222.5,-1313 222.5,-1381"/>
<text text-anchor="middle" x="118.5" y="-1365.8" font-family="Times,serif" font-size="14.00" fill="#000000">ZcashFoundation/frost#40</text>
<text text-anchor="middle" x="118.5" y="-1350.8" font-family="Times,serif" font-size="14.00" fill="#000000">Migrate/port `redpallas`</text>
<text text-anchor="middle" x="118.5" y="-1335.8" font-family="Times,serif" font-size="14.00" fill="#000000">to frost&#45;core / FROST</text>
<text text-anchor="middle" x="118.5" y="-1320.8" font-family="Times,serif" font-size="14.00" fill="#000000">spec v05+</text>
</a>
</g>
</g>
</g>
</svg>
</div>
<script>
svgPanZoom('#dag > svg', {
zoomScaleSensitivity: 0.4
});
</script>
</body>
</html>