• KevonLooney@lemm.ee
    link
    fedilink
    English
    arrow-up
    7
    arrow-down
    5
    ·
    6 months ago

    It’s not just a predictive text program. That’s been around for decades. That’s a common misconception.

    As I understand it, it uses statistics from the whole text to create new text. It would be very rare to output “cats have feathers” because that phrase doesn’t ever appear in the training data. Both words “have feathers” never follow “cats”.

    • skulblaka@sh.itjust.works
      link
      fedilink
      English
      arrow-up
      9
      ·
      6 months ago

      But the fact remains that it doesn’t know what a cat or a feather is. All of this is still based purely on statistical frequency and not at all on actual meanings.

    • vrighter@discuss.tchncs.de
      link
      fedilink
      English
      arrow-up
      4
      arrow-down
      1
      ·
      edit-2
      6 months ago

      and that is exactly how a predictive text algorithm works.

      • some tokens go in

      • they are processed by a deterministic, static statistical model, and a set of probabilities (always the same, deterministic, remember?) comes out.

      • pick the word with the highest probability, add it to your initial string and start over.

      • if you want variety, add some randomness and don’t just always pick the most probable next token.

      Coincidentally, this is exactly how llms work. It’s a big markov chain, but with a novel lossy compression algorithm on its state transition table. The last point is also the reason why, if anyone says they can fix llm hallucinations, they’re lying.

      • CeeBee_Eh@lemmy.world
        link
        fedilink
        English
        arrow-up
        2
        ·
        6 months ago

        Coincidentally, this is exactly how llms work

        Everyone who says this doesn’t actually understand how LLMs work.

        Multivector word embeddings create emergent relationships that’s new knowledge that doesn’t exist in the training dataset.

        Computerphile did a good video on this well before the LLM craze.

    • barsoap@lemm.ee
      link
      fedilink
      English
      arrow-up
      2
      arrow-down
      1
      ·
      edit-2
      6 months ago

      because that phrase doesn’t ever appear in the training data.

      Eh but LLMs abstract. It has seen “<animal> have feathers” and “<animal> have fur” quite a lot of times. The problem isn’t that LLMs can’t reason at all, the problem is that they do employ techniques used in proper reasoning, in particular tracking context throughout the text (cross-attention) but lack techniques necessary for the whole thing, instead relying on confabulation to sound convincing regardless of the BS they spout. Suffices to emulate an Etonian but that’s not a high standard.

      • FaceDeer@fedia.io
        link
        fedilink
        arrow-up
        2
        arrow-down
        1
        ·
        6 months ago

        Workarounds for those sorts of limitations have been developed, though. Chain-of-thought prompting has been around for a while now, and I recall recently seeing an article about a model that had that built right into it; it had been trained to use <thought></thought> tags to enclose invisible chunks of its output that would be hidden from the end user but would be used by the AI to work its way through a problem. So if you asked it whether cats had feathers it might respond “<thought>Feathers only grow on birds and dinosaurs. Cats are mammals.</thought> No, cats don’t have feathers.” And you’d only see the latter bit. It was a pretty neat approach to improving LLM reasoning.

    • WalnutLum@lemmy.ml
      link
      fedilink
      English
      arrow-up
      1
      ·
      edit-2
      6 months ago

      This isn’t really accurate either. At the moment of generation, an LLM only has context for the input string and the network of text tokens it’s been assigned. It pulls from a “pool” of these tokens based on what it’s already output and the input context, nothing more.

      Most LLMs have what are called “Top P”, “Top K” etc, these are the number of tokens that it ends up selecting from based on the previous token, alongside the input tokens. It then randomly chooses one based on temperature settings.

      It’s why if you turn these models’ temperature settings really high they output pure nonsense both conceptually and grammatically, because the tenuous thread linking the previous token’s context to the next token has been widened enough that it completely loses any semblance of cohesiveness.