Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Oppiskele Gradienttiteippi | TensorFlow:n Perusteet
Johdanto TensorFlow'hun

bookGradienttiteippi

Gradient Tape

Perustietämys tensorien käsittelystä mahdollistaa siirtymisen prosessien tehostamiseen ja nopeuttamiseen hyödyntämällä TensorFlown sisäänrakennettuja ominaisuuksia. Ensimmäinen näistä edistyneistä työkaluista on Gradient Tape.

Mikä on Gradient Tape?

Tässä luvussa käsitellään yhtä TensorFlown keskeisistä käsitteistä, Gradient Tape -ominaisuutta. Tämä toiminto on olennainen gradienttipohjaisten optimointimenetelmien ymmärtämisessä ja toteuttamisessa, erityisesti syväoppimisessa.

Gradient Tape TensorFlow'ssa on työkalu, joka tallentaa laskutoimitukset automaattista differentiaatiota varten. Kun laskutoimitukset suoritetaan Gradient Tape -lohkon sisällä, TensorFlow seuraa kaikkia suoritettuja laskutoimituksia. Tämä on erityisen hyödyllistä koneoppimismallien koulutuksessa, jossa gradientteja tarvitaan mallin parametrien optimointiin.

Note
Huomio

Käytännössä gradientti on osittaisderivaattojen joukko.

Gradient Tapen käyttö

Gradient Tapen käyttöön liittyvät seuraavat vaiheet:

  • Luo Gradient Tape -lohko: käytä with tf.GradientTape() as tape:. Tämän lohkon sisällä kaikki laskutoimitukset tallennetaan;
  • Määrittele laskutoimitukset: suorita tensorien kanssa operaatioita lohkon sisällä (esim. määrittele neuroverkon eteenpäin suuntautuva laskenta);
  • Laske gradientit: käytä tape.gradient(target, sources) laskeaksesi gradientit kohteen suhteen lähteisiin.

Yksinkertainen gradientin laskenta

Yksinkertainen esimerkki tämän ymmärtämiseksi paremmin.

123456789101112131415
import tensorflow as tf # Define input variables x = tf.Variable(3.0) # Start recording the operations with tf.GradientTape() as tape: # Define the calculations y = x * x # Extract the gradient for the specific input (`x`) grad = tape.gradient(y, x) print(f'Result of y: {y}') print(f'The gradient of y with respect to x is: {grad.numpy()}')
copy

Tämä koodi laskee funktion y = x^2 gradientin kohdassa x = 3. Tämä vastaa funktion y osittaisderivaattaa muuttujan x suhteen.

Useita osittaisderivaattoja

Kun ulostuloon vaikuttaa useita syötteitä, voidaan laskea osittaisderivaatta jokaista näistä syötteistä (tai vain valituista) kohtaan. Tämä tehdään antamalla muuttujalista sources-parametrina.

Tämän operaation tuloksena saadaan vastaava tensorilista, jossa jokainen tensori edustaa osittaisderivaattaa suhteessa kuhunkin sources-listassa määriteltyyn muuttujaan.

1234567891011121314151617
import tensorflow as tf # Define input variables x = tf.Variable(tf.fill((2, 3), 3.0)) z = tf.Variable(5.0) # Start recording the operations with tf.GradientTape() as tape: # Define the calculations y = tf.reduce_sum(x * x + 2 * z) # Extract the gradient for the specific inputs (`x` and `z`) grad = tape.gradient(y, [x, z]) print(f'Result of y: {y}') print(f"The gradient of y with respect to x is:\n{grad[0].numpy()}") print(f"The gradient of y with respect to z is: {grad[1].numpy()}")
copy

Tämä koodi laskee funktion y = sum(x^2 + 2*z) gradientin annetuilla x- ja z-arvoilla. Tässä esimerkissä x:n gradientti esitetään kaksiulotteisena tensorina, jossa jokainen alkio vastaa alkuperäisen x-matriisin arvon osittaisderivaattaa.

Note
Huomio

Lisätietoja Gradient Tape -ominaisuuksista, kuten korkeamman asteen derivaatat ja Jacobin matriisin erottaminen, löytyy virallisesta TensorFlow -dokumentaatiosta.

Tehtävä

Swipe to start coding

Tavoitteena on laskea annetun matemaattisen funktion gradientti (eli derivaatta) tietyssä pisteessä TensorFlow'n Gradient Tape -toiminnallisuutta hyödyntäen. Funktio ja piste annetaan valmiina, ja näet, kuinka TensorFlow'ta käytetään gradientin löytämiseen kyseisessä pisteessä.

Tarkastellaan yksimuuttujaista toisen asteen funktiota x, joka on määritelty seuraavasti:

f(x) = x^2 + 2x - 1

Tehtävänäsi on laskea tämän funktion derivaatta kohdassa x = 2.

Vaiheet

  1. Määrittele muuttuja x siihen pisteeseen, jossa haluat laskea derivaatan.
  2. Käytä Gradient Tape -toimintoa tallentaaksesi funktion f(x) laskennan.
  3. Laske funktion f(x) gradientti annetussa pisteessä.

Huom

Gradientti voidaan laskea vain liukulukutyyppisille arvoille.

Derivative of a Function at a Point

Ratkaisu

Oliko kaikki selvää?

Miten voimme parantaa sitä?

Kiitos palautteestasi!

Osio 2. Luku 1
single

single

Kysy tekoälyä

expand

Kysy tekoälyä

ChatGPT

Kysy mitä tahansa tai kokeile jotakin ehdotetuista kysymyksistä aloittaaksesi keskustelumme

Suggested prompts:

Can you explain how Gradient Tape works in more detail?

What are some practical applications of Gradient Tape in machine learning?

Can you show more examples of using Gradient Tape with different functions?

close

Awesome!

Completion rate improved to 5.56

bookGradienttiteippi

Pyyhkäise näyttääksesi valikon

Gradient Tape

Perustietämys tensorien käsittelystä mahdollistaa siirtymisen prosessien tehostamiseen ja nopeuttamiseen hyödyntämällä TensorFlown sisäänrakennettuja ominaisuuksia. Ensimmäinen näistä edistyneistä työkaluista on Gradient Tape.

Mikä on Gradient Tape?

Tässä luvussa käsitellään yhtä TensorFlown keskeisistä käsitteistä, Gradient Tape -ominaisuutta. Tämä toiminto on olennainen gradienttipohjaisten optimointimenetelmien ymmärtämisessä ja toteuttamisessa, erityisesti syväoppimisessa.

Gradient Tape TensorFlow'ssa on työkalu, joka tallentaa laskutoimitukset automaattista differentiaatiota varten. Kun laskutoimitukset suoritetaan Gradient Tape -lohkon sisällä, TensorFlow seuraa kaikkia suoritettuja laskutoimituksia. Tämä on erityisen hyödyllistä koneoppimismallien koulutuksessa, jossa gradientteja tarvitaan mallin parametrien optimointiin.

Note
Huomio

Käytännössä gradientti on osittaisderivaattojen joukko.

Gradient Tapen käyttö

Gradient Tapen käyttöön liittyvät seuraavat vaiheet:

  • Luo Gradient Tape -lohko: käytä with tf.GradientTape() as tape:. Tämän lohkon sisällä kaikki laskutoimitukset tallennetaan;
  • Määrittele laskutoimitukset: suorita tensorien kanssa operaatioita lohkon sisällä (esim. määrittele neuroverkon eteenpäin suuntautuva laskenta);
  • Laske gradientit: käytä tape.gradient(target, sources) laskeaksesi gradientit kohteen suhteen lähteisiin.

Yksinkertainen gradientin laskenta

Yksinkertainen esimerkki tämän ymmärtämiseksi paremmin.

123456789101112131415
import tensorflow as tf # Define input variables x = tf.Variable(3.0) # Start recording the operations with tf.GradientTape() as tape: # Define the calculations y = x * x # Extract the gradient for the specific input (`x`) grad = tape.gradient(y, x) print(f'Result of y: {y}') print(f'The gradient of y with respect to x is: {grad.numpy()}')
copy

Tämä koodi laskee funktion y = x^2 gradientin kohdassa x = 3. Tämä vastaa funktion y osittaisderivaattaa muuttujan x suhteen.

Useita osittaisderivaattoja

Kun ulostuloon vaikuttaa useita syötteitä, voidaan laskea osittaisderivaatta jokaista näistä syötteistä (tai vain valituista) kohtaan. Tämä tehdään antamalla muuttujalista sources-parametrina.

Tämän operaation tuloksena saadaan vastaava tensorilista, jossa jokainen tensori edustaa osittaisderivaattaa suhteessa kuhunkin sources-listassa määriteltyyn muuttujaan.

1234567891011121314151617
import tensorflow as tf # Define input variables x = tf.Variable(tf.fill((2, 3), 3.0)) z = tf.Variable(5.0) # Start recording the operations with tf.GradientTape() as tape: # Define the calculations y = tf.reduce_sum(x * x + 2 * z) # Extract the gradient for the specific inputs (`x` and `z`) grad = tape.gradient(y, [x, z]) print(f'Result of y: {y}') print(f"The gradient of y with respect to x is:\n{grad[0].numpy()}") print(f"The gradient of y with respect to z is: {grad[1].numpy()}")
copy

Tämä koodi laskee funktion y = sum(x^2 + 2*z) gradientin annetuilla x- ja z-arvoilla. Tässä esimerkissä x:n gradientti esitetään kaksiulotteisena tensorina, jossa jokainen alkio vastaa alkuperäisen x-matriisin arvon osittaisderivaattaa.

Note
Huomio

Lisätietoja Gradient Tape -ominaisuuksista, kuten korkeamman asteen derivaatat ja Jacobin matriisin erottaminen, löytyy virallisesta TensorFlow -dokumentaatiosta.

Tehtävä

Swipe to start coding

Tavoitteena on laskea annetun matemaattisen funktion gradientti (eli derivaatta) tietyssä pisteessä TensorFlow'n Gradient Tape -toiminnallisuutta hyödyntäen. Funktio ja piste annetaan valmiina, ja näet, kuinka TensorFlow'ta käytetään gradientin löytämiseen kyseisessä pisteessä.

Tarkastellaan yksimuuttujaista toisen asteen funktiota x, joka on määritelty seuraavasti:

f(x) = x^2 + 2x - 1

Tehtävänäsi on laskea tämän funktion derivaatta kohdassa x = 2.

Vaiheet

  1. Määrittele muuttuja x siihen pisteeseen, jossa haluat laskea derivaatan.
  2. Käytä Gradient Tape -toimintoa tallentaaksesi funktion f(x) laskennan.
  3. Laske funktion f(x) gradientti annetussa pisteessä.

Huom

Gradientti voidaan laskea vain liukulukutyyppisille arvoille.

Derivative of a Function at a Point

Ratkaisu

Switch to desktopVaihda työpöytään todellista harjoitusta vartenJatka siitä, missä olet käyttämällä jotakin alla olevista vaihtoehdoista
Oliko kaikki selvää?

Miten voimme parantaa sitä?

Kiitos palautteestasi!

Osio 2. Luku 1
single

single

some-alt