mirror of
https://github.com/pdf2htmlEX/pdf2htmlEX.git
synced 2024-12-22 13:00:08 +00:00
2 lines
86 KiB
Plaintext
2 lines
86 KiB
Plaintext
<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>ee
Call</div><div class="t m0 x92 h14 y97 ff13 fsc fc0 sc0 ls0 ws0">Outer
T<span class="_ _2"></span>ree</div><div class="t m0 x91 h14 y192 ff13 fsc fc0 sc0 ls0 ws0">Nested
T<span class="_ _2"></span>ree</div><div class="t m0 x64 h14 y193 ff13 fsc fc0 sc0 ls0 ws0">Exit
Guard</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">Exit
Guard</div><div class="t m0 x9c h6 y104 ff15 fsc fc0 sc0 ls0 ws0">Nested
T<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>
|