Индуктивно логичко програмирање (ИЛП) је подобласт машинског учења који користи логику програмирања као јединствену репрезентацију за примере, знање и хипотезе. Дало је кодирање познатог предзнања и скупа примера представљених као логична база чињеница, један ИЛП систем ће извести хипотеза логичких програма који обухвата све позитивне и ништа од негативних примера.
Индуктивно логичко програмирање је посебно корисно у биоинформатици и обради природног језика. Ехуд Шапиро је положио теоријски темељ за индуктивно логичко програмирање[1][2] и изградио своју прву примену (модел Инференце Система) 1981:[3] Пролог програм који индуктивно закључене логичке програме из позитивних и негативних примера. Термин Индуктивно логичко програмирање је први пут уведено[4] у рад Степхена Мугглетона 1991.[5] Термин "индуктивно" овде се односи на филозофску (тј сугерише теорију да објасни посматране чињенице) више него на математичку (тј доказивања имовине за све чланове добро - организованог сета) индукцију.
Формална дефиниција
Претходно знање је дато као логичка теорија , обично у облику Хорн клаузуле које се користе у логичком програмирању. Позитивни и негативни примери су дати као целина и од unnegated и негираних подземних литерала. Исправно хипотеза је логичка пропозиција која задовољава следеће услове.[6]
| Потреба:
|
|
|
|-
| Довољност:
|
|
|
|-
| Слаба конзистентност:
|
|
|
|-
|
Јака конзистентност:
|
|
|
|}
"Потреба" не намеће ограничавање , али забрањује сваку генерацију хипотеза све док се позитивне чињенице не објасне без ње. "Довољност" захтева никакву генерисану хипотезу за објашњење свих позитивних примера . "Слаба доследност" забрањује генерацију било које хипотезе која је у супротности са позадином знања . "Јака коинзистентност" такође забрањује стварање било које хипотезе h која није у складу са негативним примерима , с обзиром на претходно знање ; то подразумева "слабу конзистентност"; ако су дати никакви негативни примери, оба услова се поклапају. Џероски[7] захтева само "довољност" (под називом "потпуност" тамо) и "Јаку доследност".
Пример
”
Следећи познати пример за учење дефиниција породичних односа користе скраћенице par : parent, fem : female, dau : daughter, g : George, h : Helen, m : Mary, t : Tom, n : Nancy, и e : Eve... То почиње од позадине знања (упореди слику)
,
су позитивни примери
,
и тривијални предлог да означи одсуство негативних примера.
Плоткинсова[8][9]"Релативна најмања општа генерализација (Рног)" је приступ индуктивном логичком програмирању која се користи како би се добио предлог о томе како да се формално дефинише ћерка односно .
Овај приступ користи следеће кораке.
Релативизује сваки позитиван пример буквално са комплетним предзнањем:
Борба против сваког компатибилног[10] пара[11] литерала:
од и ,
од и ,
од и ,
од и , сличан за све остале литерале позадинског знања
од и , и још много негираних литерала
Обриши све негиране литерале који садрже варијабле које се не јављају у позитивним литералима:
након брисања свих негираних литерала који садрже друге променљиве од , само Остаје, заједно са свим копненим литералима из знања позадине
Претвори клаузуле назад на Хорн форму:
Добијена Хорн клаузула хипотеза добијена помоћу Риг приступа. Игнорисање позадине чињеница знања, клаузула неформално пише " зове ћерку ако је родитељ од и је женско", што је уобичајено прихваћена дефиниција.
Што се тиче горенаведених услова, "Потреба" је задовољана јер предикат се не појављује у позадини знања, која стога не може означити било коју имовину која садржи овај предикат, као што су позитивни примери. "Довољност" је задовољена обрачунатим хипотезама , пошто она, заједно са од позадинског знања, подразумева први позитиван пример , и слично и
из познавања позадине подразумева други позитиван пример ."Слаба коинзистентност" је задовољена са , јер она држи у (коначној) Хербранд структури описа позадинског знања; слично за "Јака конзистентност".
Заједничка дефиниција бака односа, наиме., не могу научити коришћењем горенаведеног приступа, пошто променљива се јавља само у телима клаузула; одговарајући литерали би били избрисана у 4. корака. Да би се превазишао овај пропуст, тај корак мора бити модификован тако да се може параметризовати са различитим литералима након селекције хеуристике. Историјски, имплементација ГОЛЕМ се заснива на Риг приступу.
Индуктивни логички програмски систем
Индуктивни логички програмски систем је програм који се узима као улаз логичких теорија и даје исправну хипотезу ВРТ теорије
Алгоритам једног ИЛП система се састоји из два дела: хипотеза тражења и селекције хипотеза. Прво хипотеза је претрес са индуктивним поступком логичког програмирања, онда подскуп налази хипотезу (у већини система једна хипотеза) изабрану од стране избор алгоритма. Сортира бодове алгоритма, сваке од пронађени хипотеза и враћа оне са највећом оценом.
Пример скор функција укључује минималну дужину компресије где је хипотеза са најнижом Колмогоровом комплексношчћу има највишу оцену и враћа се. ИЛП систем је комплетан акко за било какве улазе логичких теорија нека исправна хипотеза ВРТ ове улазне теорије може се наћи са својом хипотезом у истраживачкој процедури.
Претрага Хипотеза
Модерни ИЛП системи као што су Progol,[5] Hail[12] и Imparo[13] проналазе хипотезу H користећи принцип инверзних елемената[5] за теорију B, E, H:.
Прво се конструише средња теорија F и назива се теорија моста која испуњава услове
and . Онда , они генерализују негацију теорије моста F са anti-entailment. Међутим, рад на anti-entailment је високо не-детерминистички рачунски скуп. Дакле, алтернативна хипотеза претрага може се обавити помоћу рада инверзне супсумације (анти-супсумације) уместо што је мање недетерминистички од anti-entailment.
Питања потпуност поступка хипотеза за претрагу специфичног ИЛП система настају. На пример, Прогол хипотеза истраживања поступка на основу обрнутог entailment закључивања правила није завршен у Јамамото примеру.[14] С друге стране, Импаро је завршена у anti-entailment поступку[15] и његовој изузетно инверзној супсумацији[16] поступка.
^Shapiro, Ehud Y. Inductive inference of theories from facts, Research Report 192, Yale University, Department of Computer Science, 1981. Reprinted in J.-L. Lassez, G. Plotkin (Eds.), Computational Logic, The MIT Press. Cambridge, MA. (1991). стр. 199–254.
^Shapiro, Ehud Y. . Algorithmic program debugging. Cambridge, Mass. . MIT Press. 1983. ISBN978-0-262-19218-7.
^Shapiro, Ehud Y. "The model inference system." Proceedings of the 7th international joint conference on Artificial intelligence-Volume 2. Morgan Kaufmann Publishers Inc., 1981.
^Luc De Raedt. A Perspective on Inductive Logic Programming. The Workshop on Current and Future Trends in Logic Programming, Shakertown, to appear in Springer LNCS, 1999. CiteSeerX: 10.1.1.56.1790
^ абвMuggleton, S. (1991). „Inductive logic programming”. New Generation Computing. 8 (4): 295—318. doi:10.1007/BF03037089.
^Džeroski, Sašo (1996), „Inductive Logic Programming and Knowledge Discovery in Databases”, Ур.: Fayyad, U.M.; Piatetsky-Shapiro, G.; Smith, P.; Uthurusamy, R., Advances in Knowledge Discovery and Data Mining, MIT Press, стр. 117—152; here: Sect.5.2.4
^Plotkin, Gordon D. (1970). Meltzer, B.; Michie, D., ур. „A Note on Inductive Generalization”. Machine Intelligence. Edinburgh University Press. 5: 153—163.
^Plotkin, Gordon D. (1971). Meltzer, B.; Michie, D., ур. „A Further Note on Inductive Generalization”. Machine Intelligence. Edinburgh University Press. 6: 101—124.
^i.e. sharing the same predicate symbol and negated/unnegated status
^in general: -tuple when positive example literals are given
^Ray, O., Broda, K., & Russo, A. M. (2003). Hybrid abductive inductive learning. In LNCS: Vol. 2835. Proceedings of the 13th international conference on inductive logic programming (pp. 311–328). Berlin: Springer.
^Kimber, T., Broda, K., & Russo, A. (2009). Induction on failure: learning connected Horn theories. In LNCS: Vol. 5753. Proceedings of the 10th international conference on logic programing and nonmonotonic reasoning (pp. 169–181). Berlin: Springer.
^Akihiro Yamamoto. Which hypotheses can be found with inverse entailment? In Inductive Logic Programming, pages 296–308. Springer, 1997.
^ абTimothy Kimber. Learning definite and normal logic programs by induction on failure. PhD thesis, Imperial College London, 2012.
^David Toth (2014). Imparo is complete by inverse subsumption. arXiv:1407.3836
Muggleton, S.; De Raedt, L. (1994). „Inductive Logic Programming: Theory and methods”. The Journal of Logic Programming. 19-20: 629—679. doi:10.1016/0743-1066(94)90035-3.