Speculative Speculative Decoding (SSD)

(arxiv.org)

33 points | by E-Reverance 3 hours ago

3 comments

  • Ari_Rahikkala 1 hour ago
    Neat. Very similar to tree-based speculation as they point out, and they also point how to combine them.

    Speculative decoding: Sample a linear output (next n tokens) from draft model, submit it to a verifier model. At some index the verifier might reject a token and say that no, actually the next token should be this other token instead ("bonus token" in this paper), and that's your output. Or if it accepts the whole draft, you still get a bonus token as the next token past the draft. Then you draft again from that prefix on.

    Tree-based speculation: Sample a tree of outputs from draft model, submit whole tree to verifier, pick longest accepted prefix (and its bonus token).

    Speculative speculative decoding: Sample a linear output from draft model, then in parallel both verify it with the verifier model, and produce a tree of drafts branching out from different rejection points and different choices of bonus tokens at those points. When the verifier finishes, you might have have a new draft ready to submit right away.

    Combined: Sample a tree from the draft model, submit the whole tree to the verifier and in parallel also plan out drafts for different rejection points with different bonus tokens anywhere in the tree.

  • saagarjha 1 hour ago
    Yo dawg I heard you liked speculation so we speculated your speculating
    • LoganDark 1 hour ago
      Wait till they speculate the speculation's speculation. Yo dawg I heard that yo dawg I heard