Qarorlar jadvali - Decision table

Golf to'plami.png

Qaror jadvallari berilgan shartlarga qarab qaysi harakatlarni bajarishni belgilash uchun qisqacha ingl. Ular algoritmlar uning chiqishi harakatlar to'plamidir. Qaror jadvallarida ko'rsatilgan ma'lumotlar shuningdek quyidagicha ifodalanishi mumkin qaror daraxtlari yoki a dasturlash tili qatori sifatida if-then-else va kassa bayonotlar.

Umumiy nuqtai

Har bir qaror o'zgaruvchan, munosabat yoki predikatga mos keladi, ularning mumkin bo'lgan qiymatlari shart alternativalari qatoriga kiritilgan. Har bir harakat amalga oshiriladigan protsedura yoki operatsiya bo'lib, yozuvlar yozuvga mos keladigan shartli alternativalar to'plami uchun amalni bajarilishini (yoki qanday tartibda) belgilaydi.

Ularni yanada ixchamroq qilish uchun ko'plab qaror jadvallari o'z shartlariga alternativalarni o'z ichiga oladi a parvo qilmang belgi. Bu defis bo'lishi mumkin[1][2][3] yoki bo'sh,[4] bo'sh joydan foydalanish tavsiya etilmaydi, chunki bu faqat qarorlar jadvali tugallanmaganligini ko'rsatishi mumkin.[iqtibos kerak ] Qarorlar jadvalidan foydalanish usullaridan biri bu qabul qilingan testlarni o'tkazib yuborishga imkon beradigan va shu bilan qaror qabul qilish protseduralarini soddalashtirishga imkon beradigan ba'zi bir omillar amalga oshiriladigan harakatlar uchun ahamiyatsiz bo'lgan sharoitlarni aniqlashdir.[5]

Belgini namoyish qilishning ahamiyati yo'q
Qoidalar
ShartlarO'zingizni baquvvat his qilyapsizmi?HaYo'qHaYo'q
Yomg'ir yog'yaptimi?HaHaYo'qYo'q
AmallarIchkarida qoling.BalkiBalki
Yugurishga boring.Balki
Bog'ni boqing.BalkiBalki
Qoidalar
ShartlarO'zingizni baquvvat his qilyapsizmi?HaYo'q
Yomg'ir yog'yaptimi?HaYo'qYo'q
AmallarIchkarida qoling.Balki
Yugurishga boring.Balki
Bog'ni boqing.BalkiBalki
Yuqoridagi jadvallarda bir xil ma'lumotlar keltirilgan, ammo ikkinchi jadvalda qisqartirish uchun ahamiyatsiz belgi sifatida defis ishlatiladi.

To'rt kvadrantning asosiy tuzilishidan tashqari, qarorlar jadvallari shart alternativalari va harakatlar yozuvlarini aks ettirish uslubida juda farq qiladi.[6][7] Ba'zi qaror jadvallari shartga alternativalarni ko'rsatish uchun oddiy haqiqiy / noto'g'ri qiymatlardan foydalanadi (if-then-else-ga o'xshash), boshqa jadvallar raqamlangan alternativalardan (switch-casega o'xshash) foydalanishi mumkin, va ba'zi jadvallar loyqa mantiqiy yoki ehtimolli tasvirlardan foydalanadi shartli alternativalar uchun.[8] Xuddi shu tarzda, harakatlar yozuvlari shunchaki harakatni bajarish kerakligini (bajarish uchun harakatlarni tekshiring) yoki yanada takomillashtirilgan qaror jadvallarida bajarilishi kerak bo'lgan harakatlar ketma-ketligini (bajariladigan harakatlarni raqamlash) aks ettirishi mumkin.

Qarorlar jadvali ko'rib chiqiladi muvozanatli[4] yoki to'liq[3] agar u kirish o'zgaruvchilarining har qanday mumkin bo'lgan kombinatsiyasini o'z ichiga olsa. Boshqacha qilib aytganda, muvozanatli qarorlar jadvallari kirish o'zgaruvchilari taqdim etiladigan har qanday vaziyatda harakatni belgilaydi.[4]

Misol

Cheklangan kirish jadvalini ta'riflash eng sodda. Shart muqobillari oddiy mantiqiy qiymatlar bo'lib, harakatlar yozuvlari tasdiqlash belgilaridir, ular berilgan ustundagi harakatlarning qaysi biri bajarilishini bildiradi.

Texnik qo'llab-quvvatlash kompaniyasi o'z mijozlaridan telefon orqali tasvirlangan alomatlar asosida printer muammolarini aniqlash uchun qaror jadvalini yozadi.

Quyidagi muvozanatli qarorlar jadvali (Systems Made Simple tomonidan yaratilgan).

Printer bilan muammo bartaraf qilish vositasi
Qoidalar
ShartlarPrinter bosib chiqaradiYo'qYo'qYo'qYo'qHaHaHaHa
Qizil chiroq yonmoqdaHaHaYo'qYo'qHaHaYo'qYo'q
Printer kompyuter tomonidan tan olinadiYo'qHaYo'qHaYo'qHaYo'qHa
AmallarElektr kabelini tekshiringBalki
Printer-kompyuter kabelini tekshiringBalkiBalki
Printer dasturi o'rnatilganligiga ishonch hosil qilingBalkiBalkiBalkiBalki
Murakkabni tekshiring / o'zgartiringBalkiBalkiBalki
Qog'oz tiqilib qolganligini tekshiringBalkiBalki

Albatta, bu oddiy misol (va u printer bilan bog'liq muammolarni bartaraf etish haqiqatiga to'g'ri kelmasligi shart), ammo shunga qaramay, qaror jadvallari ko'plab imkoniyatlar bilan bir nechta shartlarga qanday kattalashishi mumkinligini namoyish etadi.

Dasturiy ta'minotning afzalliklari

Qarorlar jadvallari, ayniqsa a domenga xos til, ishlab chiquvchilar va siyosat mutaxassislariga bir xil ma'lumotlardan, qarorlar jadvallaridan o'zlari ishlashga imkon beradi.

Qarorlar jadvaliga an'anaviy dasturlash tillaridan olingan bayonotlar, shuningdek, disk raskadrovka vositasi sifatida ishlatilishi mumkin bo'lsa, ichki joylashtirish vositalari.[9][10]

Qaror jadvallarini koddan ko'ra tushunish va ko'rib chiqish osonroq ekanligi isbotlangan va murakkab tizimlar uchun texnik xususiyatlarni ishlab chiqarish uchun keng va muvaffaqiyatli ishlatilgan.[11]

Tarix

1960-70-yillarda bir qator "qarorlar jadvaliga asoslangan" tillar Filetab biznes dasturlash uchun mashhur bo'lgan.

Dasturga kiritilgan qaror jadvallari

Qarorlar jadvallari kompyuter dasturlariga joylashtirilishi mumkin va ko'pincha dastur mantig'ini "qo'zg'atish" uchun ishlatiladi. Oddiy misol a bo'lishi mumkin qidiruv jadvali mumkin bo'lgan kirish qiymatlari oralig'ini o'z ichiga olgan va a funktsiya ko'rsatgichi ushbu kirishni qayta ishlash uchun kod bo'limiga.

Statik qarorlar jadvali
KiritishFunktsiya ko'rsatgichi
"1"Funktsiya 1 (boshlash)
"2"2-funktsiya (2-jarayon)
"9"9-funktsiya (tugatish)

Boshqaruv jadvallari

Butun dastur mantig'ini "bajariladigan" qarorlar jadvali shaklida inkassatsiya qilish uchun bir nechta shartlarni shunga o'xshash tarzda kodlash mumkin. boshqaruv jadvali. Amalda turli xil darajalarda ishlaydigan va ko'pincha bir-biriga bog'langan (ko'rsatgichlar yoki indeks qiymati bilan) bir nechta bunday jadvallar bo'lishi mumkin.

Amaliyotlar

  • Filetab, dastlab NCC
  • DETAB / 65, 1965, ACM
  • 1962 yilda RAND-dan FORTAB, FORTRAN-ga joylashtirilishi uchun mo'ljallangan[12]
  • A Yoqut amalga oshirish yordamida mavjud MapReduce ma'lum kirish qiymatlari asosida to'g'ri harakatlarni topish.[13]

Shuningdek qarang

Adabiyotlar

  1. ^ LI Jing (2015 yil 1-aprel). "SEEM 3430 qo'llanmasi: Qaror jadvallari" (PDF). p. 23. Olingan 11 noyabr 2017.CS1 maint: ref = harv (havola)
  2. ^ "Biznes qoidalarida qarorlar jadvalini yaratish". Oracle yordam markazi. 2017 yil 6-avgust. Olingan 11 noyabr 2017.
  3. ^ a b Ross, Ronald G. (2005). "Qaror jadvallari, 2-qism ~ To'liqlik yo'li". Biznes qoidalari jurnali. 6 (8). Olingan 11 noyabr 2017.
  4. ^ a b v Snow, Paul (2012 yil 19-iyul). "Qaror jadvallari". DTRulalar: Java asosidagi qarorlar jadvali qoidalari mexanizmi. Olingan 11 noyabr 2017.
  5. ^ LI Jing 2015 yil, p. 24-25.
  6. ^ Rojers, Uilyam T. "Qarorlar jadvaliga misollar: tibbiy sug'urta". Sankt-Xaver universiteti tizimlarini tahlil qilish va loyihalash. Arxivlandi asl nusxasi 2007 yil 29 martda.
  7. ^ "Arxivlangan nusxa". Arxivlandi asl nusxasi 2012-05-30 kunlari. Olingan 2010-07-07.CS1 maint: nom sifatida arxivlangan nusxa (havola)
  8. ^ Nam, Geert; Vitloks, Frank; Timmermans, Garri; Vantienen, yanvar (1996). "Aniq bo'lmagan qarorlar jadvallari yordamida joylashishni tanlashni modellashtirish". Loyqa mantiq va hisoblashning yangi chegaralari: 1996 yilda Shimoliy Amerika loyqa axborotni qayta ishlash jamiyatining ikki yillik anjumani - NAFIPS. Shimoliy Amerika loyqa axborotni qayta ishlash jamiyatining ikki yilda bir marta o'tkaziladigan konferentsiyasi. Berkli, Kaliforniya: IEEE. 80-84 betlar. doi:10.1109 / NAFIPS.1996.534708. ISBN  0-7803-3225-3.
  9. ^ "Haqiqiy CCIDE misoli"
  10. ^ "Qarorlar jadvalini engish uchun tajriba". Arxivlandi asl nusxasi 2017-05-04 da. Olingan 2010-07-07.
  11. ^ Udo V.Poch, "Qaror jadvallarini tarjimasi", ACM hisoblash tadqiqotlari, 6-jild, 2-son (1974 yil iyun) Sahifalar: 125–151 ISSN  0360-0300
  12. ^ "FORTAB: Ilmiy hisoblash dasturlari uchun qarorlar jadvali tili", 1962, Rand
  13. ^ Aleksandr Uilyams (2015). "Ruby qarorlar jadvalini tahlil qiluvchi"

Qo'shimcha o'qish

  • Dwyer, B. and Hutchings, K. (1977) "Cope-da oqim sxemasini optimallashtirish, ko'p tanlovli qarorlar jadvali" Aust. Komp. J. Vol. 9 № 3 p. 92 (1977 yil sentyabr).
  • Fisher, D.L. (1966) "Ma'lumotlar, hujjatlar va qarorlar jadvallari" Comm ACM jild. 9 № 1 (1966 yil yanvar) p. 26–31.
  • General Electric Company (1962) GE-225 TABSOL ma'lumot qo'llanmasi va GF-224 TABSOL dastur qo'llanmasi CPB-l47B (1962 yil iyun).
  • Grindli, KB (1968) "Sistematikada qaror jadvallarini ishlatish" Comp. J. Vol. 11 № 2 p. 128 (1968 yil avgust).
  • Jekson, MA (1975) Dasturlarni loyihalashtirish asoslari Akademik matbuot
  • Myers, H.J. (1972) "Qaror jadvallaridan optimallashtirilgan kodni kompilyatsiya qilish" IBM J. Res. & Rivojlanish (1972 yil sentyabr) p. 489-503.
  • Pollack, S.L. (1962) "DETAB-X: takomillashtirilgan biznesga yo'naltirilgan kompyuter tili" Rand Corp. Memo RM-3273-PR (1962 yil avgust)
  • Shumaxer, H. va Sevcik, K.C. (1976) "Qarorlarni jadvalga aylantirishga sintetik yondashuv" Comm. ACM jildi 19 № 6 (1976 yil iyun) p. 343–351
  • CSA, (1970): Z243.1-1970, qarorlar jadvallari uchun, Kanada standartlari assotsiatsiyasi
  • Jorgensen, Pol C. (2009) Dasturiy ta'minotning o'zini tutishini modellashtirish: Hunarmandning yondashuvi. Auerbach nashrlari, CRC Press. 5-bob.

Tashqi havolalar

  • RapidGen dasturiy ta'minoti Qarorlar jadvaliga asoslangan dasturlash vositalari va kompilyatorlari Windows, Unix, Linux va OpenVMS versiyalari uchun
  • LogicGem dasturi Mantiq va biznes qoidalarini takomillashtirish uchun Windows qaror jadval protsessori uchun