Základní válka - Core War

Základní válka
Snímek obrazovky Core War
Hra Core War běžící pod simulátorem pMARS
VývojářiD. G. Jones & A. K. Dewdney
UvolněníBřezen 1984
ŽánrProgramovací hra

Základní válka je 1984 programovací hra vytvořili D. G. Jones a A. K. Dewdney ve kterém dva nebo více bitevních programů (zvaných „válečníci“) soutěží o kontrolu a virtuální počítač. Tyto bojové programy jsou psány abstraktně montážní jazyk volala Redcode.

Hratelnost

Na začátku hry je každý bitevní program načten do paměti na náhodném místě, po kterém každý program postupně provede jednu instrukci. Cílem hry je způsobit ukončení procesů nepřátelských programů (k čemuž dojde, pokud provedou neplatnou instrukci), přičemž vítězný program zůstane ve výhradním vlastnictví stroje.

Nejdříve publikovaná verze Redcode definovala pouze osm pokynů. Standard ICWS-86 zvýšil počet na 10, zatímco standard ICWS-88 jej zvýšil na 11. Aktuálně používaný standard ICWS-94 má 16 pokynů. Redcode však podporuje řadu různých režimy adresování a (z ICWS-94) modifikátory instrukcí, které zvyšují skutečný počet možných operací na 7168. Standard Redcode ponechává základní instrukční reprezentaci nedefinovanou a neposkytuje programům žádný přístup. Aritmetické operace lze provádět na dvou adresních polích obsažených v každé instrukci, ale jediné operace podporované na samotných kódech instrukcí jsou kopírování a porovnávání pro rovnost.

Konstantní délka a čas výuky
Každá instrukce Redcode zabírá přesně jeden paměťový slot a její provedení trvá přesně jeden cyklus. Rychlost, jakou proces provádí pokyny, však závisí na počtu dalších procesů ve frontě, protože doba zpracování je sdílena rovnoměrně.
Kruhová paměť
Paměť je adresována v jednotkách jedné instrukce. Paměťový prostor (nebo jádro) je konečné velikosti, ale pouze relativní adresování se používá, tj. adresa 0 vždy odkazuje na aktuálně prováděnou instrukci, adresu 1 podle pokynů po něm atd. Maximální hodnota adresy je nastavena na hodnotu rovnou jedné menší než je počet paměťových míst a v případě potřeby se zalomí. Výsledkem je vzájemná korespondence mezi adresami a paměťovými místy, ale pro program Redcode není možné určit absolutní adresu. Proces, který nenarazí na žádné neplatné nebo skokové instrukce, bude pokračovat v nekonečném provádění následných instrukcí a nakonec se vrátí k instrukci, kde začala.
Nízkoúrovňové multiprocesování
Místo jednoho ukazatel instrukce simulátor Redcode má procesní fronta pro každý program obsahující proměnný počet ukazatelů instrukcí, kterými simulátor cykluje. Každý program začíná pouze jedním procesem, ale do fronty lze přidávat nové procesy pomocí SPL návod. Proces umírá, když provede a DAT instrukce nebo provede dělení nulou. Program je považován za mrtvý, pokud mu nezbývají žádné další procesy.
Žádný externí přístup
Redcode a architektura MARS neposkytují žádné vstupní ani výstupní funkce. Simulátor je uzavřený systém, přičemž jediným vstupem jsou počáteční hodnoty paměti a procesní fronty a jediným výstupem je výsledek bitvy, tj. Které programy měly přežívající procesy. Simulátor samozřejmě může stále umožňovat externí kontrolu a úpravy paměti, když je simulace spuštěna.

Verze Redcode

Existuje řada verzí Redcode. Nejstarší verze popsaná uživatelem A. K. Dewdney[1] se v mnoha ohledech liší od pozdějších standardů zavedených Mezinárodní základní válečnou společností a lze jej považovat za jiný, byť související jazyk. Forma Redcode, která se dnes nejčastěji používá, je založena na návrhu standardu předloženého ICWS v roce 1994, který nebyl nikdy formálně přijat, protože ICWS v té době účinně zanikl. Vývoj Redcode však pokračoval neformálním způsobem, zejména prostřednictvím online fór, jako je rec.games.corewar[2] diskusní skupina.

Strategie

Válečníci jsou obvykle rozděleni do několika širokých kategorií, ačkoli skuteční válečníci mohou často kombinovat chování dvou nebo více z nich. Tři společné strategie (replikátor, skener a bombardér) jsou také známé jako papír, nůžky a kámen, protože jejich výkony se navzájem blíží jejich jmenovcům ve známé hře na hřišti.[3]

Papír (nebo replikátor)
Replikátor vytváří opakované kopie sebe sama a spouští je paralelně, případně vyplňuje celé jádro kopiemi svého kódu. Replikátory je těžké zabít, ale často mají potíže se zabitím svých protivníků. Replikátoři proto mají tendenci zaznamenávat mnoho vazeb, zejména proti ostatním replikátorům.
A hedvábí je speciální typ velmi rychlého replikátoru, pojmenovaný podle Silk Warrior[4] autor: Juha Pohjalainen. Většina moderních replikátorů je tohoto typu. Hedvábné replikátory používají paralelní provádění ke kopírování celého svého kódu pomocí jedné instrukce a zahájení provádění kopie před jejím dokončením.[5]
Nůžky (nebo skener)
Skener je navržen tak, aby porazil replikátory. Skener neútočí slepě, ale snaží se najít svého nepřítele před zahájením cíleného útoku. Díky tomu je efektivnější proti těžce zabíjejícím protivníkům, jako jsou replikátoři, ale také je zranitelný vůči návnadám. Skener obvykle bombarduje paměť SPL 0 instrukce. To způsobí, že nepřítel vytvoří obrovské množství procesů, které nedělají nic jiného, ​​než vytvoří více procesů a zpomalí užitečné procesy. Když se nepřítel zpomalí natolik, že není schopen udělat nic užitečného, ​​paměť je bombardována DAT instrukce. Skenery jsou také obecně složitější, a proto větší a křehčí než jiné typy válečníků.[6]
A jedna rána je velmi jednoduchý skener, který skenuje pouze jádro, dokud nenajde první cíl, a poté trvale přepne na strategii útoku, obvykle vymazanou z jádra. Myrmidon[7] Roy van Rijn je příkladem onehot.
Kámen (nebo bombardér)
Atentátník v pravidelných intervalech slepě kopíruje „bombu“ v naději, že zasáhne nepřítele. Bomba je často a DAT instrukce, i když lze použít i jiné instrukce, nebo dokonce bomby pro více instrukcí. Bombardér může být malý a rychlý a získává další výhodu nad skenováním protivníků, protože bomby slouží také jako pohodlné rozptýlení. Bombardéry jsou často kombinovány s imp spirálami, aby získaly větší odolnost proti replikátorům.
Upír (nebo lovec jámy)
Upír se snaží, aby procesy jeho oponenta skočily do části vlastního kódu zvaného „jáma“. Upíři mohou být založeni na bombardérech nebo skenerech. Hlavní slabinou upírů je to, že na ně lze snadno zaútočit nepřímo, protože musí nezbytně rozptýlit ukazatele na svůj kód po celém jádru. Jejich útoky jsou také pomalé, protože procesům trvá další kolo, než se dostanou do jámy. myVamp[8] Paulsson je příkladem upíra.
Imp
Skřeti jsou pojmenováni podle vůbec prvního zveřejněného válečníka, Imp[9] podle A. K. Dewdney, triviální mobilní instruktor s jednou instrukcí, který neustále kopíruje svou jedinou instrukci těsně před svou ukazatel instrukce. Imps je těžké zabít, ale téměř k ničemu pro přestupek. Jejich použití spočívá ve skutečnosti, že se mohou snadno rozmnožit ve velkém počtu a mohou přežít, i když je zbytek válečníka zabit.
An imp prsten (nebo imp spirála) se skládá z impů rozmístěných ve stejných intervalech kolem jádra a prováděných střídavě. Impové v každém rameni prstenu / spirály kopírují své pokyny do dalšího ramene, kde je okamžitě znovu provedeno. Prsteny a spirály je ještě těžší zabít než obyčejné skřety a dokonce mají (malou) šanci zabít válečníky, kteří proti nim nejsou chráněni. Počet ramen v prstenci nebo spirále musí být relativně prime s velikostí jádra.
Quickscanner (nebo q-scan)
Quickscanner se pokouší včas zachytit svého protivníka pomocí velmi rychlé rozvinuté smyčky skenování. Quickscanning je strategie rané hry a jako záloha vždy vyžaduje nějakou jinou strategii. Přidání komponenty rychlého skenování do bojovníka může zlepšit jeho skóre u dlouhých bojovníků, jako jsou jiné rychlé skenery. Rozvinutý sken však může cílit pouze na omezený počet míst a je nepravděpodobné, že by chytil malého protivníka.
Jádro jasné
Jádro jasné postupně přepisuje každou instrukci v jádru, někdy dokonce včetně sebe. Vymazání jádra nejsou příliš časté jako samostatní válečníci, ale bombardéry a skenery je často používají jako strategii na konci hry.

Základní válka Programování

S pochopením Základní válka strategií může programátor vytvořit válečníka, aby dosáhl určitých cílů. Revoluční myšlenky přicházejí jednou za čas; Většinou však programátoři zakládají své programy na již publikovaných válečnících. Pomocí optimalizátorů, jako je OptiMax nebo nástrojů pro optimalizaci základních kroků, lze vytvořit efektivnějšího válečníka.

Válečníci mohou být také generováni genetické algoritmy nebo genetické programování. Programy, které integrují tuto evoluční techniku, jsou známé jako vývojáři. Několik vývojářů bylo představeno Základní válka komunity a mají tendenci soustředit se na generování válečníků pro menší základní nastavení. Nejnovější evolver s významným úspěchem byl μGP[10] který produkoval některé z nejúspěšnějších nano a drobných válečníků. Evoluční strategie přesto musí prokázat svou účinnost na větších základních nastaveních.[11]

Rozvoj

Základní válka byl inspirován a samoreplikující se zavolal program Liána a následný program s názvem Reaper, který zničil kopie Creepera.[12] Creeper vytvořil Bob Thomas v BBN.[13] Dewdney si nebyl vědom původu Creepera a Reapera a odkazuje na ně jako na pověst pocházející z Darwine a experimenty s červy z Shoch a Hupp. 1984 Scientific American článek na Základní válka[12] nicméně cituje hru Darwine, kterou hraje Victor A. Vyssotsky, Robert Morris, a Douglas McIlroy na Bell Labs v roce 1961. Slovo „Core“ v názvu pochází paměť s magnetickým jádrem, zastaralý paměť s náhodným přístupem technologie.

První popis jazyka Redcode byl publikován v březnu 1984 v Hlavní válečné směrnice D. G. Jones a A. K. Dewdney.[1] Tato hra byla veřejnosti představena v květnu 1984 v článku, který napsal Dewdney v Scientific American. Dewdney se vrátil Základní válka ve sloupci „Počítačové rekreace“ v březnu 1985,[14] a znovu v lednu 1987.[15]

International Core Wars Society (ICWS) byla založena v roce 1985, rok po původním článku Dewdney. ICWS zveřejnila nové standardy pro jazyk Redcode v letech 1986 a 1988 a v roce 1994 navrhla aktualizaci, která nikdy nebyla formálně stanovena jako nový standard.[16] Návrh z roku 1994 byl nicméně obecně přijat a rozšířen a tvoří základ dohody de facto dnes standard pro Redcode. Režii ICWS provedli Mark Clarkson (1985–1987), William R. Buckley (1987–1992) a Jon Newman (1992–); v současné době je ICWS zaniklý.[17]

Redcode

 0000:  PŘIDAT.AB  #   4, $   3 0001:  MOV.F   $   2, @   2 0002:  JMP.B   $  -2, $   0 0003:  DAT.F   #   0, #   0
Sestavený Redcode ve stylu ICWS-94

Redcode je programovací jazyk použito v Základní válka. Provádí jej a virtuální stroj známý jako Simulátor Redcode paměti Arraynebo MARS. Návrh Redcode je volně založený na skutečném CISC montážní jazyky z počátku 80. let, ale obsahuje několik funkcí, které se ve skutečných počítačových systémech obvykle nenacházejí.

Redcode i prostředí MARS jsou navrženy tak, aby poskytovaly jednoduchou a abstraktní platformu bez složitosti skutečných počítačů a procesorů. Ačkoli se Redcode má podobat běžnému montážnímu jazyku CISC, liší se v mnoha ohledech od „skutečného“ sestavení.

Implementace

Vývoj implementací hry pokračoval v průběhu let několika autory. K dispozici je několik verzí hry,[18] přeneseno pro několik platforem. Například pMARS který je open source software s zdrojový kód na Sourceforge,[19] nebo SDL na základě SDL pMARS pro Windows.[20] Nedávno byl vytvořen plně webový simulátor https://www.corewar.io/ odstranění nutnosti stahovat jakékoli nástroje specifické pro platformu.

Běžná implementace pMars byla stažena 30 000krát mezi lety 2000 a 2017 z Sourceforge.[21]

Reference

  1. ^ A b Jones, D. G .; Dewdney, A.K. (Březen 1984). „Hlavní válečné směrnice“. Citováno 2013-03-11.
  2. ^ „rec.games.corewar ve Skupinách Google“. Citováno 2013-03-11.
  3. ^ Wangsaw, Mintardjo. „Intro to Art in '88: Paper - Stone - Scissors Trilogy“. Citováno 2013-03-11.
  4. ^ Pohjalainen, Jippo. „Silk Warrior 1.3“. Citováno 2013-03-11.
  5. ^ Pohjalainen, Jippo (duben 1995). „Replikátoři? - zdroj Phoenix & TimeScape“. Citováno 2013-03-11.
  6. ^ Metcalf, John (duben 2004). „Anatomie skeneru, základní úvod“. Citováno 2013-03-11.
  7. ^ van Rijn, Roy. "Myrmidon". Citováno 2013-03-11.
  8. ^ Paulsson, Magnus. „myVamp v3.7“. Citováno 2013-03-11.
  9. ^ Dewdney, A. K. "Imp". Citováno 2013-03-11.
  10. ^ Squillero, Giovanni. „μGP (MicroGP v2)“. Citováno 2018-09-10.
  11. ^ Vowk, Barkley; Počkejte, Alexander; Schmidt, Christian. „Evoluční přístup generuje lidské konkurenční Corewarové programy“ (PDF). Citováno 2013-03-11.
  12. ^ A b Dewdney, A. K. (Květen 1984). „Ve hře zvané Core War se nepřátelské programy zapojí do bitvy na kusy“. Scientific American. Citováno 2017-10-05.
  13. ^ Shoch, J.; Hupp, J. (březen 1982). „Programy„ Červ “- rané zkušenosti s distribuovaným výpočtem“. Komunikace ACM. 25 (3): 172–180. doi:10.1145/358453.358455.
  14. ^ Dewdney, A. K. (Březen 1985). „Základní válečný bestiář virů, červů a dalších hrozeb pro počítačové paměti“. Scientific American. Citováno 2017-10-05.
  15. ^ Dewdney, A. K. (Leden 1987). „Program s názvem MICE okusuje cestu k vítězství na prvním turnaji Core War“. Scientific American. Citováno 2017-10-05.
  16. ^ Doligez, Damien; Durham, Mark (8. listopadu 1995). „Komentovaný návrh navrhovaného standardu základní války z roku 1994“. Citováno 2013-03-11.
  17. ^ Metcalf, John. „Stručná historie Corewar“. Citováno 2013-03-11.
  18. ^ Corewar emulátory na corewar.info
  19. ^ corewar na sourceforge
  20. ^ pMARS-SDL na corewar.co.uk Joonas Pihlaja (7. května 2003)
  21. ^ stáhnout čísla na sourceforge (přístup 22.03.2017)

externí odkazy