Gaussin algoritmi

Wikipediasta
(Ohjattu sivulta Johtava alkio)
Siirry navigaatioon Siirry hakuun

Gaussin algoritmi eli Gaussin eliminointimenetelmä on ensisijaisesti lineaarialgebran menetelmä, algoritmi, jolla voidaan ratkaista lineaarinen yhtälöryhmä matriisimuodossa. Se tuottaa alkuperäisen matriisin kanssa riviekvivalentin matriisin, josta yhtälöryhmän ratkaisut on mahdollista lukea. Gaussin eliminointimenetelmä toimii kaikissa mahdollisissa tapauksissa, joissa yhtälöryhmällä on 1) ääretön määrä ratkaisuja 2) yksi ratkaisu 3) ei ratkaisua.

Menetelmästä on olemassa myös laajennus, joka tunnetaan Gaussin-Jordanin eliminointimenetelmänä. Tässä menetelmässä matriisin porrasmuotoon saattamisen jälkeen sen työstämistä jatketaan kunnes matriisin tuntemattomia edustava vasen puoli muistuttaa yksikkömatriisia.

Gaussin eliminointimenetelmä on nimetty matemaatikko Carl Friedrich Gaussin mukaan, mutta hän ei ole kehittänyt sitä. Ensimmäiset maininnat menetelmästä ovat jo vuosilta 150 eaa. - 179 kiinankielisessä kirjassa Jiuzhang suanshu, Yhdeksän lukua matemaattisesta taiteesta. Nykymuotoonsa menetelmän kehitti Isaac Newton, jonka muistiinpanot mm. yhtälöistä julkaistiin vuonna 1707 teoksessa Arithmetica Universalis. Lopulta, vasta 1950-luvulla menetelmä sai nykyisen nimensä aiheen historiaan liittyvien väärinkäsitysten myötä.

Algoritmin tausta

[muokkaa | muokkaa wikitekstiä]

Gaussin eliminointimenetelmä perustuu lineaarisen yhtälöryhmän seuraaviin ominaisuuksiin:

  • Yhtälöryhmän kahden yhtälön paikkaa voidaan vaihtaa
  • Yhtälöryhmän yhtälö voidaan kertoa puolittain nollasta poikkeavalla vakiolla
  • Yhtälöryhmän yhtälö voidaan lisätä yhtälöryhmän toiseen yhtälöön, kerrottuna nollasta poikkeavalla vakiolla

Suoritettaessa mikä tahansa edellä olevista operaatioista muodostetaan uusi, alkuperäisen kanssa ekvivalentti yhtälöryhmä. Toisin sanoen, alkuperäisen ja uuden yhtälöryhmän ratkaisujoukot ovat täsmälleen samat.

Ratkaistaessa yhtälöryhmää, operoidaan itse asiassa ainoastaan tuntemattomien kertoimilla ja vakioilla. Itse tuntemattomat ovat "paikanpitäjän" roolissa. Näin ollen, mistä tahansa yhtälöryhmästä voidaan muodostaa matriisi seuraavasti:

Esimerkki matriisiesityksestä

[muokkaa | muokkaa wikitekstiä]

Yhtälöryhmää

vastaa matriisiesitys

jossa siis kolmessa vasemmanpuoleisimmassa sarakkeessa tuntemattomien kertoimet, rivin vastatessa yhtä yhtälöä, ja oikeanpuoleisessa sarakkeessa vakiot yhtälöittäin.

Itse Gaussin eliminointimenetelmä toimii seuraavasti: Annettu matriisi voidaan aina asettaa porrasmuotoon yhtälöryhmien operaatioita vastaavien alkeisrivitoimitusten avulla. Alkeisrivitoimituksella tarkoitetaan sitä, että

  • Rivi kerrotaan jollain nollasta eroavalla vakiolla.
  • Rivi kerrotaan jollain nollasta eroavalla vakiolla ja lisätään se johonkin toiseen riviin.
  • Kaksi matriisin riviä vaihdetaan keskenään.

Alkeisrivitoimituksia yksi kerrallaan, äärellisen määrän suorittamalla päästään alkuperäisen matriisin kanssa riviekvivalenttiin, porrasmuotoiseen matriisiin.

Matriisi on porrasmuodossa, mikäli seuraavat ehdot ovat voimassa:

  • Nollarivit (jos niitä on) ovat alimpina.
  • Jokaisen nollasta eroavan rivin vasemmalta lukien ensimmäinen nollasta eroava alkio, ko. rivin johtava alkio = 1.
  • Alemman rivin johtavan alkion sarake sijaitsee aina ylemmän rivin johtavan alkion sarakkeen oikealla puolella.

Suoritetaan Gaussin algoritmi ja päästään matriisiin:

joka on siis haluttu, porrasmuotoinen matriisi.

Tästä saadaan takaisinsijoituksella:

Saatiin siis yksikäsitteinen ratkaisu.

Gaussin algoritmi tietokoneelle

[muokkaa | muokkaa wikitekstiä]
i=1
j=1
while (i ≤ m and j ≤ n) do
  # Etsi johtava alkio sarakkeelta j, alkaen riviltä i:
  max_val = A[i,j]
  max_ind = i
  for k=i+1 to m do
    val = A[k,j]
    if abs(val) > abs(max_val) then
      max_val = val
      max_ind = k
    end_if
  end_for
  if max_val ≠ 0 then
    vaihda rivit i ja max_ind
    jaa rivi i luvulla max_val
    for u = 1 to m do
       if u ≠ i then
          lisää -A[u,j] * rivi i riviin u
       end_if
    end_for
    i = i + 1
  end_if
  j = j + 1
end_while

Gaussin eliminointimenetelmän sovelluksia

[muokkaa | muokkaa wikitekstiä]

Kaikki lineaariseksi yhtälöryhmäksi puettavat ongelmat

[muokkaa | muokkaa wikitekstiä]
  • Esim. sähköverkot, liikennevirrat, tuotanto ja kulutus, väestönkasvu.

Lineaarialgebran lukuisat ongelmat

[muokkaa | muokkaa wikitekstiä]

Mahdollisia ongelmia

[muokkaa | muokkaa wikitekstiä]

Virheherkkyys

[muokkaa | muokkaa wikitekstiä]

Yhtälöryhmien lähtöaineisto oikeassa elämässä ei läheskään aina ole absoluuttisen täsmällistä. Jos kerroinmatriisi on lähellä singulaarista, pienetkin epätarkkuudet saattavat muuttaa ratkaisua olennaisesti.

Jakajiksi voi tulla hyvin suuria/pieniä lukuja, mikä voi muuttaa kertoimien suuruusluokkaa paljonkin.

Yli- ja alivuodot

[muokkaa | muokkaa wikitekstiä]

Mahdolliset liian suuret/pienet luvut tietokoneen käsiteltäväksi. Ongelma yleensä vältettävissä oikealla skaalauksella.