Robustnost (informatika) - Robustness (computer science)

v počítačová věda, robustnost je schopnost počítačového systému vyrovnat se s chybami během provádění[1][2] a vyrovnat se s chybným vstupem.[2] Robustnost může zahrnovat mnoho oblastí počítačové vědy, jako např robustní programování, robustní strojové učení, a Robustní bezpečnostní síť. Formální techniky, jako např fuzz testování, jsou nezbytné k prokázání robustnosti, protože tento typ testování zahrnuje neplatné nebo neočekávané vstupy. Alternativně, vstřikování poruch lze použít k testování robustnosti. Různé komerční produkty provádějí testování robustnosti softwarové analýzy.[3]

Úvod

Obecně je budování robustních systémů, které zahrnují každý bod možného selhání, obtížné kvůli velkému množství možných vstupů a kombinací vstupů.[4] Protože by všechny vstupy a kombinace vstupů vyžadovaly příliš mnoho času na testování, vývojáři nemohou všechny případy vyčerpávat. Místo toho se vývojář pokusí takové případy zobecnit.[5] Představte si například, že nějaké zadáte celočíselné hodnoty. Některé vybrané vstupy se mohou skládat ze záporného čísla, nuly a kladného čísla. Při použití těchto čísel k testování softwaru tímto způsobem vývojář zobecní množinu všech realů na tři čísla. Jedná se o efektivnější a zvládnutelnější metodu, ale náchylnější k neúspěchu. Zobecnění testovacích případů je příkladem pouze jedné techniky řešení selhání - konkrétně selhání v důsledku neplatného vstupu uživatele. Systémy mohou obecně selhat také z jiných důvodů, například z odpojení od sítě.

Bez ohledu na to by složité systémy měly všechny chyby, s nimiž se setkají ladně, stále zvládnout. Existuje mnoho příkladů takových úspěšných systémů. Některé z nejrobustnějších systémů lze vyvíjet a lze je snadno přizpůsobit novým situacím.[4]

Výzvy

Programy a software jsou nástroje zaměřené na velmi konkrétní úkol, a proto nejsou zobecněné a flexibilní.[4] Pozorování v systémech, jako je Internet nebo biologické systémy prokázat přizpůsobení se svému prostředí. Jedním ze způsobů, jak se biologické systémy přizpůsobují prostředí, je využití redundance.[4] Mnoho orgánů je u lidí nadbytečných. The ledviny je jeden takový příklad. Lidé obecně potřebujete pouze jednu ledvinu, ale mít druhou ledvinu poskytuje prostor pro selhání. Stejný princip lze použít i pro software, ale existují určité výzvy. Při aplikaci principu redundance na informatiku se slepé přidávání kódu nedoporučuje. Slepé přidání kódu přináší více chyb, dělá systém složitějším a ztěžuje pochopení.[6] Kód, který neposkytuje žádné posílení již existujícího kódu, je nežádoucí. Nový kód musí místo toho mít ekvivalent funkčnost, takže pokud dojde k poruše funkce, může ji nahradit jiná poskytující stejnou funkci, a to ručně nebo automaticky softwarová rozmanitost. Aby to bylo možné, musí nový kód vědět, jak a kdy se má přizpůsobit bodu selhání.[4] To znamená více logika je třeba přidat do systému. Ale jak systém přidává více logiky, komponenty a zvětšuje se, stává se složitějším. Při vytváření redundantnějšího systému se tedy systém také stává složitějším a vývojáři musí zvážit vyvážení redundance se složitostí.

V současné době se postupy počítačové vědy nezaměřují na budování robustních systémů.[4] Spíše mají sklon soustředit se na škálovatelnost a účinnost. Jedním z hlavních důvodů, proč se dnes nezaměřuje na robustnost, je to, že je těžké to udělat obecně.[4]

Oblasti

Robustní programování

Robustní programování je styl programování, který se zaměřuje na zpracování neočekávaného ukončení a neočekávaných akcí.[7] Vyžaduje kód pro řádné zpracování těchto zakončení a akcí zobrazením přesných a jednoznačných chybové zprávy. Tyto chybové zprávy umožňují uživateli snadnější ladění programu.

Zásady

Paranoia - Při vytváření softwaru programátor předpokládá, že uživatelé budou porušovat svůj kód.[7] Programátor také předpokládá, že jeho vlastní psaný kód může selhat nebo fungovat nesprávně.[7]

Hloupost - Programátor předpokládá, že se uživatelé pokusí o nesprávné, falešné a chybně zadané vstupy.[7] V důsledku toho programátor vrátí uživateli jednoznačnou a intuitivní chybovou zprávu, která nevyžaduje vyhledávání chybových kódů. Chybová zpráva by se měla snažit být co nejpřesnější, aniž by byla pro uživatele zavádějící, aby bylo možné problém snadno vyřešit.

Nebezpečné nářadí - Uživatelé by neměli získat přístup k knihovny, datové struktury nebo ukazatele k datovým strukturám.[7] Tyto informace by měly být uživateli skryty, aby je uživatel omylem nezměnil a nezavedl chybu v kódu. Když takové rozhraní jsou správně sestaveny, uživatelé je používají, aniž by našli mezery v úpravách rozhraní. Rozhraní by již mělo být správně implementováno, takže uživatel nemusí provádět žádné úpravy. Uživatel se proto zaměřuje výhradně na svůj vlastní kód.

To se nemůže stát - Velmi často je kód upravován a může představovat možnost, že dojde k „nemožnému“ případu. Nemožné případy se proto považují za vysoce nepravděpodobné.[7] Vývojář přemýšlí o tom, jak řešit případ, který je vysoce nepravděpodobný, a podle toho implementuje zpracování.

Robustní strojové učení

Robustní strojové učení se obvykle týká robustnosti algoritmů strojového učení. Aby byl algoritmus strojového učení považován za robustní, musí být chyba testování konzistentní s chybou tréninku, nebo je výkon stabilní po přidání nějakého šumu do datové sady.[8]

Robustní design sítě

Robustní návrh sítě je studium návrhu sítě tváří v tvář proměnným nebo nejistým požadavkům.[9] V jistém smyslu je robustnost v návrhu sítě široká, stejně jako robustnost v designu softwaru, a to kvůli velkým možnostem změn nebo vstupů.

Robustní algoritmy

Existují algoritmy, které tolerují chyby ve vstupu[10] nebo během výpočtu.[11] V takovém případě výpočet nakonec konverguje na správný výstup. Tento jev byl nazýván „přitažlivost správnosti“.[11]

Viz také

Reference

  1. ^ „Modelový přístup k testování robustnosti“ (PDF). Dl.ifip.org. Citováno 2016-11-13.
  2. ^ A b 1990. IEEE Standard Glossary of Software Engineering Terminology, IEEE Std 610.12-1990 definuje robustnost jako „Míra, do jaké může systém nebo komponent správně fungovat v přítomnosti neplatných vstupů nebo stresujících podmínek prostředí“
  3. ^ Baker, Jack W .; Schubert, Matthias; Faber, Michael H. (2008). „K posouzení robustnosti“ (PDF). Strukturální bezpečnost. 30 (3): 253–267. doi:10.1016 / j.strusafe.2006.11.004. Citováno 2016-11-13.
  4. ^ A b C d E F G Gerald Jay Sussman (13. ledna 2007). „Budování robustních systémů - esej“ (PDF). Skupiny.csail.mit.edu. Citováno 2016-11-13.
  5. ^ Joseph, Joby (2009-09-21). „Důležitost vytváření zobecněných testovek - Klub pro testování softwaru - Komunita pro testování softwaru online“. Klub testování softwaru. Citováno 2016-11-13.
  6. ^ Agenti na wEb: Robustní software. „Budování robustních systémů - esej“ (PDF). Cse.sc.edu. Citováno 2016-11-13.
  7. ^ A b C d E F „Robustní programování“. Nob.cs.ucdavis.edu. Citováno 2016-11-13.
  8. ^ El Sayed Mahmoud. „Jaká je definice robustnosti algoritmu strojového učení?“. Citováno 2016-11-13.
  9. ^ „Robustní návrh sítě“ (PDF). Math.mit.edu. Citováno 2016-11-13.
  10. ^ Carbin, Michael; Rinard, Martin C. (12. července 2010). „Automatická identifikace kritických vstupních oblastí a kódu v aplikacích“ (PDF). Sborník 19. mezinárodního sympozia o testování a analýze softwaru - ISSTA '10. ACM. 37–48. doi:10.1145/1831708.1831713. ISBN  9781605588230. S2CID  1147058.
  11. ^ A b Danglot, Benjamin; Preux, Philippe; Baudry, Benoit; Monperrus, Martin (21. prosince 2017). „Přitažlivost správnosti: studie stability chování softwaru při poruchách za běhu“. Empirické softwarové inženýrství. 23 (4): 2086–2119. arXiv:1611.09187. doi:10.1007 / s10664-017-9571-8. S2CID  12549038.