Flynnin luokittelu
From Wikipedia, the free encyclopedia
Remove ads
Flynnin luokittelu (engl. Flynn’s taxonomy) on Michael J. Flynnin vuonna 1966 esittämä luokittelu tietokonearkkitehtuureille.
Luokittelua on alun perin käytetty tietokoneen arkkitehtuuriin (useilla suorittimilla), mutta sitä käytetään toisinaan myös suoritintoteutuksen sisäiselle arkkitehtuurille.selvennä
Luokittelu
Luokittelu voidaan jakaa seuraavasti neljään luokkaan:[1][2]
- SISD (Single Instruction, Single Data)
- MISD (Multiple Instruction, Single Data)
- SIMD (Single Instruction, Multiple Data)
- MIMD (Multiple Instruction, Multiple Data)
Luokittelussa instruction viittaa käskyvirtaan ja data muuttujavirtaan.[3]
Käskyvirta ja muuttujavirta voivat olla samaa tai eri muistia, ks. muistiarkkitehtuurin toteutustavat.
Lisäluokat
Nvidia on ehdottanut SIMT (Single Instruction, Multiple Threads) luokittelua alkuperäisten neljän lisäksi.[4]
MIMD on ehdotettu jaettavaksi kahteen kategoriaan:
- SPMD (Single program, multiple data streams)[5]
- MPMD (Multiple programs, multiple data streams)
Remove ads
Luokkien määrittelyt
- SISD
- MISD
- SIMD
- MIMD
SISD
SISD on yksinkertaisin tapaus: yksi suoritin joka suorittaa yhden käskyn yhdelle muistille.
SISD-arkkitehtuurissa voi olla myös rinnakkaisuutta suorittimen liukuhihnan (pipeline) ja superskalaarisuus-ominaisuuksien muodossa.
MISD
MISD-mallissa datalle suoritetaan useita komentoja. Liukuhihna (pipeline) suorittimissa voidaan käsittää MISD-mallina.
Mallia voidaan käyttää myös vikasietoisissa tietokoneissa redundanttiseen käsittelyyn, jotta vikaantuneen yksikön toiminta ei häiritse.
Ainoa tunnettu MISD-mallia käyttävä tietokone on ollut Carnegie Mellon -yliopiston C.mmp.[3][6]
SIMD
SIMD-mallissa sama komento suoritetaan useammalle arvolle yhtäaikaisesti. Tämä yleinen rinnakkaissuorituksen muoto rinnakkaislaskennassa ja vektorisuorittimissa.
SIMD-mallissa kyse on data-tason rinnakkaisuudesta (parallel), mutta ei yhtäaikaisuudesta (concurrency): käsiteltävänä on vain yksi komento kerrallaan.
SIMD-malli on useissa suorittimissa toteutettu vektorisuoritin-tyylisinä käskylaajennuksina. Cell BE toteuttaa useamman SIMD-suoritukseen tarkoitetun yksikön samaan suorittimeen. SIMD-operaatioiden hyödyntäminen ohjelmoinnissa vaatii lähestymisen ohjelmointiin, joka tähtää rinnakkaisuuden hyödyntämiseen.[7]
MIMD
MIMD-mallissa suoritetaan useita komentoja useille datapisteille rinnakkain.
MIMD-mallissa on kyse sekä rinnakkaisuudesta (parallel) että yhtäaikaisuudesta (concurrency), koska sekä komentoja että datapisteitä on useita käytössä yhtä aikaa eri vaiheissa. MIMD-mallin rinnakkaisohjelmointi on eri lähestymistapoja.[8]
Malli on tyypillisesti käytössä useita suorittimia ja suoritinytimiä sisältävissä moniprosessointikoneissa.[9] Kaikkien moniprosessointikoneiden voi sanoa käyttävän MIMD-mallia.[3]
Remove ads
Katso myös
Lähteet
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads