Hacker Newsnew | past | comments | ask | show | jobs | submitlogin
Speculative Speculative Decoding (SSD) (arxiv.org)
44 points by E-Reverance 7 hours ago | hide | past | favorite | 7 comments
 help



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.


> Our implementation is up to 2x faster than optimized speculative decoding baselines and up to 5x faster than autoregressive decoding with open source inference engines

what about per-FLOP?


This is interesting stuff. I wonder if these sorts of tricks are already in use at the big labs.

Incidentally, I would recommend trying implementing speculative decoding yourself if you really want to understand LLM inference internals (that, and KV caching of course). I tried it over the Christmas holidays and it was a wonderful learning experience. (And hard work, especially because I forced myself to do it by hand without coding agent assistance.)


Yo dawg I heard you liked speculation so we speculated your speculating

Wait till they speculate the speculation's speculation. Yo dawg I heard that yo dawg I heard

Is it gonna be speculation all the way down?

We're almost to Duddits Decoding (SSDD)



Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: