Hvordan bestemme den deriverte i et punkt numerisk
Til nå har vi sett på hvordan vi kan finne den deriverte eksakt, enten algebraisk som grenseverdien til et uttrykk eller grafisk som stigningstallet til en tangent. Nå skal vi finne den deriverte i et punkt numerisk, men for å gjøre det må vi vite hva det vil si å løse noe numerisk.
Numerisk metode med CAS i GeoGebra
Du har kanskje lagt merke til at det for eksempel i GeoGebra er to alternativer for å løse en likning, markert med eller . Disse tilsvarer kommandoene "Løs" og "NLøs". Den første varianten finner det eksakte svaret, og den andre varianten finner et tilnærmet svar. Som oftest er svarene nokså like, men kanskje har du også opplevd å få ulikt svar hvis du bruker begge metodene?
Noen ganger greier ikke GeoGebra å regne ut det eksakte svaret på likningen, men vi kan finne et tilnærmet svar ved å velge "NLøs". Andre ganger finner GeoGebra kanskje to løsninger ved å regne eksakt, mens det bare kommer én tilnærmet løsning. Denne måten å finne løsninger på er en numerisk metode.
Det å finne et tall numerisk skiller seg fra andre måter å regne på ved at det er en form for såkalt prøve-og-feile-metode. Det vil si at man starter med et forslag til løsning, og ved hjelp av ulike mønstre nærmer man seg den egentlige løsningen. Når GeoGebra har funnet en løsning, slutter programmet å lete, selv om det kan finnes flere løsninger. Dette er en viktig grunn til alltid å velge eksakt løsning av likninger, for så å runde av svarene etterpå.
Vi kan se på et eksempel der vi forsøker å løse et likningssett:

Vi legger merke til at "Løs" finner begge de to løsningene, mens "NLøs" sluttet å lete etter å ha funnet den ene løsningen. Vi kan stort sett stole på at løsningen "NLøs" gir oss, er rett, men ikke at den gir oss alle løsningene. Dette er felles for de fleste numeriske metoder.
Numerisk derivasjon i Python
I 1T brukte vi numeriske metoder både for hånd og ved hjelp av programmering. Vi fant blant annet nullpunkt på oppgavesiden "Programmering av nullpunkt med halveringsmetoden". Vi fant også tilnærmede verdier for den deriverte med programmering på oppgavesiden "Tilnærmede verdier til den deriverte". Å lete etter løsninger er tidkrevende hvis man skal gjøre det for hånd, så dette er en oppgave for datamaskiner.
Vi skal her vise en måte vi kan bruke når vi skal finne en tilnærming til den deriverte gjennom programmering. Vi bruker som eksempel at vi skal finne den deriverte der for funksjonen . Vi tar utgangspunkt i definisjonen til den deriverte:
Hvis vi i stedet for å la gå mot 0 setter , der h er et veldig lite tall, får vi det vi kaller Newtons kvotient. Da kan vi si at vi kan definere den deriverte som en tilnærming slik:
Målet vårt er nå å lage et program som kan gjøre tilnærmingen til den deriverte så god vi ønsker, gjennom å gjøre h mindre og mindre. Før vi begynner selve kodingen, kan det lønne seg å beskrive nøye i en tekst hva vi ønsker å gjøre, før vi lager en mer trinnvis algoritme.
🤔 Tenk over: Hva må være med i programmet for at vi skal finne en god tilnærming til den deriverte? Prøv selv å formulere en tekst før du ser på beskrivelsen av programmet i boksen under.
Algoritme
Ut fra teksten over kan vi prøve å skrive en algoritme for programmet:
Først definerer vi funksjonen.
Vi definerer en funksjon for den deriverte.
Vi definerer x-verdien til punktet der vi skal finne den deriverte.
Vi setter startverdien til h.
Vi definerer en variabel na for nøyaktighet og setter den til 0,0001.
Vi setter startverdien for forrige tilnærmingsverdi til og startverdi for siste tilnærmingsverdi til h.
Vi starter ei løkke som skal gå så lenge forskjellen mellom to påfølgende tilnærminger er større enn na.
Inne i løkka regner vi ut en tilnærming og halverer h.
Vi må skrive ut tilnærmingen når vi har kommet langt nok.
Program
Følg algoritmen over og se om du klarer å lage programmet før du ser i boksen. Kanskje er ditt program mer effektivt enn vårt, eller bare annerledes, men like bra? Husk alltid at det er mange måter å lage et program på.
På oppgavesiden skal du få prøve andre måter å tilnærme verdien til den deriverte på.