Ағымдағы X-Machine - Stream X-Machine

The Ағынды X-машина (SXM) - Гилберт Лэйкоктың 1993 жылғы кандидаттық диссертациясында енгізілген есептеу үлгісі, Техникалық сипаттамаға негізделген бағдарламалық жасақтаманы сынау теориясы мен практикасы.[1]Негізделген Сэмюэль Эйленберг Келіңіздер X-машина, ұзартылған ақырғы күйдегі машина типті деректерді өңдеу үшін X,[2] Stream X-Machine - бұл бір түрі X-машина жадының мәліметтер типін өңдеуге арналған Мем байланысты кіріс және шығыс ағындарымен Жылы* және Шығу*, яғни қайда X = Шығу* × Мем × Жылы*. Stream X-машинасының ауысулары φ формасының функцияларымен белгіленеді: Мем × ЖылыШығу × Мем, яғни шығыс мәнін есептейтін және жадыны жаңартатын, ағымдағы жадтан және кіріс мәнінен.

Жалпы болғанымен X-машина бағдарламалық жасақтаманы нақтылау үшін 1980 жылы ықтимал пайдалы формалы модель ретінде анықталған,[3] Stream X-Machine пайда болғанға дейін ғана бұл идеяны толығымен пайдалануға болатын еді. Флорентин Ипейт пен Майк Холкомб теориясын дамыта түсті толық функционалдық тестілеу,[4] онда жүздеген мың күйі бар және миллиондаған өтпелі күрделі бағдарламалық жасақтаманы дұрыс интеграцияланғандығына кепілдендірілген дәлме-дәл тексеруге болатын жеке SXM-ге бөлуге болады.[5]

Stream X-Machines-ті интуитивті түрде «кіріс және шығысымен өңдеуші агенттер» деп түсіндіргендіктен, олар нақты құбылыстарды модельдеуге пайдалы болғандықтан, қызығушылықты арттырды. SXM моделі әр түрлі салаларда маңызды қосымшаларға ие есептеу биологиясы, бағдарламалық жасақтаманы тестілеу және агенттерге негізделген есептеу экономикасы.

Stream X-Machine

Stream X-Machine (SXM) кеңейтілген ақырғы күйдегі машина қосалқы жадымен, кіріс және шығысымен. Бұл жалпының нұсқасы X-машина, онда негізгі деректер түрі X = Шығу* × Мем × Жылы*, яғни шығыс ағыннан, жадтан және кіріс ағынынан тұратын кортеж. SXM ажыратады басқару ағыны жүйенің өңдеу жүйемен жүзеге асырылады. Басқару а ақырғы күйдегі машина (ретінде белгілі байланысты автомат), олардың ауысулары Φ жиынтығынан таңдалған өңдеу функциясымен белгіленеді ( түрі деректердің негізгі түріне сәйкес келетін машинаның).

Φ-дегі әрбір өңдеу функциясы ішінара функция болып табылады және оны type типі бар деп санауға болады: Мем × ЖылыШығу × Мем, қайда Мем бұл жад түрі, және Жылы және Шығу сәйкесінше енгізу және шығару түрлері болып табылады. Кез келген жағдайда ауысу болып табылады қосылды егер байланысты функцияның домені φмен келесі кіріс мәнін және ағымдағы жад күйін қамтиды. Егер берілген күйде (ең көп дегенде) бір ауысу қосылса, машина жұмыс істейді детерминистік. Өтпелі кезеңнен өту the байланысты функцияны қолдануға теңмен, бір кірісті тұтынады, мүмкін жадыны өзгертеді және бір нәтиже шығарады. Құрылғы арқылы танылған әрбір жол a тізімін жасайды1 ... φn функциялар, ал SXM осы функцияларды деректердің негізгі типіне қатынас құру үшін бірге жасайды | φ1 ... φn|: XX.

Рентген машиналарымен байланыс

Stream X-Machine - нұсқасы X-машина онда негізгі мәліметтер типі X = Шығу* × Мем × Жылы*. Түпнұсқада X-машина, φмен жалпы болып табылады қарым-қатынастар қосулы X. Stream X-Machine-де бұлар әдетте шектелген функциялары; дегенмен SXM әлі де детерминирленген, егер әр күйде (ең көп дегенде) бір ауысу қосылса.

Генерал X-машина α алдыңғы кодтау функциясын қолдана отырып, кіріс пен шығыспен жұмыс істейді: YX декодтаудың артқы функциясы және енгізу үшін: XЗ шығу үшін, қайда Y және З сәйкесінше енгізу және шығару түрлері болып табылады. Stream X-Machine-де бұл түрлер ағындар болып табылады:

 Y = Жылы* З = Шығу*

және кодтау және декодтау функциялары келесідей анықталады:

 α (инс) = (<>, мем0, инс) β (шығу, мемn, <>) = шығу

қайда ин: In*, шығу: шығу* және меммен: Мем. Басқаша айтқанда, машина барлық кіріс ағынымен инициализацияланады; және декодталған нәтиже - бұл кіріс ағыны түгелдей, егер кіріс ағыны түгелдей жұмсалса (әйтпесе нәтиже анықталмаған).

SXM-дегі әр өңдеу функциясына қысқартылған түрі φ беріледіSXM: Мем × ЖылыШығу × Мем. Мұны жалпыға салыстыруға болады X-машина φ: X → X түріндегі қатынас, егер біз мұны есептеу ретінде қарастырсақ:

 φ (шығу, меммен, жылы :: инс) = (шығу :: шығу, мемi + 1, инс)

қайда :: элементтің тізбегін және тізбекті білдіреді. Басқаша айтқанда, қатынас кіріс ағынының басын шығарады, жадыны өзгертеді және шығыс ағынының құйрығына мән қосады.

Өңдеу және сыналатын қасиеттер

Жоғарыдағы эквиваленттілікке байланысты назар Stream X-Machine қосалқы жадыны қолданып, кірістерді шығысқа өңдейтін тәсілге аударылуы мүмкін. Жадтың бастапқы күйі берілген мем0 және кіріс ағыны инс, машина бір уақытта бір кірісті тұтынатын және бір уақытта бір шығыс шығаратын қадамдық әдіспен жұмыс істейді. Бұл (кем дегенде) бір танылған жолмен жол = φ1 ... φn кіріс жұмсалған күйге әкелетін болса, машина соңғы жад күйін шығарады мемn және шығыс ағыны шығу. Жалпы, біз мұны барлық танылған жолдармен есептелген қатынас ретінде қарастыра аламыз: | жол | : Жылы* → Шығу*. Мұны жиі деп атайды мінез-құлық Stream X-Machine құрылғысы.

Әр күйде (ең көп дегенде) бір ауысу қосылса, мінез-құлық детерминирленген. Бұл қасиет және машинаның кірістер мен жадыға жауап ретінде қалай әрекет ететіндігін басқару мүмкіндігі оны бағдарламалық жасақтаманың спецификациясы үшін тамаша модель етеді. Егер спецификация мен іске асырудың екеуі де Stream X-Machines деп қабылданған болса, онда енгізу әр қадамда кірістер мен шығыстарды бақылаумен спецификация машинасына сәйкестігін тексеруге болады. Laycock алдымен тестілеу мақсатында бақылаулармен бір сатылы өңдеудің утилитасын атап өтті.[1]

Holcombe және Ipate мұны бағдарламалық жасақтаманы тестілеудің практикалық теориясына айналдырды[4] ол өте композициялық, өте үлкен жүйелерді масштабтау.[6] Дұрыс интеграцияның дәлелі[5] әрбір компонент пен әрбір интеграциялық қабатты бөлек тексеру бүкіл жүйені тексеруге сәйкес келетініне кепілдік береді. Бөлу мен жаулап алудың бұл тәсілі жасалады толық үлкен жүйелер үшін мүмкін болатын тестілеу.

Тестілеу әдісі жеке мақалада сипатталған Stream X-Machine әдіснамасы.

Сондай-ақ қараңыз

  • Х-машиналар, қарапайым мысалды қоса, X-машина моделінің жалпы сипаттамасы.
  • Stream X-Machine тестілеу әдістемесі, а толық функционалды тестілеу техника. Осы әдіснаманы қолдана отырып а ақырлы іске асырудың оның сипаттамасына сәйкес келуін толық анықтайтын тесттер жиынтығы. Техника қолданушыларға мұқият көрсетілген талапты қолдану арқылы шешілмеудің ресми шектеулерін жеңеді сынақ үшін дизайн іске асыру кезіндегі принциптер.
  • Байланыс ағынының X-машиналары (CSXM), әлеуметтік жәндіктерден экономикаға дейінгі салалардағы қосымшалары бар SXM моделінің бір уақытта жасалған нұсқасы.

Сыртқы сілтемелер

Әдебиеттер тізімі

  1. ^ а б Гилберт Лэйкок (1993) Техникалық сипаттамаға негізделген бағдарламалық жасақтаманы сынау теориясы мен практикасы. PhD докторлық диссертация, Шеффилд университеті, Информатика бөлімі. Реферат Мұрағатталды 2007-11-05 ж Wayback Machine
  2. ^ Сэмюэль Эйленберг (1974) Автоматтар, тілдер және машиналар, т. A. Лондон: Academic Press.
  3. ^ M. Holcombe (1988) 'X-машиналар динамикалық жүйенің спецификациясының негізі'. Бағдарламалық жасақтама журналы 3 (2), 69-76 бет.
  4. ^ а б Майк Холкомб және Флорентин Ипейт (1998) Дұрыс жүйелер - бизнес-процестің шешімін құру. Қолданбалы есептеу сериясы. Берлин: Шпрингер-Верлаг.
  5. ^ а б F. Ipate және W. M. L. Holcombe (1997) 'Барлық ақауларды табатын интеграциялық тестілеу әдісі'. Int. J. Comp. Математика., 63, 159-178 беттер.
  6. ^ F. Ipate және M. Holcombe (1998) 'Машинаның жалпыланған сипаттамаларын нақтылау және сынау әдісі'. Int. J. Comp. Математика. 68, 197-219 беттер.