Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Lære Hvordan Fungerer RNN? | Introduktion til RNN'er
Introduktion til RNNs

bookHvordan Fungerer RNN?

Note
Definition

Rekursive neurale netværk (RNN'er) er designet til at håndtere sekventielle data ved at bevare information fra tidligere input i deres interne tilstande. Dette gør dem ideelle til opgaver som sproglig modellering og sekvensforudsigelse.

Afstandsmål
  • Sekventiel behandling: RNN behandler data trin for trin og holder styr på, hvad der er kommet før;
  • Sætningsfuldførelse: givet den ufuldstændige sætning "My favourite dish is sushi. So, my favourite cuisine is _____." behandler RNN ordene én ad gangen. Efter at have set "sushi", forudsiger den det næste ord som "Japanese" baseret på tidligere kontekst;
  • Hukommelse i RNN'er: ved hvert trin opdaterer RNN sin interne tilstand (hukommelse) med ny information, hvilket sikrer, at den bevarer konteksten til fremtidige trin;
  • Træning af RNN: RNN'er trænes ved hjælp af backpropagation through time (BPTT), hvor fejl sendes baglæns gennem hvert tidssteg for at justere vægte for bedre forudsigelser.

Fremadrettet Propagering

Under fremadrettet propagering behandler RNN inputdata trin for trin:

  1. Input ved tidssteg tt: netværket modtager et input xtx_t ved hvert tidssteg;

  2. Opdatering af skjult tilstand: den nuværende skjulte tilstand hth_t opdateres baseret på den forrige skjulte tilstand ht1h_{t-1} og det nuværende input xtx_t ved hjælp af følgende formel:

    ht=f(W[ht1,xt]+b)
    • Hvor:
      • WW er vægtmatricen;
      • bb er biasvektoren;
      • ff er aktiveringsfunktionen.
  3. Outputgenerering: outputtet yty_t genereres baseret på den nuværende skjulte tilstand hth_t ved hjælp af formlen:

    yt=g(Vht+c)

    • Hvor:
      • VV er outputvægtmatricen;
      • cc er outputbias;
      • gg er aktiveringsfunktionen brugt i outputlaget.

Tilbagepropageringsproces

Tilbagepropagering i RNN'er er afgørende for at opdatere vægtene og forbedre modellen. Processen er tilpasset for at tage højde for den sekventielle karakter af RNN'er gennem tilbagepropagering gennem tid (BPTT):

  1. Fejlberegning: det første trin i BPTT er at beregne fejlen ved hvert tidssteg. Denne fejl er typisk forskellen mellem det forudsagte output og det faktiske mål;

  2. Gradientberegning: i rekurrente neurale netværk beregnes gradienterne af tabfunktionen ved at differentiere fejlen med hensyn til netværkets parametre og propageres bagud gennem tiden fra det sidste til det første trin, hvilket kan føre til forsvindende eller eksploderende gradienter, især i lange sekvenser;

  3. Vægtopdatering: når gradienterne er beregnet, opdateres vægtene ved hjælp af en optimeringsteknik som stokastisk gradientnedstigning (SGD). Vægtene justeres således, at fejlen minimeres i fremtidige iterationer. Formlen for opdatering af vægte er:

    W:=WηLossW

    • Hvor:
      • η\eta er indlæringsraten;
      • LossW er gradienten af tabfunktionen med hensyn til vægtmatricen.

Sammenfattende er RNN'er kraftfulde, fordi de kan huske og udnytte tidligere information, hvilket gør dem velegnede til opgaver, der involverer sekvenser.

question mark

Hvad er funktionen af funktionen gg i udgangsligningen yt=g(Vht+c)y_t = g(V \cdot h_t+ c)

Select the correct answer

Var alt klart?

Hvordan kan vi forbedre det?

Tak for dine kommentarer!

Sektion 1. Kapitel 2

Spørg AI

expand

Spørg AI

ChatGPT

Spørg om hvad som helst eller prøv et af de foreslåede spørgsmål for at starte vores chat

Awesome!

Completion rate improved to 4.55

bookHvordan Fungerer RNN?

Stryg for at vise menuen

Note
Definition

Rekursive neurale netværk (RNN'er) er designet til at håndtere sekventielle data ved at bevare information fra tidligere input i deres interne tilstande. Dette gør dem ideelle til opgaver som sproglig modellering og sekvensforudsigelse.

Afstandsmål
  • Sekventiel behandling: RNN behandler data trin for trin og holder styr på, hvad der er kommet før;
  • Sætningsfuldførelse: givet den ufuldstændige sætning "My favourite dish is sushi. So, my favourite cuisine is _____." behandler RNN ordene én ad gangen. Efter at have set "sushi", forudsiger den det næste ord som "Japanese" baseret på tidligere kontekst;
  • Hukommelse i RNN'er: ved hvert trin opdaterer RNN sin interne tilstand (hukommelse) med ny information, hvilket sikrer, at den bevarer konteksten til fremtidige trin;
  • Træning af RNN: RNN'er trænes ved hjælp af backpropagation through time (BPTT), hvor fejl sendes baglæns gennem hvert tidssteg for at justere vægte for bedre forudsigelser.

Fremadrettet Propagering

Under fremadrettet propagering behandler RNN inputdata trin for trin:

  1. Input ved tidssteg tt: netværket modtager et input xtx_t ved hvert tidssteg;

  2. Opdatering af skjult tilstand: den nuværende skjulte tilstand hth_t opdateres baseret på den forrige skjulte tilstand ht1h_{t-1} og det nuværende input xtx_t ved hjælp af følgende formel:

    ht=f(W[ht1,xt]+b)
    • Hvor:
      • WW er vægtmatricen;
      • bb er biasvektoren;
      • ff er aktiveringsfunktionen.
  3. Outputgenerering: outputtet yty_t genereres baseret på den nuværende skjulte tilstand hth_t ved hjælp af formlen:

    yt=g(Vht+c)

    • Hvor:
      • VV er outputvægtmatricen;
      • cc er outputbias;
      • gg er aktiveringsfunktionen brugt i outputlaget.

Tilbagepropageringsproces

Tilbagepropagering i RNN'er er afgørende for at opdatere vægtene og forbedre modellen. Processen er tilpasset for at tage højde for den sekventielle karakter af RNN'er gennem tilbagepropagering gennem tid (BPTT):

  1. Fejlberegning: det første trin i BPTT er at beregne fejlen ved hvert tidssteg. Denne fejl er typisk forskellen mellem det forudsagte output og det faktiske mål;

  2. Gradientberegning: i rekurrente neurale netværk beregnes gradienterne af tabfunktionen ved at differentiere fejlen med hensyn til netværkets parametre og propageres bagud gennem tiden fra det sidste til det første trin, hvilket kan føre til forsvindende eller eksploderende gradienter, især i lange sekvenser;

  3. Vægtopdatering: når gradienterne er beregnet, opdateres vægtene ved hjælp af en optimeringsteknik som stokastisk gradientnedstigning (SGD). Vægtene justeres således, at fejlen minimeres i fremtidige iterationer. Formlen for opdatering af vægte er:

    W:=WηLossW

    • Hvor:
      • η\eta er indlæringsraten;
      • LossW er gradienten af tabfunktionen med hensyn til vægtmatricen.

Sammenfattende er RNN'er kraftfulde, fordi de kan huske og udnytte tidligere information, hvilket gør dem velegnede til opgaver, der involverer sekvenser.

question mark

Hvad er funktionen af funktionen gg i udgangsligningen yt=g(Vht+c)y_t = g(V \cdot h_t+ c)

Select the correct answer

Var alt klart?

Hvordan kan vi forbedre det?

Tak for dine kommentarer!

Sektion 1. Kapitel 2
some-alt