www.wikidata.uk-ua.nina.az
ALGOL abo ALGOL skorochennya vid angl ALGOrithmic Language algoritmichna mova simejstvo imperativnih mov programuvannya pershu versiyu rozrobleno v seredini 1950 h i stala de fakto standartnoyu movoyu publikaciyi algoritmiv na nastupni 30 rokiv ALGOL bulo rozrobleno dlya podolannya deyakih problem yaki buli pritamanni dlya Fortrana ta dala poshtovh dlya rozvitku bagatoh inshih mov sered nih Paskal U ALGOL zastosovuvalis operatorni duzhki ce persha mova yaka dlya yih rozmezhuvannya zastosuvala paru begin ta end Fragmenti ALGOL podibnogo sintaksisu dosi vikoristovuyutsya u deyakih notaciyah algoritmiv Pidgin Algol ALGOLParadigma procedurna imperativna strukturnaData poyavi 1958Tvorci Rozroblena komitetom inzhenerivPid vplivom vid FortranVplinula na Paskal Ada ALGOL u VikishovishiOficijni versiyi ALGOLu nazivayut za rokami koli voni vpershe buli opublikovani Isnuye tri veliki oficijni gilki simejstva ALGOL ALGOL 58 spochatku vidomij yak IAL angl International Algorithmic Language Mizhnarodna Algoritmichna Mova ALGOL 60 versiya 1963 roku ALGOL 68 versiya 1973 roku Niklaus Virt vzyav ALGOL 60 za osnovu dlya svogo ALGOL V pered tim yak perejti do rozrobki Paskalyu ALGOL V mav bi stati nastupnim pokolinnyam ALGOL ale komitet ALGOL 68 viddav perevagu bilsh skladnomu j rozvinenomu dizajnu pered sproshenim i prozorishim ALGOL 60 Zmist 1 Istoriya 1 1 Oficijni specifikaciyi ALGOL 60 ta jogo realizaciyi 2 Vlastivosti 3 Priklad kodu ALGOL 60 4 Vivedennya Hello world u riznih versiyah 4 1 ALGOL 58 IAL 4 2 Simejstvo ALGOL 60 4 3 ALGOL 68 5 Zarezervovani slova ta zaboroneni identifikatori ALGOL 60 6 Dzherela 7 PosilannyaIstoriya RedaguvatiALGOL bulo rozrobleno spilnim komitetom yevropejskih ta amerikanskih vchenih na zustrichi 1958 roku u Shvejcarskomu Federalnomu Instituti Tehnologij Komitet viznachiv tri rizni sintaksisi osnovnij publikaciyi ta realizaciyi Rizni sintaksisi dozvolyali vikoristovuvati rizni klyuchovi slova ta rozdilovi znaki komi ta defisi dlya riznih mov ALGOL perevazhno vikoristovuvavsya dlya naukovih doslidzhen u SShA ta Yevropi Jogo shiroke zastosuvannya bulo uskladnene vidsutnistyu v jogo specifikaciyi standartnogo rishennya dlya vvodu vivodu danih ta vidsutnistyu interesu z boku velikih postachalnikiv komp yuteriv ALGOL 60 popri te stav standartom publikaciyi algoritmiv ta zrobiv vagomij vnesok u rozvitok podalshih mov programuvannya Dzhon Bekus rozrobiv notaciyu Bekusa metod opisu mov programuvannya priv yazanij do ALGOLu 58 Cej metod bulo pereglyanuto j rozshireno Piterom Naurom dlya ALGOLu 60 Za propoziciyeyu Donalda Knuta jogo nazvu bulo zmineno na notaciyu Bekusa Naura nbsp Yak redaktor pershogo byuletenya ALGOLu ya brav uchast u mizhnarodnomu obgovorenni movi ta buv obranij chlenom Yevropejskoyi grupi rozrobnikiv u listopadi 1959 Na cij posadi ya buv redaktorom zvitu pro ALGOL 60 yakij stav rezultatom zustrichi u Parizhi u sichni 1960 roku nbsp Piter NaurNa zustrichi v Parizhi z 1 po 16 sichnya takozh buli prisutni Z Yevropi Fridrih Bauer Piter Naur Gajnc Rutishauzer Klaus Zamelson Bernard Vakui Adrian van Vijngaarden ta Majkl Vudzher Zi Spoluchenih Shtativ Dzhon Bekus Dzhuli Grin Charlz Katc Dzhon Makkarti Alan Perlis Dzhosef Genri Vegstejn nbsp Zustrich bula visnazhliva dovga ta vesela Htos nervuvav koli jogo garni ideyi vidkidalis razom z poganimi ideyami inshih Ale starannist panuvala ves period roboti Robota trinadcyati bula chudovoyu nbsp Alan PerlisI Dzhon Bekus i Piter Naur buli takozh v komiteti yakij rozrobiv ALGOL 60 yak i Velli Fercig yakij piznishe stvoriv movu programuvannya Logo ALGOL 60 nadihnuv rozvitok bagatoh mov yaki jogo nasliduvali visliv Toni Goara pro nogo zgodom stav aforizmom nbsp Ce mova yaka nastilki viperedila chas sho stala ne tilki rozvitkom yiyi poperednikiv ale j majzhe vsih yiyi nastupnikiv nbsp Cej visliv inkoli pripisuyut Edsgeru Dejkstri yakij takozh brav uchast u rozrobci pershogo kompilyatora dlya ALGOL 60 dzherelo Oficijni specifikaciyi ALGOL 60 ta jogo realizaciyi Redaguvati Isnuvalo blizko 70 polipshen rozshiren rozgaluzhen ta pidmov ALGOL 60 1 Veliki sistemi Byurro stekovi mashini rozrobleni dlya programuvannya na rozshirenomu varianti ALGOL 60 vidomomu yak Elliot ALGOL yihnya operacijna sistema MCP bula napisana na Elliot ALGOL she 1961 roku Korporaciya Unisys dosi koli prodaye mashini z ciyeyu nazvoyu yaki vikoristovuyut MCP ta pidtrimuyut nabir kompilyatoriv Elliot ALGOL Vlastivosti RedaguvatiOficijna specifikaciya ALGOL 60 ne mistila mozhlivostej vvodu vivodu danih rizni realizaciyi kompilyatora viznachali svoyi vlasni metodi yaki ridko buli sumisni odin z odnim Na vidminu ALGOL 68 mav rozshirenu biblioteku transput dlya vvodu vivodu danih ALGOL 60 dozvolyav dva metodi peredachi parametriv za znachennyam ta za nazvoyu Peredacha za nazvoyu mala pevni obmezhennya na vidminu vid peredachi za posilannyam sho robilo yiyi nebazhanoyu dlya programuvannya na imperativnih movah Napriklad v ALGOL 60 nemozhlivo zrobiti proceduru yaka obminyuye znachennya dvoh parametriv yaksho faktichnimi parametrami mozhut buti cili zminni ta masiv cilih Priklad kodu ALGOL 60 Redaguvati Te yak vidilenij tekst maye buti napisanij zalezhit vid konkretnoyi realizaciyi napriklad INTEGER vklyuchno z lapkami zamist integer procedure Absmax a Size n m Result y Subscripts i k value n m array a integer n m i k real y comment Najbilshij po modulyu element matrici a rozmirom n na m zanositsya do y a jogo indeksi do i ta k begin integer p q y 0 i k 1 for p 1 step 1 until n do for q 1 step 1 until m do if abs a p q gt y then begin y abs a p q i p k q end end Absmax Ce priklad togo yak realizuvati tablicyu vikoristovuyuchi Elliott 803 ALGOL FLOATING POINT ALGOL TEST BEGIN REAL A B C D READ D FOR A 0 0 STEP D UNTIL 6 3 DO BEGIN PRINT PUNCH 3 L B SIN A C COS A PRINT PUNCH 3 SAMELINE ALIGNED 1 6 A B C END END PUNCH 3 napravlyaye vivid na teletajp a ne na perfokartu SAMELINE zapobigaye povernennyu karetki ta zabezpechuye normalne vivedennya ryadka argumentiv ALIGNED 1 6 formatovanij vivid 1 cifri do i 6 pislya komi Vivedennya Hello world u riznih versiyah RedaguvatiVariativnist ta nemozhlivist perenesennya program z odniyeyi realizaciyi ALGOL na inshu legko demonstruyetsya klasichnoyu programoyu hello world ALGOL 58 IAL Redaguvati ALGOL 58 ne mav metodiv vvodu vivodu Simejstvo ALGOL 60 Redaguvati Oskilki ALGOL 60 ne mav standartnizovanih metodiv vvodu vivodu informaciyi na ALGOLi ne isnuye programi hello world yaku mozhna bulo b perenositi Nastupna programa mozhe buti skompilovana ta vikonana na realizaciyi ALGOL na mejnfrejmi Unisys A Series i ye sproshennyam kodu vzyatogo z cogo sajtu angl BEGIN FILE F KIND REMOTE EBCDIC ARRAY E 0 11 REPLACE E BY HELLO WORLD WRITE F E END Alternativnij priklad iz zastosuvannyam Elliott Algol I O V Elliott Algol dlya poznachennya pochatku ta kincya simvolnih konstant vzhivayut rizni simvoli ta program HiFolks begin print Hello world end Nastupna versiya dlya Elliott 803 Algol A104 Standart Elliott 803 vikoristovuvav perfokarti z p yatma otvorami takim chinom u kodi bulo vsogo 25 32 simvoli V nomu buli lishe literi verhnogo registru majzhe ne bulo rozdilovih znakiv tomu anglijskij znak funta zastosovuvavsya dlya poznachennya pochatku ryadka a znak pitannya dlya poznachennya kincya Osoblivi poslidovnosti bralis u podvijni lapki napriklad L oznachalo novij ryadok na teletajpi HIFOLKS BEGIN PRINT HELLO WORLD L END Versiya vvodu vivodu ICL 1900 Algol dozvolyala vvedennya informaciyi z paperovoyi strichki chi perfokart Povnij rezhim paperovoyi strichki dozvolyav literi nizhnogo registru Vivid zdijsyuvavsya na printer BEGIN WRITE TEXT HELLO WORLD END ALGOL 68 Redaguvati Algol 68 Report bulo perekladeno rosijskoyu nimeckoyu francuzkoyu ta bolgarskoyu movami U movi ALGOL 68 metodi vvodu vivodu buli uzagalneno nazvani Transput begin print Hello world newline end Abo vikorstovuyuchi specialnij kanal obminu begin putf stand out gl Hello world end Takozh ALGOL 68 dozvolyav programuvati iz vikoristannyam shirshih naboriv simvoliv napriklad kirilichnogo alfavitu na BESM 4 begin print Zdravstvuj mir newline end Primitka radyanskij standart 1964 roku GOST 10859 dozvolyav koduvannya 4 5 6 ta 7 bitnih simvoliv na ALGOL U publikaciyah ALGOL 68 zarezervovani slova buli v nizhnomu registri ale drukuvalis napivzhirnim shriftom chi pidkresleno Dlya polegshennya programuvannya 7 bitnih komp yuteriv buli oficijni metodi vidilyati zarezervovani slova napriklad vikoristovuyuchi verhnij registr BEGIN print Hello world newline END Inodi programisti buli zmusheni povnistyu DUMATI U VERHNOMU REGISTRI na komp yuterah yaki mali tilki 6 bitni simvoli napriklad superkomp yuteri CDC V comu vipadku vishenavedenij kod mav pisatisya tak BEGIN PRINT HELLO WORLD NEWLINE END Zarezervovani slova ta zaboroneni identifikatori ALGOL 60 RedaguvatiIsnuye 35 zarezervovanih sliv u movi Velikoyi sistemi Byuro ALPHA ARRAY BEGIN BOOLEAN COMMENT CONTINUE DIRECT DO DOUBLE ELSE END EVENT FALSE FILE FOR FORMAT GO IF INTEGER LABEL LIST LONG OWN POINTER PROCEDURE REAL STEP SWITCH TASK THEN TRUE UNTIL VALUE WHILE ZIP Ye 71 zaboronenij identifikator ACCEPT AND ATTACH BY CALL CASE CAUSE CLOSE DEALLOCATE DEFINE DETACH DISABLE DISPLAY DIV DUMP ENABLE EQL EQV EXCHANGE EXTERNAL FILL FORWARD GEQ GTR IMP IN INTERRUPT IS LB LEQ LIBERATE LINE LOCK LSS MERGE MOD MONITOR MUX NEQ NO NOT ON OPEN OR OUT PICTURE PROCESS PROCURE PROGRAMDUMP RB READ RELEASE REPLACE RESET RESIZE REWIND RUN SCAN SEEK SET SKIP SORT SPACE SWAP THRU TIMES TO WAIT WHEN WITH WRITE a takozh nazvi vsih vnutrishnih funkcij Dzherela Redaguvati Arhivovana kopiya Arhiv originalu za 27 veresnya 2011 Procitovano 8 listopada 2007 Posilannya RedaguvatiAlgol Arhivovano 17 lyutogo 2022 u Wayback Machine VUE Pereglyanutij zvit pro algoritmichnu movu ALGOL 60 Arhivovano 25 chervnya 2007 u Wayback Machine Piter Naur BNF sintaksisu ALGOL 60 Starij odyag Imperatora promova Goara na vruchenni Nagorodi Tyuringa u 1980 roci yaka rozglyadaye istoriyu ta rozvitok ALGOL MARST Arhivovano 23 zhovtnya 2007 u Wayback Machine vilnij Algol to C translyator Retrokomp yuternij Muzej Arhivovano 3 kvitnya 2020 u Wayback Machine Erika Rejmonda sered inshogo mistit posilannya na NASE Algol 60 interpretator napisanij na C Otrimano z https uk wikipedia org w index php title ALGOL amp oldid 37834114