1
0
mirror of https://github.com/pdf2htmlEX/pdf2htmlEX.git synced 2024-12-22 04:50:09 +00:00
pdf2htmlEX/demo/demo7.page
2013-09-28 13:30:57 +08:00

2 lines
86 KiB
Plaintext
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<div class="pd w0 h0"><div id="pf7" class="pf" data-page-no="7"><div class="pc pc7"><img class="bi x2f y13e w8 h18" alt="" src=""/><div class="c xd yc w9 h19"><div class="t m0 x8e h1a y13e ff13 fsb fc0 sc0 ls0 ws0">i<span class="fs9">2</span></div><div class="t m0 x8f h1a y33 ff13 fsb fc0 sc0 ls0 ws0">i<span class="fs9">3<span class="_ _25"> </span></span>i<span class="fs9">4</span></div><div class="t m0 x8e h1a y18c ff13 fsb fc0 sc0 ls0 ws0">i<span class="fs9">5</span></div><div class="t m0 x8e h1a y18d ff13 fsb fc0 sc0 ls0 ws0">i<span class="fs9">1</span></div><div class="t m0 x51 h1a y18e ff13 fsb fc0 sc0 ls0 ws0">i<span class="fs9">6</span></div><div class="t m0 x8e h1a y17d ff13 fsb fc0 sc0 ls0 ws0">i<span class="fs9">7</span></div><div class="t m0 x31 h1a y18f ff13 fsb fc0 sc0 ls0 ws0">t<span class="fs9">1</span></div><div class="t m0 x90 h1a y190 ff13 fsb fc0 sc0 ls0 ws0">t<span class="fs9">2</span></div><div class="t m0 x91 h14 y191 ff13 fsc fc0 sc0 ls0 ws0">Tr<span class="_ _2"></span>eeCall</div><div class="t m0 x92 h14 y97 ff13 fsc fc0 sc0 ls0 ws0">OuterT<span class="_ _2"></span>ree</div><div class="t m0 x91 h14 y192 ff13 fsc fc0 sc0 ls0 ws0">NestedT<span class="_ _2"></span>ree</div><div class="t m0 x64 h14 y193 ff13 fsc fc0 sc0 ls0 ws0">ExitGuard</div><div class="t m0 x93 h8 y194 ff13 fsa fc0 sc0 ls0 ws0">(a)</div><div class="t m0 x94 h8 y195 ff13 fsa fc0 sc0 ls0 ws0">(b)</div></div><div class="t m0 x2f h5 y196 ff1 fs3 fc0 sc0 ls0 ws0">Figure<span class="_ _5"> </span>7.<span class="_ _1"> </span><span class="ff2">Control<span class="_ _5"> </span>flow<span class="_ _5"> </span>graph<span class="_ _5"> </span>of<span class="_ _5"> </span>a<span class="_ _5"> </span>nested<span class="_ _5"> </span>loop<span class="_ _3"> </span>with<span class="_ _5"> </span>an<span class="_ _5"> </span>if<span class="_ _5"> </span>statement</span></div><div class="t m0 x2f h5 y197 ff2 fs3 fc0 sc0 ls0 ws0">inside<span class="_ _8"> </span>the<span class="_ _d"> </span>inner<span class="_ _8"> </span>most<span class="_ _d"> </span>loop<span class="_ _8"> </span>(a).<span class="_ _d"> </span>An<span class="_ _8"> </span>inner<span class="_ _d"> </span>tree<span class="_ _8"> </span>captures<span class="_ _d"> </span>the<span class="_ _8"> </span>inner</div><div class="t m0 x2f h5 y198 ff2 fs3 fc0 sc0 ls0 ws0">loop,<span class="_ _5"> </span>and<span class="_ _5"> </span>is<span class="_ _5"> </span>nested<span class="_ _5"> </span>inside<span class="_ _5"> </span>an<span class="_ _5"> </span>outer<span class="_ _5"> </span>tree<span class="_ _5"> </span>which<span class="_ _5"> </span>“calls”<span class="_ _5"> </span>the<span class="_ _5"> </span>inner<span class="_ _5"> </span>tree.</div><div class="t m0 x2f h5 y199 ff2 fs3 fc0 sc0 ls0 ws0">The<span class="_ _3"> </span>inner<span class="_ _3"> </span>tree<span class="_ _3"> </span>returns<span class="_ _3"> </span>to<span class="_ _3"> </span>the<span class="_ _3"> </span>outer<span class="_ _3"> </span>tree<span class="_ _3"> </span>once<span class="_ _3"> </span>it<span class="_ _3"> </span>exits<span class="_ _3"> </span>along<span class="_ _3"> </span>its<span class="_ _3"> </span>loop</div><div class="t m0 x2f h5 y19a ff2 fs3 fc0 sc0 ls0 ws0">condition<span class="_ _5"> </span>guard<span class="_ _5"> </span>(b).</div><div class="t m0 x2f h5 y116 ff2 fs3 fc0 sc0 ls0 ws0">In<span class="_ _5"> </span>general,<span class="_ _5"> </span>if<span class="_ _5"> </span>loops<span class="_ _7"> </span>are<span class="_ _5"> </span>nested<span class="_ _5"> </span>to<span class="_ _5"> </span>depth<span class="_ _7"> </span><span class="fff">k<span class="_ _4"></span></span>,<span class="_ _5"> </span>and<span class="_ _5"> </span>each<span class="_ _5"> </span>loop<span class="_ _7"> </span>has<span class="_ _5"> </span><span class="fff">n<span class="_ _5"> </span></span>paths</div><div class="t m0 x2f h5 y15c ff2 fs3 fc0 sc0 ls0 ws0">(on<span class="_ _8"> </span>geometric<span class="_ _d"> </span>a<span class="_ _2"></span>verage),<span class="_ _6"> </span>this<span class="_ _d"> </span>na</div><div class="t m0 x95 h5 y15c ff2 fs3 fc0 sc0 ls0 ws0">¨</div><div class="t m0 x95 h7 y15c ff2 fs3 fc0 sc0 ls0 ws0">ıve<span class="_ _8"> </span>strategy<span class="_ _8"> </span>yields<span class="_ _8"> </span><span class="fff">O<span class="_ _4"></span><span class="ff14">(</span>n</span></div><div class="t m0 x96 h1b ye1 ff10 fs4 fc0 sc0 ls0 ws0">k</div><div class="t m0 x1 h7 y15c ff14 fs3 fc0 sc0 ls0 ws0">)<span class="_ _8"> </span><span class="ff2">traces,</span></div><div class="t m0 x2f h5 y15d ff2 fs3 fc0 sc0 ls0 ws0">which<span class="_ _5"> </span>can<span class="_ _5"> </span>easily<span class="_ _3"> </span>fill<span class="_ _5"> </span>the<span class="_ _5"> </span>trace<span class="_ _5"> </span>cache.</div><div class="t m0 x34 h5 y15e ff2 fs3 fc0 sc0 ls0 ws0">In<span class="_ _8"> </span>order<span class="_ _d"> </span>to<span class="_ _8"> </span>execute<span class="_ _8"> </span>programs<span class="_ _8"> </span>with<span class="_ _d"> </span>nested<span class="_ _8"> </span>loops<span class="_ _8"> </span>efficiently<span class="_ _b"></span>,<span class="_ _d"> </span>a</div><div class="t m0 x2f h5 y15f ff2 fs3 fc0 sc0 ls0 ws0">tracing<span class="_ _5"> </span>system<span class="_ _7"> </span>needs<span class="_ _5"> </span>a<span class="_ _5"> </span>technique<span class="_ _7"> </span>for<span class="_ _5"> </span>cov<span class="_ _2"></span>ering<span class="_ _5"> </span>the<span class="_ _7"> </span>nested<span class="_ _5"> </span>loops<span class="_ _5"> </span>with</div><div class="t m0 x2f h5 y160 ff2 fs3 fc0 sc0 ls0 ws0">nativ<span class="_ _2"></span>e<span class="_ _5"> </span>code<span class="_ _5"> </span>without<span class="_ _5"> </span>exponential<span class="_ _5"> </span>trace<span class="_ _5"> </span>duplication.</div><div class="t m0 x2f hc y79 ff1 fs3 fc0 sc0 ls0 ws0">4.1<span class="_ _9"> </span>Nesting<span class="_ _5"> </span>Algorithm</div><div class="t m0 x2f h5 y19b ff2 fs3 fc0 sc0 ls0 ws0">The<span class="_ _3"> </span>k<span class="_ _2"></span>ey<span class="_ _3"> </span>insight<span class="_ _5"> </span>is<span class="_ _3"> </span>that<span class="_ _3"> </span>if<span class="_ _5"> </span>each<span class="_ _3"> </span>loop<span class="_ _3"> </span>is<span class="_ _5"> </span>represented<span class="_ _3"> </span>by<span class="_ _3"> </span>its<span class="_ _3"> </span>o<span class="_ _2"></span>wn<span class="_ _5"> </span>trace</div><div class="t m0 x2f h5 y19c ff2 fs3 fc0 sc0 ls0 ws0">tree,<span class="_ _3"> </span>the<span class="_ _3"> </span>code<span class="_ _3"> </span>for<span class="_ _3"> </span>each<span class="_ _5"> </span>loop<span class="_ _3"> </span>can<span class="_ _3"> </span>be<span class="_ _3"> </span>contained<span class="_ _3"> </span>only<span class="_ _3"> </span>in<span class="_ _3"> </span>its<span class="_ _3"> </span>o<span class="_ _2"></span>wn<span class="_ _3"> </span>tree,</div><div class="t m0 x2f h5 y19d ff2 fs3 fc0 sc0 ls0 ws0">and<span class="_ _5"> </span>outer<span class="_ _5"> </span>loop<span class="_ _5"> </span>paths<span class="_ _7"> </span>will<span class="_ _5"> </span>not<span class="_ _5"> </span>be<span class="_ _5"> </span>duplicated.<span class="_ _5"> </span>Another<span class="_ _5"> </span>k<span class="_ _2"></span>e<span class="_ _2"></span>y<span class="_ _5"> </span>fact<span class="_ _5"> </span>is<span class="_ _7"> </span>that</div><div class="t m0 x2f h5 y19e ff2 fs3 fc0 sc0 ls0 ws0">we<span class="_ _5"> </span>are<span class="_ _5"> </span>not<span class="_ _5"> </span>tracing<span class="_ _5"> </span>arbitrary<span class="_ _5"> </span>bytecodes<span class="_ _5"> </span>that<span class="_ _5"> </span>might<span class="_ _5"> </span>hav<span class="_ _2"></span>e<span class="_ _5"> </span>irreduceable</div><div class="t m0 x2f h5 y19f ff2 fs3 fc0 sc0 ls0 ws0">control<span class="_ _3"> </span>flow<span class="_ _3"> </span>graphs,<span class="_ _3"> </span>but<span class="_ _3"> </span>rather<span class="_ _3"> </span>bytecodes<span class="_ _3"> </span>produced<span class="_ _6"> </span>by<span class="_ _3"> </span>a<span class="_ _3"> </span>compiler</div><div class="t m0 x2f h5 y1a0 ff2 fs3 fc0 sc0 ls0 ws0">for<span class="_ _3"> </span>a<span class="_ _6"> </span>language<span class="_ _3"> </span>with<span class="_ _3"> </span>structured<span class="_ _3"> </span>control<span class="_ _6"> </span>flo<span class="_ _2"></span>w<span class="_ _b"></span>.<span class="_ _6"> </span>Thus,<span class="_ _3"> </span>giv<span class="_ _2"></span>en<span class="_ _3"> </span>two<span class="_ _3"> </span>loop</div><div class="t m0 x2f h5 y1a1 ff2 fs3 fc0 sc0 ls0 ws0">edges,<span class="_ _8"> </span>the<span class="_ _d"> </span>system<span class="_ _8"> </span>can<span class="_ _d"> </span>easily<span class="_ _d"> </span>determine<span class="_ _8"> </span>whether<span class="_ _d"> </span>the<span class="_ _2"></span>y<span class="_ _8"> </span>are<span class="_ _d"> </span>nested</div><div class="t m0 x2f h5 y1a2 ff2 fs3 fc0 sc0 ls0 ws0">and<span class="_ _3"> </span>which<span class="_ _5"> </span>is<span class="_ _5"> </span>the<span class="_ _3"> </span>inner<span class="_ _5"> </span>loop.<span class="_ _3"> </span>Using<span class="_ _5"> </span>this<span class="_ _3"> </span>kno<span class="_ _2"></span>wledge,<span class="_ _5"> </span>the<span class="_ _3"> </span>system<span class="_ _5"> </span>can</div><div class="t m0 x2f h5 y1a3 ff2 fs3 fc0 sc0 ls0 ws0">compile<span class="_ _5"> </span>inner<span class="_ _7"> </span>and<span class="_ _5"> </span>outer<span class="_ _5"> </span>loops<span class="_ _7"> </span>separately<span class="_ _2"></span>,<span class="_ _5"> </span>and<span class="_ _7"> </span>make<span class="_ _5"> </span>the<span class="_ _5"> </span>outer<span class="_ _7"> </span>loop<span class="_ _2"></span>s</div><div class="t m0 x2f h5 y1a4 ff2 fs3 fc0 sc0 ls0 ws0">traces<span class="_ _5"> </span><span class="ffa">call<span class="_ _5"> </span></span>the<span class="_ _3"> </span>inner<span class="_ _5"> </span>loop<span class="_ _b"></span>s<span class="_ _3"> </span>trace<span class="_ _5"> </span>tree.</div><div class="t m0 x34 h5 y1a5 ff2 fs3 fc0 sc0 ls0 ws0">The<span class="_ _3"> </span>algorithm<span class="_ _3"> </span>for<span class="_ _3"> </span>b<span class="_ _2"></span>uilding<span class="_ _3"> </span>nested<span class="_ _3"> </span>trace<span class="_ _3"> </span>trees<span class="_ _3"> </span>is<span class="_ _5"> </span>as<span class="_ _3"> </span>follows.<span class="_ _3"> </span>W<span class="_ _b"></span>e</div><div class="t m0 x2f h5 y1a6 ff2 fs3 fc0 sc0 ls0 ws0">start<span class="_ _3"> </span>tracing<span class="_ _5"> </span>at<span class="_ _3"> </span>loop<span class="_ _5"> </span>headers<span class="_ _3"> </span>exactly<span class="_ _5"> </span>as<span class="_ _3"> </span>in<span class="_ _5"> </span>the<span class="_ _3"> </span>basic<span class="_ _3"> </span>tracing<span class="_ _5"> </span>system.</div><div class="t m0 x2f h5 y1a7 ff2 fs3 fc0 sc0 ls0 ws0">When<span class="_ _8"> </span>we<span class="_ _8"> </span>exit<span class="_ _6"> </span>a<span class="_ _8"> </span>loop<span class="_ _8"> </span>(detected<span class="_ _8"> </span>by<span class="_ _8"> </span>comparing<span class="_ _8"> </span>the<span class="_ _8"> </span>interpreter<span class="_ _8"> </span>PC</div><div class="t m0 x2f h5 y1a8 ff2 fs3 fc0 sc0 ls0 ws0">with<span class="_ _d"> </span>the<span class="_ _8"> </span>range<span class="_ _d"> </span>gi<span class="_ _2"></span>ven<span class="_ _8"> </span>by<span class="_ _d"> </span>the<span class="_ _8"> </span>loop<span class="_ _d"> </span>edge),<span class="_ _8"> </span>we<span class="_ _d"> </span>stop<span class="_ _d"> </span>the<span class="_ _8"> </span>trace.<span class="_ _d"> </span>The</div><div class="t m0 x2f h5 y1a9 ff2 fs3 fc0 sc0 ls0 ws0">key<span class="_ _6"> </span>step<span class="_ _8"> </span>of<span class="_ _8"> </span>the<span class="_ _8"> </span>algorithm<span class="_ _d"> </span>occurs<span class="_ _6"> </span>when<span class="_ _8"> </span>we<span class="_ _d"> </span>are<span class="_ _6"> </span>recording<span class="_ _8"> </span>a<span class="_ _8"> </span>trace</div><div class="t m0 x2f h5 y1aa ff2 fs3 fc0 sc0 ls0 ws0">for<span class="_ _3"> </span>loop<span class="_ _3"> </span><span class="fff">L</span></div><div class="t m0 x97 h1b y47 ff10 fs4 fc0 sc0 ls0 ws0">R</div><div class="t m0 x4c h5 y1aa ff2 fs3 fc0 sc0 ls0 ws0">(<span class="fff">R<span class="_ _3"> </span></span>for<span class="_ _3"> </span>loop<span class="_ _3"> </span>being<span class="_ _3"> </span>recorded)<span class="_ _3"> </span>and<span class="_ _5"> </span>we<span class="_ _3"> </span>reach<span class="_ _3"> </span>the<span class="_ _3"> </span>header</div><div class="t m0 x2f h5 y1ab ff2 fs3 fc0 sc0 ls0 ws0">of<span class="_ _5"> </span>a<span class="_ _5"> </span>different<span class="_ _5"> </span>loop<span class="_ _5"> </span><span class="fff">L</span></div><div class="t m0 x46 h1b y48 ff10 fs4 fc0 sc0 ls0 ws0">O</div><div class="t m0 x65 h5 y1ab ff2 fs3 fc0 sc0 ls0 ws0">(<span class="fff">O<span class="_ _3"> </span></span>for<span class="_ _5"> </span>other<span class="_ _5"> </span>loop).<span class="_ _5"> </span>Note<span class="_ _5"> </span>that<span class="_ _5"> </span><span class="fff">L</span></div><div class="t m0 x2c h1b y48 ff10 fs4 fc0 sc0 ls0 ws0">O</div><div class="t m0 x98 h5 y1ab ff2 fs3 fc0 sc0 ls0 ws0">must<span class="_ _5"> </span>be<span class="_ _5"> </span>an</div><div class="t m0 x2f h5 y1ac ff2 fs3 fc0 sc0 ls0 ws0">inner<span class="_ _5"> </span>loop<span class="_ _5"> </span>of<span class="_ _3"> </span><span class="fff">L</span></div><div class="t m0 x94 h1b y49 ff10 fs4 fc0 sc0 ls0 ws0">R</div><div class="t m0 x92 h5 y1ac ff2 fs3 fc0 sc0 ls0 ws0">because<span class="_ _5"> </span>we<span class="_ _5"> </span>stop<span class="_ _3"> </span>the<span class="_ _5"> </span>trace<span class="_ _5"> </span>when<span class="_ _5"> </span>we<span class="_ _5"> </span>exit<span class="_ _5"> </span>a<span class="_ _5"> </span>loop.</div><div class="t m0 x36 h4 y1ad ff3 fs2 fc0 sc0 ls0 ws0">•</div><div class="t m0 x37 h5 y174 ff2 fs3 fc0 sc0 ls0 ws0">If<span class="_ _3"> </span><span class="fff">L</span></div><div class="t m0 x52 h1b y132 ff10 fs4 fc0 sc0 ls0 ws0">O</div><div class="t m0 x25 h5 y174 ff2 fs3 fc0 sc0 ls0 ws0">has<span class="_ _3"> </span>a<span class="_ _3"> </span>type-matching<span class="_ _3"> </span>compiled<span class="_ _3"> </span>trace<span class="_ _3"> </span>tree,<span class="_ _3"> </span>we<span class="_ _3"> </span>call<span class="_ _3"> </span><span class="fff">L</span></div><div class="t m0 x10 h1b y132 ff10 fs4 fc0 sc0 ls0 ws0">O</div><div class="t m0 x1c h5 y174 ff2 fs3 fc0 sc0 ls0 ws0">as</div><div class="t m0 x37 h5 y175 ff2 fs3 fc0 sc0 ls0 ws0">a<span class="_ _3"> </span>nested<span class="_ _5"> </span>trace<span class="_ _3"> </span>tree.<span class="_ _5"> </span>If<span class="_ _3"> </span>the<span class="_ _5"> </span>call<span class="_ _3"> </span>succeeds,<span class="_ _5"> </span>then<span class="_ _3"> </span>we<span class="_ _5"> </span>record<span class="_ _3"> </span>the<span class="_ _5"> </span>call</div><div class="t m0 x37 h5 y1ae ff2 fs3 fc0 sc0 ls0 ws0">in<span class="_ _5"> </span>the<span class="_ _3"> </span>trace<span class="_ _5"> </span>for<span class="_ _5"> </span><span class="fff">L</span></div><div class="t m0 x91 h1b y134 ff10 fs4 fc0 sc0 ls0 ws0">R</div><div class="t m0 x65 h5 y1ae ff2 fs3 fc0 sc0 ls0 ws0">.<span class="_ _5"> </span>On<span class="_ _3"> </span>future<span class="_ _5"> </span>ex<span class="_ _2"></span>ecutions,<span class="_ _5"> </span>the<span class="_ _3"> </span>trace<span class="_ _5"> </span>for<span class="_ _5"> </span><span class="fff">L</span></div><div class="t m0 x29 h1b y134 ff10 fs4 fc0 sc0 ls0 ws0">R</div><div class="t m0 x5e h5 y1ae ff2 fs3 fc0 sc0 ls0 ws0">will</div><div class="t m0 x37 h5 y1af ff2 fs3 fc0 sc0 ls0 ws0">call<span class="_ _5"> </span>the<span class="_ _5"> </span>inner<span class="_ _3"> </span>trace<span class="_ _5"> </span>directly<span class="_ _b"></span>.</div><div class="t m0 x36 h4 y1b0 ff3 fs2 fc0 sc0 ls0 ws0">•</div><div class="t m0 x37 h5 y1b1 ff2 fs3 fc0 sc0 ls0 ws0">If<span class="_ _6"> </span><span class="fff">L</span></div><div class="t m0 x52 h1b y1b2 ff10 fs4 fc0 sc0 ls0 ws0">O</div><div class="t m0 x25 h5 y1b1 ff2 fs3 fc0 sc0 ls0 ws0">does<span class="_ _6"> </span>not<span class="_ _3"> </span>have<span class="_ _3"> </span>a<span class="_ _6"> </span>type-matching<span class="_ _3"> </span>compiled<span class="_ _6"> </span>trace<span class="_ _3"> </span>tree<span class="_ _6"> </span>yet,</div><div class="t m0 x37 h5 y1b3 ff2 fs3 fc0 sc0 ls0 ws0">we<span class="_ _8"> </span>hav<span class="_ _2"></span>e<span class="_ _6"> </span>to<span class="_ _8"> </span>obtain<span class="_ _8"> </span>it<span class="_ _8"> </span>before<span class="_ _8"> </span>we<span class="_ _8"> </span>are<span class="_ _8"> </span>able<span class="_ _8"> </span>to<span class="_ _8"> </span>proceed.<span class="_ _8"> </span>In<span class="_ _8"> </span>order</div><div class="t m0 x37 h5 y1b4 ff2 fs3 fc0 sc0 ls0 ws0">to<span class="_ _3"> </span>do<span class="_ _3"> </span>this,<span class="_ _6"> </span>we<span class="_ _3"> </span>simply<span class="_ _3"> </span>abort<span class="_ _6"> </span>recording<span class="_ _3"> </span>the<span class="_ _3"> </span>first<span class="_ _3"> </span>trace.<span class="_ _6"> </span>The<span class="_ _3"> </span>trace</div><div class="t m0 x37 h5 y1b5 ff2 fs3 fc0 sc0 ls0 ws0">monitor<span class="_ _6"> </span>will<span class="_ _6"> </span>see<span class="_ _8"> </span>the<span class="_ _6"> </span>inner<span class="_ _6"> </span>loop<span class="_ _8"> </span>header<span class="_ _2"></span>,<span class="_ _6"> </span>and<span class="_ _6"> </span>will<span class="_ _8"> </span>immediately</div><div class="t m0 x37 h5 y1b6 ff2 fs3 fc0 sc0 ls0 ws0">start<span class="_ _5"> </span>recording<span class="_ _5"> </span>the<span class="_ _3"> </span>inner<span class="_ _5"> </span>loop.</div><div class="t m0 x3 h8 y13a ff2 fs4 fc0 sc0 ls0 ws0">2</div><div class="t m0 x34 h5 y14d ff2 fs3 fc0 sc0 ls0 ws0">If<span class="_ _5"> </span>all<span class="_ _7"> </span>the<span class="_ _5"> </span>loops<span class="_ _7"> </span>in<span class="_ _7"> </span>a<span class="_ _5"> </span>nest<span class="_ _7"> </span>are<span class="_ _5"> </span>type-stable,<span class="_ _7"> </span>then<span class="_ _5"> </span>loop<span class="_ _7"> </span>nesting<span class="_ _5"> </span>creates</div><div class="t m0 x2f h5 y14e ff2 fs3 fc0 sc0 ls0 ws0">no<span class="_ _5"> </span>duplication.<span class="_ _7"> </span>Otherwise,<span class="_ _5"> </span>if<span class="_ _7"> </span>loops<span class="_ _5"> </span>are<span class="_ _7"> </span>nested<span class="_ _5"> </span>to<span class="_ _7"> </span>a<span class="_ _5"> </span>depth<span class="_ _7"> </span><span class="fff">k<span class="_ _4"></span></span>,<span class="_ _5"> </span>and<span class="_ _7"> </span>each</div><div class="t m0 x2f h8 y9a ff2 fs4 fc0 sc0 ls0 ws0">2</div><div class="t m0 x36 h3 y31 ff2 fs2 fc0 sc0 ls0 ws0">Instead<span class="_ _5"> </span>of<span class="_ _3"> </span>aborting<span class="_ _5"> </span>the<span class="_ _5"> </span>outer<span class="_ _3"> </span>recording,<span class="_ _5"> </span>we<span class="_ _5"> </span>could<span class="_ _5"> </span>principally<span class="_ _3"> </span>merely<span class="_ _5"> </span>sus-</div><div class="t m0 x2f h3 y14f ff2 fs2 fc0 sc0 ls0 ws0">pend<span class="_ _3"> </span>the<span class="_ _3"> </span>recording,<span class="_ _3"> </span>but<span class="_ _3"> </span>that<span class="_ _3"> </span>would<span class="_ _3"> </span>require<span class="_ _3"> </span>the<span class="_ _3"> </span>implementation<span class="_ _3"> </span>to<span class="_ _3"> </span>be<span class="_ _3"> </span>able</div><div class="t m0 x2f h3 y33 ff2 fs2 fc0 sc0 ls0 ws0">to<span class="_ _3"> </span>record<span class="_ _3"> </span>se<span class="_ _2"></span>veral<span class="_ _3"> </span>traces<span class="_ _5"> </span>simultaneously<span class="_ _2"></span>,<span class="_ _3"> </span>complicating<span class="_ _3"> </span>the<span class="_ _3"> </span>implementation,</div><div class="t m0 x2f h3 y9d ff2 fs2 fc0 sc0 ls0 ws0">while<span class="_ _5"> </span>sa<span class="_ _2"></span>ving<span class="_ _5"> </span>only<span class="_ _5"> </span>a<span class="_ _7"> </span>few<span class="_ _5"> </span>iterations<span class="_ _7"> </span>in<span class="_ _5"> </span>the<span class="_ _5"> </span>interpreter<span class="_ _2"></span>.</div><div class="c x99 y1b7 wa h1c"><div class="t m0 x9a h16 y17f ff15 fs8 fc0 sc0 ls0 ws0">i<span class="fsd">2</span></div><div class="t m0 x9a h16 y1b8 ff15 fs8 fc0 sc0 ls0 ws0">i<span class="fsd">3</span></div><div class="t m0 x9a h16 y99 ff15 fs8 fc0 sc0 ls0 ws0">i<span class="fsd">1</span></div><div class="t m0 x9a h16 y1b9 ff15 fs8 fc0 sc0 ls0 ws0">i<span class="fsd">6</span></div><div class="t m0 x9a h16 y1ba ff15 fs8 fc0 sc0 ls0 ws0">i<span class="fsd">4</span></div><div class="t m0 x9a h16 yba ff15 fs8 fc0 sc0 ls0 ws0">i<span class="fsd">5</span></div><div class="t m0 x9b h16 y17f ff15 fs8 fc0 sc0 ls0 ws0">t<span class="fsd">2</span></div><div class="t m0 x68 h16 y56 ff15 fs8 fc0 sc0 ls0 ws0">t<span class="fsd">1</span></div><div class="t m0 x9b h16 y1bb ff15 fs8 fc0 sc0 ls0 ws0">t<span class="fsd">4</span></div><div class="t m0 x0 h6 y1bc ff15 fsc fc0 sc0 ls0 ws0">ExitGuard</div><div class="t m0 x9c h6 y104 ff15 fsc fc0 sc0 ls0 ws0">NestedT<span class="_ _2"></span>ree</div></div><div class="t m0 x32 h5 y1bd ff1 fs3 fc0 sc0 ls0 ws0">Figure<span class="_ _5"> </span>8.<span class="_ _1"> </span><span class="ff2">Control<span class="_ _7"> </span>flow<span class="_ _5"> </span>graph<span class="_ _5"> </span>of<span class="_ _7"> </span>a<span class="_ _5"> </span>loop<span class="_ _5"> </span>with<span class="_ _5"> </span>tw<span class="_ _2"></span>o<span class="_ _5"> </span>nested<span class="_ _5"> </span>loops<span class="_ _7"> </span>(left)</span></div><div class="t m0 x32 h5 y1be ff2 fs3 fc0 sc0 ls0 ws0">and<span class="_ _3"> </span>its<span class="_ _6"> </span>nested<span class="_ _3"> </span>trace<span class="_ _3"> </span>tree<span class="_ _3"> </span>configuration<span class="_ _6"> </span>(right).<span class="_ _3"> </span>The<span class="_ _3"> </span>outer<span class="_ _6"> </span>tree<span class="_ _3"> </span>calls</div><div class="t m0 x32 h5 y1bf ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _3"> </span>tw<span class="_ _2"></span>o<span class="_ _5"> </span>inner<span class="_ _3"> </span>nested<span class="_ _5"> </span>trace<span class="_ _3"> </span>trees<span class="_ _5"> </span>and<span class="_ _3"> </span>places<span class="_ _5"> </span>guards<span class="_ _3"> </span>at<span class="_ _5"> </span>their<span class="_ _3"> </span>side<span class="_ _5"> </span>exit</div><div class="t m0 x32 h5 y1c0 ff2 fs3 fc0 sc0 ls0 ws0">locations.</div><div class="t m0 x32 h5 y13 ff2 fs3 fc0 sc0 ls0 ws0">loop<span class="_ _5"> </span>is<span class="_ _5"> </span>entered<span class="_ _5"> </span>with<span class="_ _5"> </span><span class="fff">m<span class="_ _5"> </span></span>dif<span class="_ _2"></span>ferent<span class="_ _5"> </span>type<span class="_ _5"> </span>maps<span class="_ _5"> </span>(on<span class="_ _5"> </span>geometric<span class="_ _5"> </span>a<span class="_ _2"></span>v<span class="_ _2"></span>erage),</div><div class="t m0 x32 h7 y1c1 ff2 fs3 fc0 sc0 ls0 ws0">then<span class="_ _3"> </span>we<span class="_ _3"> </span>compile<span class="_ _5"> </span><span class="fff">O<span class="_ _4"></span><span class="ff14">(</span>m</span></div><div class="t m0 x9d h1b y1c2 ff10 fs4 fc0 sc0 ls0 ws0">k</div><div class="t m0 x9e h7 y1c1 ff14 fs3 fc0 sc0 ls0 ws0">)<span class="_ _3"> </span><span class="ff2">copies<span class="_ _3"> </span>of<span class="_ _5"> </span>the<span class="_ _3"> </span>innermost<span class="_ _3"> </span>loop.<span class="_ _5"> </span>As<span class="_ _3"> </span>long<span class="_ _3"> </span>as</span></div><div class="t m0 x32 h5 y1c3 fff fs3 fc0 sc0 ls0 ws0">m<span class="_ _5"> </span><span class="ff2">is<span class="_ _5"> </span>close<span class="_ _3"> </span>to<span class="_ _5"> </span>1,<span class="_ _5"> </span>the<span class="_ _5"> </span>resulting<span class="_ _5"> </span>trace<span class="_ _5"> </span>trees<span class="_ _5"> </span>will<span class="_ _3"> </span>be<span class="_ _5"> </span>tractable.</span></div><div class="t m0 x33 h5 y1c4 ff2 fs3 fc0 sc0 ls0 ws0">An<span class="_ _5"> </span>important<span class="_ _7"> </span>detail<span class="_ _7"> </span>is<span class="_ _5"> </span>that<span class="_ _7"> </span>the<span class="_ _5"> </span>call<span class="_ _7"> </span>to<span class="_ _7"> </span>the<span class="_ _5"> </span>inner<span class="_ _7"> </span>trace<span class="_ _5"> </span>tree<span class="_ _7"> </span>must<span class="_ _7"> </span>act</div><div class="t m0 x32 h5 y1c5 ff2 fs3 fc0 sc0 ls0 ws0">like<span class="_ _5"> </span>a<span class="_ _5"> </span>function<span class="_ _5"> </span>call<span class="_ _5"> </span>site:<span class="_ _5"> </span>it<span class="_ _5"> </span>must<span class="_ _5"> </span>return<span class="_ _5"> </span>to<span class="_ _5"> </span>the<span class="_ _5"> </span>same<span class="_ _5"> </span>point<span class="_ _7"> </span>every<span class="_ _5"> </span>time.</div><div class="t m0 x32 h5 y1c6 ff2 fs3 fc0 sc0 ls0 ws0">The<span class="_ _3"> </span>goal<span class="_ _3"> </span>of<span class="_ _5"> </span>nesting<span class="_ _3"> </span>is<span class="_ _3"> </span>to<span class="_ _3"> </span>mak<span class="_ _2"></span>e<span class="_ _3"> </span>inner<span class="_ _5"> </span>and<span class="_ _3"> </span>outer<span class="_ _3"> </span>loops<span class="_ _3"> </span>independent;</div><div class="t m0 x32 h5 y1c7 ff2 fs3 fc0 sc0 ls0 ws0">thus<span class="_ _6"> </span>when<span class="_ _6"> </span>the<span class="_ _6"> </span>inner<span class="_ _6"> </span>tree<span class="_ _6"> </span>is<span class="_ _8"> </span>called,<span class="_ _6"> </span>it<span class="_ _6"> </span>must<span class="_ _6"> </span>exit<span class="_ _6"> </span>to<span class="_ _6"> </span>the<span class="_ _6"> </span>same<span class="_ _6"> </span>point</div><div class="t m0 x32 h5 y1c8 ff2 fs3 fc0 sc0 ls0 ws0">in<span class="_ _3"> </span>the<span class="_ _6"> </span>outer<span class="_ _3"> </span>tree<span class="_ _6"> </span>e<span class="_ _2"></span>very<span class="_ _3"> </span>time<span class="_ _3"> </span>with<span class="_ _6"> </span>the<span class="_ _3"> </span>same<span class="_ _3"> </span>type<span class="_ _6"> </span>map.<span class="_ _3"> </span>Because<span class="_ _6"> </span>we</div><div class="t m0 x32 h5 y1c9 ff2 fs3 fc0 sc0 ls0 ws0">cannot<span class="_ _3"> </span>actually<span class="_ _3"> </span>guarantee<span class="_ _6"> </span>this<span class="_ _3"> </span>property<span class="_ _b"></span>,<span class="_ _6"> </span>we<span class="_ _3"> </span>must<span class="_ _3"> </span>guard<span class="_ _3"> </span>on<span class="_ _3"> </span>it<span class="_ _6"> </span>after</div><div class="t m0 x32 h5 y1ca ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _8"> </span>call,<span class="_ _8"> </span>and<span class="_ _8"> </span>side<span class="_ _6"> </span>exit<span class="_ _8"> </span>if<span class="_ _8"> </span>the<span class="_ _8"> </span>property<span class="_ _8"> </span>does<span class="_ _8"> </span>not<span class="_ _8"> </span>hold.<span class="_ _8"> </span>A<span class="_ _8"> </span>common</div><div class="t m0 x32 h5 y1cb ff2 fs3 fc0 sc0 ls0 ws0">reason<span class="_ _d"> </span>for<span class="_ _8"> </span>the<span class="_ _d"> </span>inner<span class="_ _d"> </span>tree<span class="_ _8"> </span>not<span class="_ _d"> </span>to<span class="_ _d"> </span>return<span class="_ _d"> </span>to<span class="_ _8"> </span>the<span class="_ _d"> </span>same<span class="_ _d"> </span>point<span class="_ _d"> </span>w<span class="_ _2"></span>ould</div><div class="t m0 x32 h5 y1cc ff2 fs3 fc0 sc0 ls0 ws0">be<span class="_ _8"> </span>if<span class="_ _8"> </span>the<span class="_ _d"> </span>inner<span class="_ _8"> </span>tree<span class="_ _8"> </span>took<span class="_ _8"> </span>a<span class="_ _d"> </span>ne<span class="_ _2"></span>w<span class="_ _8"> </span>side<span class="_ _8"> </span>exit<span class="_ _8"> </span>for<span class="_ _8"> </span>which<span class="_ _d"> </span>it<span class="_ _6"> </span>had<span class="_ _d"> </span>ne<span class="_ _2"></span>ver</div><div class="t m0 x32 h5 y1cd ff2 fs3 fc0 sc0 ls0 ws0">compiled<span class="_ _6"> </span>a<span class="_ _6"> </span>trace.<span class="_ _6"> </span>At<span class="_ _6"> </span>this<span class="_ _6"> </span>point,<span class="_ _6"> </span>the<span class="_ _6"> </span>interpreter<span class="_ _6"> </span>PC<span class="_ _6"> </span>is<span class="_ _6"> </span>in<span class="_ _6"> </span>the<span class="_ _6"> </span>inner</div><div class="t m0 x32 h5 y1ce ff2 fs3 fc0 sc0 ls0 ws0">tree,<span class="_ _3"> </span>so<span class="_ _6"> </span>we<span class="_ _3"> </span>cannot<span class="_ _3"> </span>continue<span class="_ _3"> </span>recording<span class="_ _6"> </span>or<span class="_ _3"> </span>executing<span class="_ _3"> </span>the<span class="_ _3"> </span>outer<span class="_ _3"> </span>tree.</div><div class="t m0 x32 h5 y1cf ff2 fs3 fc0 sc0 ls0 ws0">If<span class="_ _3"> </span>this<span class="_ _3"> </span>happens<span class="_ _3"> </span>during<span class="_ _3"> </span>recording,<span class="_ _6"> </span>we<span class="_ _3"> </span>abort<span class="_ _3"> </span>the<span class="_ _3"> </span>outer<span class="_ _3"> </span>trace,<span class="_ _3"> </span>to<span class="_ _3"> </span>give</div><div class="t m0 x32 h5 y1d0 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _5"> </span>inner<span class="_ _3"> </span>tree<span class="_ _5"> </span>a<span class="_ _5"> </span>chance<span class="_ _5"> </span>to<span class="_ _3"> </span>finish<span class="_ _5"> </span>gro<span class="_ _2"></span>wing.<span class="_ _5"> </span>A<span class="_ _3"> </span>fut<span class="_ _2"></span>ure<span class="_ _5"> </span>execution<span class="_ _5"> </span>of<span class="_ _5"> </span>the</div><div class="t m0 x32 h5 y1d1 ff2 fs3 fc0 sc0 ls0 ws0">outer<span class="_ _5"> </span>tree<span class="_ _5"> </span>would<span class="_ _5"> </span>then<span class="_ _5"> </span>be<span class="_ _3"> </span>able<span class="_ _5"> </span>to<span class="_ _5"> </span>properly<span class="_ _5"> </span>finish<span class="_ _5"> </span>and<span class="_ _5"> </span>record<span class="_ _5"> </span>a<span class="_ _3"> </span>call<span class="_ _5"> </span>to</div><div class="t m0 x32 h5 y1d2 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _5"> </span>inner<span class="_ _5"> </span>tree.<span class="_ _5"> </span>If<span class="_ _5"> </span>an<span class="_ _5"> </span>inner<span class="_ _5"> </span>tree<span class="_ _7"> </span>side<span class="_ _5"> </span>exit<span class="_ _5"> </span>happens<span class="_ _5"> </span>during<span class="_ _5"> </span>e<span class="_ _2"></span>xecution<span class="_ _5"> </span>of</div><div class="t m0 x32 h5 y1d3 ff2 fs3 fc0 sc0 ls0 ws0">a<span class="_ _3"> </span>compiled<span class="_ _3"> </span>trace<span class="_ _3"> </span>for<span class="_ _6"> </span>the<span class="_ _3"> </span>outer<span class="_ _3"> </span>tree,<span class="_ _3"> </span>we<span class="_ _3"> </span>simply<span class="_ _6"> </span>e<span class="_ _2"></span>xit<span class="_ _3"> </span>the<span class="_ _3"> </span>outer<span class="_ _3"> </span>trace</div><div class="t m0 x32 h5 y1d4 ff2 fs3 fc0 sc0 ls0 ws0">and<span class="_ _5"> </span>start<span class="_ _5"> </span>recording<span class="_ _3"> </span>a<span class="_ _5"> </span>ne<span class="_ _2"></span>w<span class="_ _5"> </span>branch<span class="_ _5"> </span>in<span class="_ _5"> </span>the<span class="_ _5"> </span>inner<span class="_ _3"> </span>tree.</div><div class="t m0 x32 hc y22 ff1 fs3 fc0 sc0 ls0 ws0">4.2<span class="_ _9"> </span>Blacklisting<span class="_ _5"> </span>with<span class="_ _5"> </span>Nesting</div><div class="t m0 x32 h5 y1d5 ff2 fs3 fc0 sc0 ls0 ws0">The<span class="_ _6"> </span>blacklisting<span class="_ _6"> </span>algorithm<span class="_ _6"> </span>needs<span class="_ _8"> </span>modification<span class="_ _6"> </span>to<span class="_ _6"> </span>work<span class="_ _6"> </span>well<span class="_ _8"> </span>with</div><div class="t m0 x32 h5 y1d6 ff2 fs3 fc0 sc0 ls0 ws0">nesting.<span class="_ _6"> </span>The<span class="_ _6"> </span>problem<span class="_ _6"> </span>is<span class="_ _6"> </span>that<span class="_ _6"> </span>outer<span class="_ _8"> </span>loop<span class="_ _6"> </span>traces<span class="_ _6"> </span>often<span class="_ _6"> </span>abort<span class="_ _6"> </span>during</div><div class="t m0 x32 h5 y1d7 ff2 fs3 fc0 sc0 ls0 ws0">startup<span class="_ _5"> </span>(because<span class="_ _3"> </span>the<span class="_ _5"> </span>inner<span class="_ _5"> </span>tree<span class="_ _3"> </span>is<span class="_ _5"> </span>not<span class="_ _3"> </span>a<span class="_ _2"></span>v<span class="_ _2"></span>ailable<span class="_ _5"> </span>or<span class="_ _3"> </span>tak<span class="_ _2"></span>es<span class="_ _5"> </span>a<span class="_ _3"> </span>side<span class="_ _5"> </span>exit),</div><div class="t m0 x32 h5 y1d8 ff2 fs3 fc0 sc0 ls0 ws0">which<span class="_ _6"> </span>would<span class="_ _6"> </span>lead<span class="_ _6"> </span>to<span class="_ _6"> </span>their<span class="_ _8"> </span>being<span class="_ _6"> </span>quickly<span class="_ _6"> </span>blacklisted<span class="_ _6"> </span>by<span class="_ _8"> </span>the<span class="_ _6"> </span>basic</div><div class="t m0 x32 h5 y1d9 ff2 fs3 fc0 sc0 ls0 ws0">algorithm.</div><div class="t m0 x33 h5 y1da ff2 fs3 fc0 sc0 ls0 ws0">The<span class="_ _3"> </span>k<span class="_ _2"></span>ey<span class="_ _5"> </span>observation<span class="_ _3"> </span>is<span class="_ _5"> </span>that<span class="_ _3"> </span>when<span class="_ _3"> </span>an<span class="_ _5"> </span>outer<span class="_ _3"> </span>trace<span class="_ _3"> </span>aborts<span class="_ _5"> </span>because</div><div class="t m0 x32 h5 y1db ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _3"> </span>inner<span class="_ _3"> </span>tree<span class="_ _3"> </span>is<span class="_ _3"> </span>not<span class="_ _3"> </span>ready<span class="_ _b"></span>,<span class="_ _3"> </span>this<span class="_ _3"> </span>is<span class="_ _3"> </span>probably<span class="_ _3"> </span>a<span class="_ _3"> </span>temporary<span class="_ _3"> </span>condition.</div><div class="t m0 x32 h5 y8e ff2 fs3 fc0 sc0 ls0 ws0">Thus,<span class="_ _3"> </span>we<span class="_ _5"> </span>should<span class="_ _3"> </span>not<span class="_ _5"> </span>count<span class="_ _3"> </span>such<span class="_ _3"> </span>aborts<span class="_ _5"> </span>toward<span class="_ _5"> </span>blacklisting<span class="_ _3"> </span>as<span class="_ _5"> </span>long</div><div class="t m0 x32 h5 y8f ff2 fs3 fc0 sc0 ls0 ws0">as<span class="_ _5"> </span>we<span class="_ _5"> </span>are<span class="_ _3"> </span>able<span class="_ _5"> </span>to<span class="_ _5"> </span>b<span class="_ _2"></span>uild<span class="_ _5"> </span>up<span class="_ _5"> </span>more<span class="_ _5"> </span>traces<span class="_ _3"> </span>for<span class="_ _5"> </span>the<span class="_ _5"> </span>inner<span class="_ _5"> </span>tree.</div><div class="t m0 x33 h5 y1dc ff2 fs3 fc0 sc0 ls0 ws0">In<span class="_ _3"> </span>our<span class="_ _6"> </span>implementation,<span class="_ _3"> </span>when<span class="_ _6"> </span>an<span class="_ _3"> </span>outer<span class="_ _3"> </span>tree<span class="_ _6"> </span>aborts<span class="_ _3"> </span>on<span class="_ _6"> </span>the<span class="_ _3"> </span>inner</div><div class="t m0 x32 h5 y1dd ff2 fs3 fc0 sc0 ls0 ws0">tree,<span class="_ _6"> </span>we<span class="_ _6"> </span>increment<span class="_ _6"> </span>the<span class="_ _6"> </span>outer<span class="_ _6"> </span>tree<span class="_ _2"></span>s<span class="_ _3"> </span>blacklist<span class="_ _6"> </span>counter<span class="_ _6"> </span>as<span class="_ _6"> </span>usual<span class="_ _6"> </span>and</div><div class="t m0 x32 h5 y1de ff2 fs3 fc0 sc0 ls0 ws0">back<span class="_ _3"> </span>off<span class="_ _3"> </span>on<span class="_ _3"> </span>compiling<span class="_ _3"> </span>it.<span class="_ _3"> </span>When<span class="_ _3"> </span>the<span class="_ _3"> </span>inner<span class="_ _6"> </span>tree<span class="_ _3"> </span>finishes<span class="_ _3"> </span>a<span class="_ _3"> </span>trace,<span class="_ _3"> </span>we</div><div class="t m0 x32 h5 y1df ff2 fs3 fc0 sc0 ls0 ws0">decrement<span class="_ _3"> </span>the<span class="_ _3"> </span>blacklist<span class="_ _3"> </span>counter<span class="_ _3"> </span>on<span class="_ _3"> </span>the<span class="_ _6"> </span>outer<span class="_ _3"> </span>loop,<span class="_ _3"> </span>“forgi<span class="_ _2"></span>ving”<span class="_ _3"> </span>the</div><div class="t m0 x32 h5 y1e0 ff2 fs3 fc0 sc0 ls0 ws0">outer<span class="_ _5"> </span>loop<span class="_ _5"> </span>for<span class="_ _7"> </span>aborting<span class="_ _5"> </span>pre<span class="_ _2"></span>viously<span class="_ _b"></span>.<span class="_ _5"> </span>W<span class="_ _b"></span>e<span class="_ _5"> </span>also<span class="_ _5"> </span>undo<span class="_ _7"> </span>the<span class="_ _5"> </span>backof<span class="_ _2"></span>f<span class="_ _5"> </span>so<span class="_ _5"> </span>that</div><div class="t m0 x32 h5 y1e1 ff2 fs3 fc0 sc0 ls0 ws0">the<span class="_ _5"> </span>outer<span class="_ _5"> </span>tree<span class="_ _5"> </span>can<span class="_ _5"> </span>start<span class="_ _5"> </span>immediately<span class="_ _5"> </span>trying<span class="_ _3"> </span>to<span class="_ _5"> </span>compile<span class="_ _5"> </span>the<span class="_ _5"> </span>ne<span class="_ _2"></span>xt<span class="_ _5"> </span>time</div><div class="t m0 x32 h5 yad ff2 fs3 fc0 sc0 ls0 ws0">we<span class="_ _5"> </span>reach<span class="_ _5"> </span>it.</div><div class="t m0 x32 h9 y103 ff1 fs1 fc0 sc0 ls0 ws0">5.<span class="_ _a"> </span>T<span class="_ _b"></span>race<span class="_ _3"> </span>T<span class="_ _b"></span>ree<span class="_ _3"> </span>Optimization</div><div class="t m0 x32 h5 y9a ff2 fs3 fc0 sc0 ls0 ws0">This<span class="_ _1"> </span>section<span class="_ _1"> </span>e<span class="_ _2"></span>xplains<span class="_ _1"> </span>ho<span class="_ _2"></span>w<span class="_ _1"> </span>a<span class="_ _d"> </span>recorded<span class="_ _1"> </span>trace<span class="_ _1"> </span>is<span class="_ _1"> </span>translated<span class="_ _1"> </span>to<span class="_ _d"> </span>an</div><div class="t m0 x32 h5 y9b ff2 fs3 fc0 sc0 ls0 ws0">optimized<span class="_ _6"> </span>machine<span class="_ _6"> </span>code<span class="_ _6"> </span>trace.<span class="_ _6"> </span>The<span class="_ _6"> </span>trace<span class="_ _6"> </span>compilation<span class="_ _8"> </span>subsystem,</div><div class="t m0 x32 h5 y9c ff2 fse fc0 sc0 ls0 ws0">NA<span class="_ _4"></span>N<span class="_ _4"></span>O<span class="_ _4"></span>J<span class="_ _4"></span>I<span class="_ _4"></span>T<span class="fs3">,<span class="_ _1"> </span>is<span class="_ _d"> </span>separate<span class="_ _1"> </span>from<span class="_ _d"> </span>the<span class="_ _1"> </span>VM<span class="_ _d"> </span>and<span class="_ _1"> </span>can<span class="_ _1"> </span>be<span class="_ _d"> </span>used<span class="_ _1"> </span>for<span class="_ _d"> </span>other</span></div><div class="t m0 x32 h5 y9d ff2 fs3 fc0 sc0 ls0 ws0">applications.</div></div><div class="pi" data-data='{"ctm":[1.673203,0.000000,0.000000,1.673203,0.000000,0.000000]}'></div></div></div>