Qotishma (spetsifikatsiya tili) - Alloy (specification language)

Yilda Kompyuter fanlari va dasturiy ta'minot, Qotishma deklarativdir spetsifikatsiya tili a-da murakkab tarkibiy cheklovlar va xatti-harakatlarni ifodalash uchun dasturiy ta'minot tizimi. Qotishma oddiy tarkibiy modellashtirish vositasini taqdim etadi birinchi darajali mantiq.[1] Qotishma yaratishga qaratilgan mikro modellar keyin avtomatik ravishda tekshirilishi mumkin to'g'rilik. Qotishma texnik xususiyatlarini qotishma analizatori yordamida tekshirish mumkin.

Qotishma avtomatik tahlilni hisobga olgan holda ishlab chiqarilgan bo'lsa-da, qotishma ko'plab texnik tillardan farq qiladi modellarni tekshirish u cheksiz modellarni ta'riflashga imkon beradi. Qotishma analizatori cheksiz modellarda ham cheklangan hajm tekshiruvlarini amalga oshirish uchun mo'ljallangan.

Qotishma tili va analizatori boshchiligidagi guruh tomonidan ishlab chiqilgan Daniel Jekson da Massachusets texnologiya instituti ichida Qo'shma Shtatlar.

Tarix va ta'sirlar

Qotishma tilining birinchi versiyasi 1997 yilda paydo bo'lgan. Bu juda cheklangan edi ob'ektni modellashtirish til. Tilning muvaffaqiyatli takrorlanishlari "qo'shildi miqdoriy ko'rsatkichlar, yuqori arity munosabatlar, polimorfizm, kichik tip va imzolar.[2]

Tilning matematik asoslariga kuchli ta'sir ko'rsatgan Z belgisi, va sintaksis qotishma kabi tillarga ko'proq qarzdor Ob'ektni cheklash tili.

Qotishma analizatori

Qotishma analizatori.

Qotishma analizatori "engil rasmiy usullar" deb nomlangan maxsus ishlab chiqilgan. Shunday qilib, u aksincha, to'liq avtomatlashtirilgan tahlilni taqdim etishga mo'ljallangan isbotlovchi interaktiv teorema qotishma o'xshash spetsifikatsiya tillari bilan tez-tez ishlatiladigan usullar. Analizatorning rivojlanishi dastlab tomonidan taqdim etilgan avtomatlashtirilgan tahlildan ilhomlangan shashka modellari. Biroq, modelni tekshirish odatda qotishmada ishlab chiqarilgan modellarga mos kelmaydi va natijada analizatorning yadrosi oxiriga o'rnatilgan model topuvchi sifatida amalga oshirildi. mantiqiy SAT hal qiluvchi.[1]

3.0 versiyasi orqali Qotishma analizatori SAT-echimiga asoslangan ajralmas SAT-ga asoslangan model qidiruvchisini birlashtirdi. Ammo 4.0-versiyadan boshlab Analizator Kodkod modelini topuvchisidan foydalanadi, bu uchun analizator oldingi qism vazifasini bajaradi. Ikkala modelni qidiruvchilar asosan ifodalangan modelni tarjima qilishadi munosabat mantig'i mos keladiganga mantiqiy mantiq formulasini tanlang va keyin mantiqiy formulada mavjud bo'lgan SAT-erituvchini ishlating. Agar hal qiluvchi echim topgan bo'lsa, natija relyatsion mantiqiy modeldagi o'zgaruvchilar bilan doimiy ravishda majburiy bog'lanishiga aylantiriladi.[3]

Modelni topish muammosini ta'minlash uchun hal qiluvchi, qotishma analizatori foydalanuvchi tomonidan belgilangan cheklangan sonli ob'ektlardan tashkil topgan cheklangan doiralar bo'yicha modellarni aniqlashni amalga oshiradi. Bu analizator tomonidan ishlab chiqarilgan natijalarning umumiyligini cheklashga ta'sir qiladi. Biroq, qotishma analizatorining dizaynerlari cheklangan doirada ishlash qarorini apellyatsiya orqali oqlashadi kichik doiradagi gipoteza: xatoliklarning yuqori qismini, ba'zi bir kichik hajmdagi barcha test kirishlari uchun dasturni sinab ko'rish orqali topish mumkin.[4]

Model tuzilishi

Qotishma modellari relyatsion xarakterga ega va bir nechta turli xil bayonotlardan iborat:[1]

  • Imzolar yangi to'plamlarni yaratish orqali modelning so'z boyligini aniqlash
sig Ob'ekt {} imzo belgilaydi Ob'ekt
sig Ro'yxat {bosh: yolg'iz Tugun} imzo belgilaydi Ro'yxat maydonni o'z ichiga olgan bosh turdagi Tugun va ko'plik yolg'iz - bu o'rtasidagi munosabat mavjudligini belgilaydi Ro'yxats va Tugunhar bir kishi shunday Ro'yxat birdan ko'p bo'lmagan bosh bilan bog'liq Tugun
  • Faktlar har doim ham mavjud deb taxmin qilinadigan cheklovlardir
  • Bashoratlar parametrlangan cheklovlar bo'lib, operatsiyalarni namoyish qilish uchun ishlatilishi mumkin
  • Vazifalar natijalarni beradigan iboralar
  • Tasdiqlar model haqidagi taxminlar

Qotishma deklarativ tildir, chunki modelning ma'nosi bayonotlar tartibiga ta'sir qilmaydi.

Adabiyotlar

  1. ^ a b v Jekson, Doniyor (2006). Dastur abstraktsiyalari: mantiq, til va tahlil. MIT Press. ISBN  978-0-262-10114-1.
  2. ^ "Qotishma bilan tez-tez so'raladigan savollar". Arxivlandi asl nusxasi 2007 yil 7-iyunda. Olingan 7 mart 2013.
  3. ^ Torlak, E .; Dennis, G. (2008 yil aprel). "Qotishma foydalanuvchilari uchun Kodkod" (PDF). Birinchi ACM qotishma ustaxonasi. Portlend, Oregon. Arxivlandi asl nusxasi (PDF) 2010-06-22. Olingan 2009-04-19.
  4. ^ Andoni, Aleksandr; Daniliuk, Dumitru; Xurshid, Sarfraz; Marinov, Darko (2002). "Kichik doiradagi gipotezani baholash". CiteSeerX  10.1.1.8.7702. Iqtibos jurnali talab qiladi | jurnal = (Yordam bering)

Tashqi havolalar