1. domača naloga
Navodila
Izberite eno izmed spodnjih nalog. Po možnosti tako, ki je ni še nihče drug izbral (preverite zahtevke na Gitlabu).
Domačo nalogo lahko delate skupaj s kolegi, vendar morate v tem primeru rešiti toliko različnih nalog, kot je študentov v skupini.
Oddaja naloge
Naloge oddajte na Gitlab.
Naloge, ki jih boste oddali na Gitlabu, bodo javno dostopne. Če kdo ne želi, da je njegov izdelek javno dostopen, naj si ustvari privatno različico(fork) repozitorija nummat-1819 in naj povabi zraven kolega, ki bo kodo pregledal in asistenta(@mrcinv). Če kdo ne želi uporabljati Gitlaba ali programskega jezika julia, naj se oglasi asistentu.
Navodila za oddajo naloge (glejte tudi dokument o delu z gitom in Gitlabom)
- Ustvarite svoj zahtevek(issue) in zahtevo za združitev(merge request).
- Napište kodo, teste in kratek dokument z opisom rešitve in primerom. Kodo potisnite na repozitorij v svoji git veji.
- Povabite kolega, da pregleda vašo kodo, tako da ga omenite kot
@vzdevek
v komentarju na zahtevi za združitev(merge request). - Ko je pregled končan in pripombe kolega upoštevane, povabite še asistenta (
@mrcinv
).
Rešitev naloge naj vsebuje vsaj 3 datoteke:
- izvorna kodo v
src/domaca01/vzdevek/ImeNaloge.jl
- testi v
test/domace/01/vzdevek/ImeNaloge.jl
, ki so vključeni vtest/runtests.jl
- kratek dokument z opisom rešitve v
doc/src/domace/01/vzdevek/ImeNaloge.md
in „praktičnim“ primerom uporabe (slikice prosim :-)).
Po lastni presoji, lahko rešitev vsebuje tudi več drugih datotek. Vsaka funkcija naj tudi vsebuje docstring z opisom funkcije.
Naloge
Linearni sistemi za tri-diagonalne matrike
Naj bo $A\in\mathbb{R}^{n\times n}$ tri-diagonalna, diagonalno dominantna matrika. Primer tridiagonalne $4\times 4$ matrike
Definirajte podatkovni tip Tridiagonalna
, ki hrani le neničelne elemente tridiagonalne matrike. Za podatkovni tip Tridiagonalna
definirajte metode za naslednje funkcije:
- indeksiranje:
Base.getindex
,Base.setindex!
,Base.firstindex
inBase.lastindex
- množenje z desne
Base.*
z vektorjem - „deljenje“ z leve
Base.\
Časovna zahtevnost omenjenih funkcij naj bo linearna. Več informacij o tipih in vmesnikih.
Napišite funkcijo x, it = sor(A, b, x0, omega, tol=1e-10)
, ki reši tridiagonalni sistem $Ax=b$ z SOR iteracijo. Pri tem je x0
začetni približek, tol
pogoj za ustavitev iteracije in omega
parameter pri SOR iteraciji. Iteracija naj se ustavi, ko je
Primerjajte hitrost operatorja \
in SOR iteracije. Kot primer uporabite Laplaceovo matriko $a_{ii}=-2,\quad a_{i, i+1} = a_{i, i-1} = 1$ in konstantne desne strani. ( Če je $b_i=n^{-2}$, ta sistem predstavlja diskretizacijo robnega problema za Poissonovo enačbo v 1 dimenziji $y''(x) = 1,\quad y(0) = y(1) = 0.$)
Za ta primer Izračunajte tudi parameter $\omega$, pri katerem SOR najhitreje konvergira.
Pasovne diagonalno dominantne matrike
Pasovna matrika je matrika, ki ima neničelne elemente le v glavni diagonali in v nekaj stranskih diagonalah ob glavni diagonali. Matrika je diagonalno dominantna po vrsticah, če za vse $i$ velja
Definirajte podatkovni tipe
PasovnaMatrika
, ki predstavlja pasovno matriko,ZgornjePasovnaMatrika
, ki predstavlja zgornje trikotno pasovno matriko inSpodnjePasovnaMatrika
, ki predstavlja spodnje trikotno pasovno matriko
Podatkovni tipi naj hranijo le neničelne elemente matrike. Za omenjene podatkovne tipe definirajte metode za naslednje funkcije:
- indeksiranje:
Base.getindex
,Base.setindex!
,Base.firstindex
inBase.lastindex
- množenje z desne
Base.*
z vektorjem - „deljenje“ z leve
Base.\
lu
, ki izračuna LU-razcep brez pivotiranja, če je matrika diagonalno dominantna, sicer pa javi napako. Vrnjena faktorja
naj bosta tipa SpodnjePasovnaMatrika
in ZgornjePasovnaMatrika
.
Časovna zahtevnost omenjenih funkcij naj bo linearna (odvisna od širine pasu). Več informacij o tipih in vmesnikih.
Za primer rešite sistem za Laplaceovo matriko v 2D.
SOR iteracija za razpršene matrike
Naj bo A n × n diagonalno dominantna razpršena matrika(velika večina elementov je ničelnih $a_{ij}=0$).
Definirajte nov podatkovni tip RazprsenaMatrika
, ki matriko zaradi prostorskih zahtev hrani v dveh matrikah $V$ in $I$, kjer sta $V$ in $I$ matriki $n \times m$, tako da velja
V matriki $V$ se torej nahajajo neničelni elementi matrike $A$. Vsaka vrstica matrike $V$ vsebuje ničelne elemente iz iste vrstice v $A$. V matriki $I$ pa so shranjeni indeksi stolpcev teh neničelnih elementov.
Za podatkovni tip RazprsenaMatrika
definirajte metode za naslednje funkcije:
- indeksiranje:
Base.getindex
,Base.setindex!
,Base.firstindex
inBase.lastindex
- množenje z desne
Base.*
z vektorjem
Več informacij o tipih in vmesnikih.
Napišite funkcijo x, it = sor(A, b, x0, omega, tol=1e-10)
, ki reši tridiagonalni sistem $Ax=b$ z SOR iteracijo. Pri tem je x0
začetni približek, tol
pogoj za ustavitev iteracije in omega
parameter pri SOR iteraciji. Iteracija naj se ustavi, ko je
Metodo uporabite za vožitev grafa v ravnino ali prostor s fizikalno metodo. Če so $(x_i, y_i, z_i)$ koordinate vozlišč grafa v prostoru, potem vsaka koordinata posebej zadošča enačbam
kjer je $st(i)$ stopnja $i$-tega vozlišča, $N(i)$ pa množica indeksov sosednjih vozlišč. Če nekatera vozlišča fiksiramo, bodo ostala zavzela ravnovesno lego med fiksiranimi vozlišči.
Za primere, ki jih boste opisali, poiščite optimalni omega
, pri katerem SOR najhitreje konvergira in predstavite odvisnost hitrosti konvergence od izbire $\omega$.
Metoda konjugiranih gradientov za razpršene matrike
Definirajte nov podatkovni tip RazprsenaMatrika
, kot je opisano v prejšnji nalogi.
Napišite funkcijo [x,i]=conj_grad(A, b)
, ki reši sistem
z metodo konjugiranih gradientov za A
tipa RazprsenaMatrika
.
Metodo uporabite na primeru vložitve grafa v ravnino ali prostor s fizikalno metodo, kot je opisano v prejšnji nalogi.
Metoda konjugiranih gradientov s predpogojevanjem
Za pohitritev konvergence iterativnih metod, se velikokrat izvede t. i. predpogojevanje(angl. preconditioning). Za simetrične pozitivno definitne matrike je to pogosto nepopolni razcep Choleskega, pri katerem sledimo algoritmu za razcep Choleskega, le da ničelne elemente pustimo pri miru.
Naj bo A $n\times n$ pozitivno definitna razpršena matrika(velika večina elementov je ničelnih $a_{ij}=0$). Matriko zaradi prostorskih zahtev hranimo kot sparse matriko. Poglejte si dokumentacijo za razpršene matrike.
Napišite funkcijo L = nep_chol(A)
, ki izračuna nepopolni razcep Choleskega za matriko tipa AbstractSparseMatrix
. Napišite še funkcijo x, i = conj_grad(A, b, L)
, ki reši linearni sistem
s predpogojeno metodo konjugiranih gradientov za matriko $M = L^T L$ kot predpogojevalcem. Pri tem pazite, da matrike $M$ ne izračunate, ampak uporabite razcep $M = L^TL$. Za različne primere preverite, ali se izboljša hitrost konvergence.
QR razcep zgornje hessenbergove matrike
Naj bo $H$ $n\times n$ zgornje hessenbergova matrika (velja $a_{ij}=0$ za $j < j-2i$). Definirajte podatkovni tip ZgornjiHessenberg
za zgornje hessenbergovo matriko.
Napišite funkcijo Q, R = qr(H)
, ki izvede QR razcep matrike H
tipa ZgornjiHessenberg
z Givensovimi rotacijami. Matrika R
naj bo zgornje trikotna matrika enakih dimenzij kot H
, v Q
pa naj bo matrika tipa Givens
.
Podatkovni tip Givens
definirajte sami tako, da hrani le zaporedje rotacij, ki se med razcepom izvedejo in indekse vrstic, na katere te rotacije delujejo. Posamezno rotacijo predstavite s parom
kjer je α kot rotacije na posameznem koraku. Za podatkovni tip definirajte še množenje Base.*
z vektorji in matrikami.
Uporabite QR razcep za QR iteracijo zgornje hesenbergove matrike. Napišite funkcijo lastne_vrednosti, lastni_vektorji = eigen(H)
, ki poišče lastne vrednosti in lastne vektorje zgornje hessenbergove matrike.
Preverite časovno zahtevnost vaših funkcij in ju primerjajte z metodami qr
in eigen
za navadne matrike.
QR razcep simetrične tridiagonalne matrike
Naj bo $A$ $n × n$ simetrična tridiagonalna matrika (velja $a_{ij}=0$ za $|i-j|>1$).
Definirajte podatkovni tip SimetricnaTridiagonalna
za simetrično tridiagonalno matriko, ki hrani glavno in stransko diagonalo matrike. Za tip SimetricnaTridiagonalna
definirajte metode za naslednje funkcije:
- indeksiranje:
Base.getindex
,Base.setindex!
,Base.firstindex
inBase.lastindex
- množenje z desne
Base.*
z vektorjem ali matriko
Časovna zahtevnost omenjenih funkcij naj bo linearna. Več informacij o tipih in Napišite funkcijo Q, R = qr(T)
, ki izvede QR razcep matrike T
tipa Tridiagonalna
z Givensovimi rotacijami. Matrika R
naj bo zgornje trikotna dvodiagonalna matrika tipa ZgornjeDvodiagonalna
, v Q
pa naj bo matrika tipa Givens
. vmesnikih.
Podatkovna tipa ZgornjeDvodiagonalna
in Givens
definirajte sami (glejte tudi nalogo QR razcep zgornje hessenbergove matrike). Poleg tega implementirajte množenje Base.*
matrik tipa Givens
in ZgornjeDvodiagonalna
.
Uporabite QR razcep za QR iteracijo simetrične tridiagonalne matrike. Napišite funkcijo lastne_vrednosti, lastni_vektorji = eigen(T)
, ki poišče lastne vrednosti in lastne vektorje simetrične tridiagonalne matrike.
Preverite časovno zahtevnost vaših funkcij in ju primerjajte z metodami qr
in eigen
za navadne matrike.
Inverzna potenčna metoda za zgornje hessenbergovo matriko
Lastne vektorje matrike $A$ lahko računamo z inverzno potenčno metodo. Naj bo $A_\lambda = A-\lambda I$. Če je $\lambda$ približek za lastno vrednost, potem zaporedje vektorjev
konvergira k lastnemu vektorju za lastno vrednost, ki je po absolutni vrednosti najbližje vrednosti $\lambda$.
Da bi zmanjšali število operacij na eni iteraciji, lahko poljubno matriko $A$ prevedemo v zgornje hessenbergovo obliko (velja $a_{ij} = 0$ za $j < i - 2$). S hausholderjevimi zrcaljenji lahko poiščemo zgornje hesenbergovo matriko H, ki je podobna matriki A:
Če je $v$ lastni vektor matrike $H$, je $Qv$ lastni vektor matrike $A$, lastne vrednosti matrik $H$ in $A$ pa so enake.
Napišite funkcijo H, Q = hessenberg(A)
, ki s Hausholderjevimi zrcaljenji poišče zgornje hesenbergovo matriko H
tipa ZgornjiHessenberg
, ki je podobna matriki A
.
Tip ZgornjiHessenberg
definirajte sami, kot je opisano v nalogi o QR razcepu zgornje hessenbergove matrike. Poleg tega implementirajte metodo L, U = lu(A)
za matrike tipa ZgornjiHessenberg
, ki bo pri razcepu upoštevala lastnosti zgornje hessenbergovih matrik. Matrika L
naj ne bo polna, ampak tipa SpodnjaTridiagonalna
. Tip SpodnjaTridiagonalna
definirajte sami, tako da bo hranil le neničelne elemente in za ta tip matrike definirajte operator Base.\
, tako da bo upošteval strukturo matrikw L
.
Napišite funkcijo lambda, vektor = inv_lastni(A, l)
, ki najprej naredi hessenbergov razcep in nato izračuna lastni vektor in točno lastno matrike A
, kjer je l
približek za lastno vrednost. Inverza matrike A
nikar ne računajte, ampak raje uporabite LU razcep in na vsakem koraku rešite sistem $L(Ux^{n+1})=x^n$.
Metodo preskusite za izračun ničel polinoma. Polinomu
lahko priredimo matriko
katere lastne vrednosti se ujemajo z ničlami polinoma.
Inverzna potenčna metoda za tridiagonalno matriko
Lastne vektorje matrike $A$ lahko računamo z inverzno potenčno metodo. Naj bo $A_\lambda = A-\lambda I$. Če je $\lambda$ približek za lastno vrednost, potem zaporedje vektorjev
konvergira k lastnemu vektorju za lastno vrednost, ki je po absolutni vrednosti najbližje vrednosti $\lambda$.
Naj bo $A$ simetrična matrika. Da bi zmanjšali število operacij na eni iteraciji, lahko poljubno simetrično matriko $A$ prevedemo v tridiagonalno obliko. S hausholderjevimi zrcaljenji lahko poiščemo tridiagonalno matriko T, ki je podobna matriki A:
Če je $v$ lastni vektor matrike $T$, je $Qv$ lastni vektor matrike $A$, lastne vrednosti matrik $T$ in $A$ pa so enake.
Napišite funkcijo T, Q = tridiag(A)
, ki s Hausholderjevimi zrcaljenji poišče tridiagonalno matriko H
tipa Tridiagonalna
, ki je podobna matriki A
.
Tip Tridiagonalna
definirajte sami, kot je opisano v nalogi o QR razcepu tridiagonalne matrike. Poleg tega implementirajte metodo L, U = lu(A)
za matrike tipa Tridiagonalna
, ki bo pri razcepu upoštevala lastnosti tridiagonalnih matrik. Matrike L
in U
naj ne bodo polne matrike. Matrika L
naj bo tipa SpodnjaTridiagonalna
, matrika U
pa tipa ZgornjaTridiagonalna
. Tipa SpodnjaTridiagonalna
in ZgornjaTridiagonalna
definirajte sami, tako da bosta hranila le neničelne elemente. Za oba tipa definirajte operator Base.\
, tako da bo upošteval strukturo matrik.
Napišite funkcijo lambda, vektor = inv_lastni(A, l)
, ki najprej naredi hessenbergov razcep in nato izračuna lastni vektor in točno lastno matrike A
, kjer je l
približek za lastno vrednost. Inverza matrike A
nikar ne računajte, ampak raje uporabite LU razcep in na vsakem koraku rešite sistem $L(Ux^{n+1})=x^n$.
Metodo preskusite na laplaceovi matriki, ki ima vse elemente $0$ razen $l_{ii}=-2, l_{i+1,j}=l_{i,j+1}=1$. Poiščite nekaj lastnih vektorjev za najmanjše lastne vrednosti in jih vizualizirajte z ukazom plot
.
Lastni vektorji laplaceove matrike so približki za rešitev robnega problema za diferencialno enačbo
katere rešitve sta funkciji $\sin(\lambda x)$ in $\cos(\lambda x)$.
Naravni zlepek
Danih je $n$ interpolacijskih točk $(x_i,f_i)$, $i=1,2,...,n$. Naravni interpolacijski kubični zlepek $S$ je funkcija, ki izpolnjuje naslednje pogoje:
- \[S(x_i)=f_i, \quad i=1,2,...,n.\]
- \[S\]je polinom stopnje $3$ ali manj na vsakem podintervalu $[x_i,x_{i+1}]$, $i=1,2,...,n-1$.
- \[S\]je dvakrat zvezno odvedljiva funkcija na interpolacijskem intervalu $[x_1,x_n]$
- \[S^{\prime\prime}(x_1)=S^{\prime\prime}(x_n)=0\].
Zlepek $S$ določimo tako, da postavimo
nato pa izpolnimo zahtevane pogoje [2].
Napišite funkcijo Z = interpoliraj(x, y)
, ki izračuna koeficient polinoma $S_i$ in vrne element tipa Zlepek
.
Tip Zlepek
definirajte sami in naj vsebuje koeficiente polinoma in interpolacijske točke. Za tip Zlepek
napišite dve funkciji
y = vrednost(Z, x)
, ki vrne vrednost zlepka v dani točkix
.plot(Z)
, ki nariše graf zlepka, tako da različne odseke izmenično nariše z rdečo in modro barvo(uporabi paketPlots
).
pomagajte si z: Bronštejn, Semendjajev, Musiol, Mühlig: Matematični priročnik, Tehniška založba Slovenije, 1997, str. 754 ali pa J. Petrišič: Interpolacija, Univerza v Ljubljani, Fakulteta za strojništvo, Ljubljana, 1999, str. 47
QR iteracija z enojnim premikom
Naj bo $A$ simetrična matrika. Napišite funkcijo, ki poišče lastne vektorje in vrednosti simetrične matrike z naslednjim algoritmom
- Izvedi Hessenbergov razcep matrike $A=U^T T U$ (uporabite lahko vgrajeno funkcijo
LinearAlgebra.hessenberg
) - Za tridiagonalno matriko $T$ ponavljaj, dokler ni $h_{n-1,n}$ dovolj majhen:
- za $T - \mu I$ za $\mu = h_{n,n}$ izvedi QR razcep
- nov približek je enak $RQ + \mu I$
- Postopek ponovi za podmatriko brez zadnjega stolpca in vrstice
Napiši metodo lastne_vrednosti, lastni_vektorji = eigen(A, EnojniPremik(), vektorji = false)
, ki vrne
- vektor lastnih vrednosti simetrične matrike
A
, če je vrednostvektorji
enakafalse
. - vektor lastnih vrednosti
lambda
in matriko s pripadajočimi lastnimi vektorjiV
, če jevektorji
enakatrue
Pazi na časovno in prostorsko zahtevnost algoritma. QR razcep tridiagonalne matrike izvedi z Givensovimi rotacijami in hrani le elemente, ki so nujno potrebni (glej nalogo QR razcep simetrične tridiagonalne matrike).
Funkcijo preiskusi na Laplaceovi matriki grafa podobnosti (glej vajo o spektralnem gručenju).