- MATH.APP.160
- 4. Toisen ja korkeamman kertaluvun differentiaaliyhtälöt
- 4.4 Normaaliryhmä
\({}^*\)Normaaliryhmä¶
Tässä lisäkappaleessa luodaan katsaus useammasta differentiaaliyhtälöstä muodostuvaan differentiaaliyhtälöryhmään. Esimerkkien avulla pohditaan, kuinka käytännön ongelmasta muokataan normaalimuotoinen differentiaaliyhtälöryhmä ja kuinka se voidaan ratkaista numeerisesti Matlabilla. Varsinainen lineaaristen differentiaaliyhtälöryhmien teoria jätetään tulevalle opintojaksolle.
Määritelmä 4.4.1
Olkoot \(x_1,x_2,\ldots,x_n\) tuntemattomia reaalifunktioita. Ensimmäisen kertaluvun differentiaaliyhtälöistä koostuvaa yhtälöryhmää
missä funktiot \(f_i : I\times\R^n\to\R\) ovat \(n+1\) muuttujan reaaliarvoisia funktioita, kutsutaan normaaliryhmäksi (first-order system). Välillä \(I\) derivoituvat funktiot \(x_1,x_2,\ldots,x_n\) muodostavat normaaliryhmän ratkaisun välillä \(I\), jos yhtälöryhmän (1) yhtälöt ovat voimassa aina, kun \(t\in I\).
Normaaliryhmään liittyvällä alkuarvotehtävällä tarkoitetaan sellaisen ratkaisun hakemista, joka toteuttaa ennalta asetetut ehdot
välin \(I\) pisteessä \(t_0\).
Esimerkki 4.4.2
Differentiaaliyhtälöryhmä
on funktioiden \(x\) ja \(y\) normaaliryhmä, jonka määrittelevät funktiot \(f_1(t,x,y)=2x+y\) ja \(f_2(t,x,y)=x+2y-e^{2t}\). Ryhmän eräs ratkaisu on
sillä näille funktioille on voimassa
Määritelmä 4.4.3
Muotoa
oleva differentiaaliyhtälö on funktion \(x=x(t)\) \(n\). kertaluvun normaalimuotoinen differentiaaliyhtälö.
Normaalimuotoinen yhtälö voidaan palauttaa normaaliryhmäksi asettamalla
sillä tällöin
Nyt normaalimuotoisen differentiaaliyhtälön ratkaisemiseksi riittää ratkaista normaaliryhmä
ja tämän ratkaisusta poimitaan \(x(t)=x_1(t)\).
Esimerkki 4.4.4
Muokkaa alkuarvotehtävä
normaaliryhmäksi.
Asetetaan
jolloin normaaliryhmäksi tulee
Myös useamman normaalimuotoisen differentiaaliyhtälön ryhmä voidaan palauttaa normaaliryhmäksi.
Esimerkki 4.4.5
Tarkastellaan oheisen kuvan mukaista kahden jousen systeemiä.
Paikkojen \(x_1(t)\) ja \(x_2(t)\) nollakohdat on kiinnitetty siten, että tasapainotilassa \(x_1=x_2=0\). Massaan \(m_1\) vaikuttaa jousen 1 aiheuttaman jousivoiman \(-k_1x_1\) lisäksi jousen 2 aiheuttama voima \(k_2(x_2-x_1)\), missä \(x_2-x_1\) on jousen 2 venymä. Jousen 2 aiheuttama voima osoittaa siis oikealle, jos jousi 2 on venynyt eli \(x_2-x_1>0\). Massaan \(m_2\) vaikuttaa tämän vastavoima eli \(-k_2(x_2-x_1)\). Systeemin käyttäytymistä kuvaa siten differentiaaliyhtälöryhmä
Muunnetaan tämä normaaliryhmäksi merkitsemällä \(x_3=x_1'\) ja \(x_4=x_2'\), jolloin saadaan
Huomautus 4.4.6
Miksi normaaliryhmä? Ensimmäisen kertaluvun differentiaaliyhtälöiden ja normaaliryhmien ratkaisemiseksi on tehokkaita numeerisia menetelmiä. Käytännössä differentiaaliyhtälö tai yhtälöryhmä usein palautetaankin normaaliryhmäksi ja ratkaistaan numeerisesti. Muuttujien ja yhtälöiden lukumäärä voi sovelluksissa hyvin olla tuhansia.
Normaaliryhmän ratkaiseminen numeerisesti Matlabilla¶
Merkitään \(\bx=(x_1,\ldots,x_n)\in\R^n\). Tällöin normaaliryhmän funktioita voidaan merkitä lyhyesti \(f_i(t,x_1,\ldots,x_n)=f_i(t,\bx)\). Muodostetaan reaaliarvoisista funktioista \(f_i\) vektoriarvoinen funktio
Myös alkuehdot \(x_1(t_0)=b_1,\ldots,x_n(t_0)=b_n\) voidaan antaa vektorimuodossa, kuten
Tutkitaan esimerkiksi alkuarvotehtävää
Funktio \(\mathbf{f}\) on
Matlabissa tämä voidaan syöttää seuraavasti.
f=@(t,x)[x(1)+t*x(2);x(1)+5*x(2)+exp(t)]
Tässä x
on vektori, jonka komponentteihin viitataan x(1)
ja x(2)
. Jos halutaan välillä \([t_0,t_1]\) numeerinen arvio ratkaisulle, joka toteuttaa alkuehdon \(\bx(t_0)=(b_1,b_2)\), voidaan käyttää Matlabin ode45
-funktiota.
[t,x] = ode45(f,[t0 t1],[b1 b2]);
Esimerkissämme alkuehto on \(\bx(-1)=(1{,}5,\ -0{,}5)\), joten
[t,x] = ode45(f,[-1 0],[1.5 -0.5]);
antaa approksimaation ratkaisulle välillä \([-1,0]\). Nyt vektorissa t
on järjestyksessä muuttujan \(t\) arvoja väliltä \([-1,0]\). Matriisin x
ensimmäisessä sarakkeessa x(:,1)
on vastaavilla paikoilla arviot arvoille \(x_1(t)\) ja toisessa sarakkeessa x(:,2)
arviot arvoille \(x_2(t)\). Funktioiden \(x_1(t)\) ja \(x_2(t)\) kuvaajat voidaan siten piirtää.
plot(t,x(:,1),t,x(:,2))
Matlabin ohjeissa funktiolle \(\mathbf{f}\) käytetään nimeä odefun
.
Esimerkki 4.4.7
Ratkaistaan aiempi esimerkki Matlabilla. Symbolista ratkaisua ei voida muodostaa.
x=dsolve('D3x=-(Dx)^2-3*x+exp(t),x(0)=1,Dx(0)=0,D2x(0)=0','t')
Warning: Explicit solution could not be found.
x = [ empty sym ]
Ratkaistaan vastaava normaaliryhmä (2) numeerisesti välillä \(t\in[0,3]\) funktiolla ode45
ja tulostetaan ratkaisun \(x(t)=x_1(t)\) kuvaaja:
odefun=@(t,x)[x(2);x(3);-x(2)^2-3*x(1)+exp(t)]
t0 = 0;
t1 = 3;
x0 = [1 0 0]
[t,x] = ode45(odefun,[t0 t1],x0);
plot(t,x(:,1))
Esimerkki 4.4.8
Ratkaistaan aiemman esimerkin kahden jousen systeemi Matlabilla tapauksessa \(m_1=m_2=1\), \(k_1=1\) ja \(k_2=2\) välillä \(t\in[0,20]\) funktiolla ode45
ja tulostetaan ratkaisujen \(x_1(t)\) ja \(x_2(t)\) kuvaajat.
odefun=@(t,x)[x(3);x(4);-x(1)+2*(x(2)-x(1));-2*(x(2)-x(1))]
t0 = 0;
t1 = 20;
x0 = [1 0 0 0]
[t,x] = ode45(odefun,[t0 t1],x0);
plot(t,x(:,1),t,x(:,2),'--')
Tämän tehtävän Matlab osaa ratkaista myös symbolisesti.
s=dsolve('D2x=-x+2*(y-x),D2y=-2*(y-x)',...
'x(0)=1,y(0)=0,Dx(0)=0,Dy(0)=0','t')
s.x
s.y
Tarkastellaan peto-saalis- järjestelmää (predator-prey system), jossa on yksi petolaji ja sillä yksi saalislaji, esimerkiksi pöllöt ja myyrät. Kun saaliin määrä kasvaa, niin petojen lukumääräkin kasvaa. Toisaalta petojen määrän kasvu hidastaa saalispopulaation kasvua ja lopulta kääntää saaliin määrän laskuun aiheuttaen ennen pitkää myös petopopulaation pienenemisen. Analysoidaan tätä kilpajuoksua tarkemmin. Olkoon \(x(t)\) saaliseläinten lukumäärää ja \(y(t)\) petojen lukumäärää. Tarkastellaan ensin kahta ääritapausta 1 ja 2 ja sitten yleistä tapausta 3.
Jos petoja ei ole (\(y=0\)), niin saalispopulaatio kasvaa eksponentiaalisesti, kuten
\[x'=ax,\qquad a>0.\](katso esimerkki 3.4.4 populaation koosta).
Jos saalista ei ole (\(x=0\)), niin petopopulaatio vähenee eksponentiaalisesti, kuten
\[y'=-by, \qquad b>0.\]Jos \(x,y>0\), niin kohdassa 1 petojen määrän kasvaminen vähentää saalispopulaation kasvunopeutta \(x'\). Oletetaan, että vähennys kasvunopeuteen on suoraan verrannollinen petojen ja saaliseläinten kohtaamistaajuuteen, ja oletetaan edelleen, että kohtaamistaajuus on suoraan verrannollinen tuloon \(xy\). Eli jos esimerkiksi petojen määrä kaksinkertaistuu, niin kohtaamistaajuus myös kaksinkertaistuu, tai jos esimerkiksi saaliin määrä puolittuu, niin kohtaamistaajuuskin puolittuu. Niinpä päädytään yhtälöön
\[x'=ax-pxy\qquad a,p>0.\]Vastaavasti kohdassa 2 saaliin määrän lisääntyminen kasvattaa petopopulaation kasvunopeutta \(y'\) suoraan verrannollisesti kohtaamistaajuuteen. Niinpä
\[y'=-by+qxy\qquad b,q>0.\]Nämä kaksi yhtälöä muodostavat nyt (yksinkertaistetun) Lotka-Volterran mallin peto-saalis- järjestelmästä.
Esimerkki 4.4.9
Olkoon nummella hetkellä \(t=0\) (kuukausina) \(70\) kania ja \(40\) kettua. Olkoon ajan hetkellä \(t\) kanien lukumäärää \(x(t)\) ja kettujen lukumäärää \(y(t)\). Oletetaan, että lukumäärät noudattavat mallia
Ratkaistaan differentiaaliyhtälöpari numeerisesti ja piirretään kuva ratkaisuista \(x(t)\) ja \(y(t)\) Matlabilla.
odefun=@(t,x)[0.2*x(1)-0.005*x(1)*x(2); -0.5*x(2)+0.01*x(1)*x(2)]
[t,x]=ode45(odefun,[0:0.1:60],[70,40]);
figure
plot(t,x(:,1),t,x(:,2),'--')
set(gca,'fontsize',14)
hleg1=legend('x(t) kanit', 'y(t) ketut')
set(hleg1,'Location','SouthEast')
xlabel('t')
ylabel('x,y')
axis image
Nähdään, että populaatioiden koot \(x(t)\) ja \(y(t)\) ovat jaksollisia ja että syklin pituus (kahden huipun välinen etäisyys) on noin \(20\)kk ja kettujen maksimimäärä saavutetaan noin \(5\)kk kanien maksimimäärän jälkeen.
Esimerkki 4.4.10
Tarkastellaan niin sanottua kahden säiliön ongelmaa. Säiliöissä 1 on \(100\) litraa ja säiliössä 2 on \(200\) litraa suolavettä. Olkoon \(x(t)\) suolan määrää säiliössä 1 ja \(y(t)\) suolan määrää (kg) säiliössä 2 ajan \(t\) (min) funktiona. Säiliöön 1 johdetaan suolatonta vettä \(20\) l/min ja säiliöstä 2 poistuu suolavettä \(20\) l/min. Lisäksi säiliöstä 1 johdetaan suolavettä säiliöön 2 \(30\) l/min ja säiliöstä 2 säiliöön 1 \(10\) l/min (eli säiliöissä 1 ja 2 on jatkuvasti \(100\) ja \(200\) litraa suolavettä). Oletetaan lisäksi, että kummassakin säiliössä suola on sekoittamisen ansiosta kunakin ajanhetkenä tasaisesti jakautunut.
- Kirjoita differentiaaliyhtälöpari funktioille \(x(t)\) ja \(y(t)\).
- Tarkastele tilannetta siinä tapauksessa, että alkuhetkellä (\(t=0\)) säiliössä 1 on \(200\) g suolaa ja säiliössä 2 on \(100\) g suolaa.
Säiliöön 1 tulee suolaa
\[\dfrac{y\text{ kg}}{200\text{ l}}\cdot10\ \dfrac{\text{l}}{\text{min}}=0{,}05y\ \frac{\text{kg}}{\text{min}}\]ja sieltä poistuu suolaa
\[\dfrac{x\text{ kg}}{100\text{ l}}\cdot30\ \dfrac{\text{l}}{\text{min}}=0{,}3x\ \frac{\text{kg}}{\text{min}}.\]Koska \(x'(t)\) on suolan määrän muutosnopeus (kg/min) säiliössä 1 hetkellä \(t\), niin saadaan yhtälö \(x'=-0{,}3x+0{,}05y\). Vastaavalla tavoin säiliötä 2 tarkastelemalla päätellään \(y'=0{,}3x-0{,}15y\).
On ratkaistava alkuarvotehtävä
\[\begin{split}\begin{cases} x'&=-0{,}3x+0{,}05y\\ y'&=0{,}3x-0{,}15y \end{cases} \qquad \begin{cases} x(0)=0{,}2\\ y(0)=0{,}1. \end{cases}\end{split}\]Ratkaistaan systeemi numeerisesti Matlabin
ode45
-funktiolla ja piirretään kuva.odefun=@(t,x)[-0.3*x(1)+0.05*x(2); 0.3*x(1)-0.15*x(2)]; [t,x]=ode45(odefun,[0 80],[0.2 0.1]); plot(t,x(:,1),t,x(:,2),'--') set(gca,'fontsize',14) legend('x(t)','y(t)') xlabel('t') ylabel('x,y')
Säiliössä 1 on aluksi 200g suolaa ja määrä vähenee monotonisesti kohti nollaa. Säiliön 2 suolapitoisuus aluksi nousee ja vähenee sitten kohti nollaa. Vaikuttaako ratkaisu järkevältä?
Yhtälöpari voidaan ratkaista myös symbolisesti
dsolve
-komennolla.s=dsolve('Dx=-0.3*x+0.05*y, Dy=0.3*x-0.15*y, x(0)=0.2, y(0)=0.1') s.x s.y