Erinevus lehekülje "Loogiline programmeerimine (2018)" redaktsioonide vahel
(Evelin teisaldas lehekülje Loogiline programmeerimine pealkirja Loogiline programmeerimine (2017) alla) |
|||
1. rida: | 1. rida: | ||
− | #suuna [[Loogiline programmeerimine (2017)]] | + | <!-- #suuna [[Loogiline programmeerimine (2015)]] --> |
+ | |||
+ | '''Ainekood''': ITI0021<br> | ||
+ | '''Link''': http://courses.cs.ttu.ee/pages/ITI0021<br> | ||
+ | |||
+ | '''Õppejõud''': prof. Jüri Vain<br> | ||
+ | '''Kontakt''': juri.vain ätt ttu.ee, ICT-418, Vastuvõtu aeg: esmaspäeval kl. 16:00 - 17:00 eelneval kokkuleppel e-maili kaudu<br> | ||
+ | |||
+ | |||
+ | <!-- Kursus varasematel aastatel: [[Loogiline programmeerimine (2014)]] [http://vana.cs.ttu.ee/tiki-index.php?page=ITI0020 2013]<br> --> | ||
+ | |||
+ | Kursus varasematel aastatel: [[Loogiline programmeerimine (2015)| Sügis 2015]] | ||
+ | |||
+ | ==Sügis 2017== | ||
+ | |||
+ | |||
+ | ==NB!<span style="color: red; font-weight: bold;"> Praktikumide järelkaitsmine toimub 9. jaanuaril kell 10.00 (ICT-401)== | ||
+ | |||
+ | ==NB!<span style="color: red; font-weight: bold;"> Kontrolltööde järeltööd s.h. koondtest 16. jaanuaril kell 10.00 (ICT-411)== | ||
+ | |||
+ | * Loeng: Teisipäeval kl. 10:00 - 11:30 ruumis U02-102 (õppejõud prof. Jüri Vain) | ||
+ | * Praktikumid ruumis ICT-401: (õppejõud: prof. Jüri Vain, Sven Nõmm, Evelin Halling) | ||
+ | ** IAPB51, IAPB52, IAPB53, IAPB54, IAPB55 | ||
+ | *** Rühm A: Teisipäeval kl. 12:00-13:30 | ||
+ | *** Rühm B: Teisipäeval kl. 14:00-15:30 | ||
+ | *** Rühm C: Teisipäeval kl. 16:00-17:30 | ||
+ | |||
+ | |||
+ | <!-- | ||
+ | * '''Eksam''' | ||
+ | ** '''07.01.2016, kell 10.00 Akadeemia tee 15A ruumis ICT-411''' | ||
+ | ** '''14.01.2016, kell 10.00 Akadeemia tee 15A ruumis ICT-411 (NB! vastu tulles paljudele soovidele on viimase eksami aeg nihutatud 14-ndalt 21-le jaanuarile)''' | ||
+ | * '''Programmeerimistööde kaitsmine''' | ||
+ | ** '''07.01.2015, kell 10.00 - 12.00 Akadeemia tee 15A ruumis ICT-403''' | ||
+ | ** '''21.01.2015, kell 10.00 - 12.00 Akadeemia tee 15A ruumis ICT-403''' | ||
+ | --> | ||
+ | |||
+ | ==Hindamiskriteeriumid== | ||
+ | * [[Media:Hindamiskriteeriumid2017Sest.pdf|HINDAMISKRITEERIUMID vt siit]] | ||
+ | <!--* Hindelise arvestuse eelduseks on praktikumitööde (10 praktikumi) ja kodutöö esitamine ning kontrolltööde (3 kontrolltööd) sooritamine. | ||
+ | * Praktikumi- ja kodutööd tuleb panna GIT-i ja kaitsta praktikumi ajal TTÜ arvutiklassis. E-postiga saadetud töid ei arvestata. | ||
+ | * Praktikumi ülesanded: 10 tk - tähtaegselt esitatud ülesanne 1 p, pärast tähtaega 0 p (Kokku max: 10 p) | ||
+ | * Kodutöö - Kabe programmi programmeerimine - 10 p | ||
+ | ** Võimalikud boonuspunktid | ||
+ | * Kontrolltööd (3 tk - kokku 80 p) | ||
+ | ** Kontrolltöö 1 - põhimõisted 30 p | ||
+ | ** Kontrolltöö 2 - rekursiooni programmeerimine 30 p | ||
+ | ** Kontrolltöö 3 - teadmiste esitamine Prologis 20 p | ||
+ | |||
+ | <!-- | ||
+ | * Arvestusel osalemine ei ole kohustuslik nendele, kes on edukalt kaitsnud praktikumitööd ja kodutöö ning sooritanud 3 testi igaüks tulemusega 60 p ja enam. | ||
+ | --> | ||
+ | * Järeltööd kontrolltöödele 1-3 toimuvad semestri viimaste loengute aegadel | ||
+ | ** 12.12.2017 järeltööd kontrolltööle 1 ja kontrolltööle 2 | ||
+ | ** 19.12.2017 järeltööd kontrolltööle 2 ja kontrolltööle 3 | ||
+ | * Järeltööde sooritamise tingimused: | ||
+ | ** Esimesel katsel tuleb teha järeltööd konkreetselt sellele tööle, mille tulemus oli alla 51%. | ||
+ | ** Kui ka järeltöö ebaõnnestub, tuleb sooritada koondtöö kursuse kogu materjali peale. | ||
+ | |||
+ | * Arvestuse hinnet tõstab see, kui kodutööna valminud kabeprogramm saavutab viimase praktikumi ajal toimuval võistlusel auhinnalise koha: I koht +3 (mod 5) palli; II koht +2(mod 5) palli; III koht +1(mod 5) pall. | ||
+ | |||
+ | * '''Testide ja praktikumide jooksvad tulemused asuvad Moodles (ained.ttu.ee)''' | ||
+ | |||
+ | ==Loengud== | ||
+ | * [[Media:ITI0021_Loeng 1_2017.pdf|Loeng 1]]: Mis on loogiline programmeerimine? | ||
+ | * [[Media:ITI0021_Loeng_2_1_2015.pdf|Loeng 2.1]]: Loogika alusmõisted: lauseloogika | ||
+ | * [[Media:ITI0021_Loeng_2_2_2015.pdf|Loeng 2.2]]: Loogika alusmõisted: predikaatloogika | ||
+ | * [[Media:ITI0021_Loeng_2 2016.pdf|Loeng 3]]: Loogilise programmeerimise keel Prolog | ||
+ | * [[Media:ITI0021_Loeng_3_2015.pdf|Loeng 4]]: Resolutsioon ja unifitseerimine | ||
+ | * [[Media:ITI0021_Loeng_4_2015.pdf|Loeng 5]]: Prologi andmestruktuurid: listid, freimid (lisamaterjal [http://www.learnprolognow.org/lpnpage.php?pageid=teaching] vt Chapter 10) | ||
+ | * '''Kontrolltöö 1 (10.10.2017):''' Loengute 1-4 materjalile: teadmiste formaliseerimine 1st järku predikaatloogikas, Horni lause, resolutsioon, unifitseerimine, mgu, literaal, term, rekursiivne reegel,lihtsamate päringute ja rekursiivsete reeglite koostamine. | ||
+ | * [[Media:ITI0021_Loeng_6_2016.pdf|Loeng 6]]: Hulgateooria ja algebra mõistete programmeerimine | ||
+ | * [[Media:ITI0021_Loeng_7_2016.pdf|Loeng 7]]: Prolog programmi täitmine ja täitmise juhtimine | ||
+ | <!-- * <span style="color: red; font-weight: bold;"> '''Loengu (31.10.17) ajal toimub harjutus Kontrolltööks 2. ''' Teema: Rekursiooni ja tagasivõtuga otsingu programmeerimine </span> | ||
+ | --> | ||
+ | * '''Kontrolltöö 2 (7.11.2017):''' Loengute 5, 6 ja 7 materjalile: rekursioon, listid, rekursiivsed reeglid listidel, otsingu juhtimine | ||
+ | * [[Media:ITI0021_Loeng_8_2016.pdf|Loeng 8]]: DCG grammatika reeglid ja loomuliku keele parsimine (lisamaterjal [http://www.learnprolognow.org/slides/official/LPNchapter7.pdf] ja[http://www.learnprolognow.org/slides/official/LPNchapter8.pdf] | ||
+ | * [[Media:ITI0021_Loeng_9_2017.pdf|Loeng 9]]: Mängu ja otsingustrateegiate programmeerimine | ||
+ | * Loeng 10: Prologi liidestamine C ja Java programmidega | ||
+ | * Loeng 11: Tehisintellekti algoritmide programmeerimine Prologis | ||
+ | * '''Kontrolltöö 3 (05.12.2017):''' Loengute 5,6,7,8,9 materjalile | ||
+ | |||
+ | ** Algebra ja hulgateooria mõisted | ||
+ | ** DCG grammatikareeglid, reeglite Prologi sisekuju | ||
+ | ** Programmeerimisülesanded: otsingu juhtimine predikaatide repeat, fail ja cut abil (vt. Praktikum PR10 juhendit). | ||
+ | <!-- | ||
+ | * (15.12.2016) '''Kontrolltööde 1 ja 2 järeltööd''' | ||
+ | * (22.12.2016) '''Kontrolltöö 3 järeltöö''' | ||
+ | * (12.01.2017) '''Järeltööde sooritamise lisaaeg I''' | ||
+ | * (19.01.2017) '''Järeltööde sooritamise lisaaeg II''' | ||
+ | |||
+ | * | ||
+ | * [[Media:Loeng_5.pdf|Loeng 5]]:Loogilise programmeerimise andmestrutuurid | ||
+ | * [[Media:ITI0021_Loeng_7.pdf|Loeng 6]]: Hulgateooria ja algebra mõistete programmeerimine Prologis | ||
+ | * Test 2 (29.10.2014): Listioperatsioonide programmeerimine rekursiooni abil | ||
+ | * [[Media:ITI0021_Loeng_9.pdf|Loeng 9]]: Loogikate LA ja CTL interpreteerimine | ||
+ | * [[Media:ITI0021_Lecture_10.pdf|Loeng 10]]: Constraint Logic Programming | ||
+ | * Test 3 (26.11.2014): Loengute 6-9 materjal | ||
+ | * Järeltöö I (03.12.2014) | ||
+ | * Järeltöö II (10.12.2014) | ||
+ | |||
+ | --> | ||
+ | |||
+ | <!-- * Loeng 4: Test 1: Loogilise programmeerimise põhimõisted | ||
+ | * Loogilise programmeerimise andmestruktuurid | ||
+ | * Hulgateooria ja algebra mõistete programmeerimine Prologis | ||
+ | * DCG grammatika reeglid ja loomuliku keele parsimine | ||
+ | * Loeng 9: Listioperatsioonide programmeerimine rekursiooni abil (harjutus Test2-ks) | ||
+ | * Loeng 10: Test 2: Listioperatsioonide programmeerimine rekursiooni abil | ||
+ | * Predikaat- ja temporaalloogika valemite interpreteerimine | ||
+ | * Prologi integreerimine teiste programmeerimiskeelte ja keskkondadega | ||
+ | * Kitsendustega loogiline programmeerimine | ||
+ | * Loeng 14: Test 3: Loengute 6-8,11-13 materjal | ||
+ | * Loeng 15: Testide 1 ja 2 järeltööd | ||
+ | * Loeng 16: Koondjäreltöö * --> | ||
+ | |||
+ | ==Praktikumid== | ||
+ | Praktikumides kasutame SWI-Prologi [http://www.swi-prolog.org/ SWI-Prolog]. | ||
+ | |||
+ | Eclipse plugin: [http://sewiki.iai.uni-bonn.de/research/pdt/docs/start Prolog Development Tool - PDT]. | ||
+ | * Installeerimise juhend: [http://sewiki.iai.uni-bonn.de/research/pdt/docs/download] | ||
+ | * Kasutusjuhend: [http://sewiki.iai.uni-bonn.de/research/pdt/docs/getting_started] | ||
+ | |||
+ | <!-- | ||
+ | GIT URI: https://teie-ttu-uni-id-kasutajanimi@git.ttu.ee/ained/iti0021/teie-ttu-uni-id-kasutajanimi.git (NB! see link brauseris ei tööta!). NB! Uni-ID kasutajanimes peavad olema '''KÕIK VÄIKESED TÄHED!''' | ||
+ | |||
+ | [[ITI0011:git|Giti juhend Eclipse'is kasutamiseks]] | ||
+ | --> | ||
+ | '''GIT''' | ||
+ | |||
+ | Mine aadressile https://gitlab.cs.ttu.ee/ ja logi sisse oma UNI-ID kasutajanimega. | ||
+ | |||
+ | |||
+ | Loo endale projekt nimega "iti0021" (NB!! Väikesed tähed). | ||
+ | https://gitlab.cs.ttu.ee/dashboard/projects -> "New Project". Visibility las olla "private". | ||
+ | |||
+ | |||
+ | Kui projekt tehtud, siis mine üleval menüüst "Members". | ||
+ | Lisa kasutajatena 'hodor-live' ja 'Evelin.Halling'. Määra "access level" "Developer". | ||
+ | Nüüd saavad kursuse õppejõud sinu repole ligi. Samuti saab sinu repole ligi tester. | ||
+ | |||
+ | |||
+ | Lisa webhook. Ülevalt "Settings" -> "Integrations". Sinna kirjuta | ||
+ | URL: https://ained.ttu.ee/mod/charon/api/git_callback | ||
+ | Jäta peale "Push events" | ||
+ | Võta maha linnuke "Enable SSL verification" | ||
+ | Nüüd nupp "Add webhook" | ||
+ | |||
+ | |||
+ | Praktikumi ülesanded tuleb laadida mainitud tähtajaks git'i vastavasse kausta (PR0x, kus x on praktikumi number [1, 2, 3, 4]). Kaustas peab olema fail nimega prax0x.pl (kus x on praktikumi number [1, 2, 3, 4]). Kaustas võib olla ka teisi faile, mis imporditakse prax0x.pl poolt. | ||
+ | |||
+ | * Praktikum 1: Tutvumine loogilise programmeerimise keskkonnaga [http://www.swi-prolog.org/ SWI-Prolog] | ||
+ | ** [[Media:ITI0021_Praktikum_1_juhend.pdf|Praktikumi 1 juhend]] | ||
+ | ** Näidismaterjal: [[Media:ITI0021_Praktikum_1.pdf|Objektid ja nende omadused]] | ||
+ | ** NB! Seda ülesannet ei tule laadida git-i | ||
+ | |||
+ | * Praktikum 2: Prologi teadmusbaasi koostamine PR02 | ||
+ | ** [[Media:ITI0021_Praktikum_2_juhend.pdf|Praktikumi 2 juhend]] | ||
+ | |||
+ | * Praktikum 3: Rekursioon PR03 | ||
+ | ** [[Media:ITI0021_Praktikum_PR03_juhend_2016.pdf|Praktikumi 3 juhend]] | ||
+ | |||
+ | * Praktikum 4: Rekursioon PR04 | ||
+ | ** [[Media:ITI0021_Praktikum_PR04_juhend_2016.pdf|Praktikumi 4 juhend]] | ||
+ | ** Näidismaterjal: [[Media:ITI0021_praktikum_PR04_näited_2016.pl|Klassid ja pärimine]] | ||
+ | ** Lisamaterjal: [[Media:ITI0021_praktikum_PR04_isco_klassifikaatorid.xls |ISCO ametite klassifikatsioon]] | ||
+ | |||
+ | * Praktikum PR05: Listid | ||
+ | ** [[Media:ITI0021_Praktikum_PR06_juhend_2016.pdf|Praktikumi PR05 juhend]] | ||
+ | |||
+ | * Praktikum PR06: Semantilised võrgud ja freimid | ||
+ | ** [[Media:ITI0021_praktikumi_7_juhend_2015.pdf|Praktikumi PR06 juhend]] | ||
+ | ** Näidismaterjal: [[Media:ITI_0021_praktikum_7_näited.pl|Klassid ja pärimine]] | ||
+ | |||
+ | * Praktikum PR07: Hulgateoreetilised tehted | ||
+ | ** [[Media:ITI0021_Praktikum_PR07_juhend_2016.pdf|Praktikumi PR07 juhend]] | ||
+ | |||
+ | * Praktikum PR08: Otsingu juhtimine | ||
+ | ** [[Media:ITI0021_Praktikum_PR08_juhend_2016.pdf|Praktikumi PR08 juhend]] | ||
+ | |||
+ | * Praktikum PR09: Reisi marsuudi leidimine | ||
+ | ** [[Media:ITI0021_Praktikum_PR09_juhend_2017.pdf|Praktikumi PR09 juhend]] | ||
+ | |||
+ | * Praktikum PR10: DCG grammatika ja loomuliku keele interpreteerimine | ||
+ | ** [[Media:ITI0021_Praktikum_PR09_juhend_2016.pdf|Praktikumi PR10 juhend]] | ||
+ | |||
+ | * Praktikum PR11: Faktide hulgal otsingu programmeerimine | ||
+ | ** [[Media:ITI0021_Praktikum_PR10_juhend_2016.pdf|Praktikumi PR11 juhend]] | ||
+ | ** Näidismaterjal: [[Media:ITI0021_Praktikum_9_kabe_2015.pl|Otsing kabe näitel]] | ||
+ | ** Tuleb implementeerida predikaadid 'vota' ja 'tee_kaik' | ||
+ | |||
+ | * Praktikum PR12: Tammi programmeerimine | ||
+ | ** Programmeerida Tammi käigud. Kasuta eelmises praktikumis (Praktikumis PR11) loodud kabe programmi. | ||
+ | ** Tammi käikude programmeerimise algoritm on toodud kodutöö ülesande kirjelduses. | ||
+ | ** predikaat 'kaigu_variandid' peab toetama tammiga käimist ja võtmist | ||
+ | |||
+ | <!-- | ||
+ | * Praktikum PR12: ALEPH algoritm (A Learning Engine for Proposing Hypotheses) | ||
+ | ** [[Media:ITI0021_Praktikum_PR12_juhend_2016.pdf|Praktikumi PR12 juhend]] | ||
+ | |||
+ | |||
+ | * Praktikum 5: Listid | ||
+ | ** [[Media:ITI0021_Praktikum_5_juhend_2015.pdf|Praktikumi 5 juhend]] | ||
+ | |||
+ | |||
+ | |||
+ | * Praktikum 7: Semantilised võrgud ja freimid | ||
+ | ** [[Media:ITI0021_praktikumi_7_juhend_2015.pdf|Praktikumi 7 juhend]] | ||
+ | ** Näidismaterjal: [[Media:ITI_0021_praktikum_7_näited.pl|Klassid ja pärimine]] | ||
+ | *Praktikum 8: DCG grammatika ja loomuliku keele interpreteerimine | ||
+ | ** [[Media:ITI0021_Praktikum_8_juhend_2015.pdf|Praktikumi 8 juhend]] | ||
+ | * Praktikum 9: Faktide hulgal otsingu programmeerimine | ||
+ | ** [[Media:ITI0021_Praktikum_9_juhend_2015.pdf|Praktikumi 9 juhend]] | ||
+ | ** Näidismaterjal: [[Media:ITI0021_Praktikum_9_kabe_2015.pl|Otsing kabe näitel]] | ||
+ | ** Programm [[Media:arbiiter.pl |Arbiiter juhib mängu]] | ||
+ | * Praktikum 10: Tammi programmeerimine | ||
+ | ** Programmeerida Tammi käigud. Kasuta eelmises praktikumis (Praktikumis 9) loodud kabe programmi. | ||
+ | ** Tammi käikude programmeerimise algoritm on toodud kodutöö ülesande kirjelduses. | ||
+ | ** [[Media: Kodutöö_kabe_2013.pdf |Kodutöö tööülesande kirjeldus]] | ||
+ | * Praktikum 11: Tammi programmeerimine | ||
+ | ** Jätkub Tammi programmeerimine (Praktikum 10). Uut ülesannet ei anta. | ||
+ | * Praktikum 12: CTL valemite interpreteerimine | ||
+ | ** [[Media: Praktikum_12_juhend_2015.pdf |"Eventuality" valemid ja Kripke struktuur]] . | ||
+ | * Praktikum 13 (20.11.2015): Iseseisev töö koduülesandega: Kabe programmeerimine | ||
+ | * Praktikum 14 (27.11.2015): Iseseisev töö koduülesandega: Kabe programmeerimine | ||
+ | * Praktikum 15 (03.12.2015): Võimalus kaitsta varasemaid praktikumiülesandeid | ||
+ | * Praktikum 16 (10.12.2015): Võimalus kaitsta varasemaid praktikumiülesandeid ja konsultatsioonid kodutöö osas | ||
+ | * (17.12.2015): Kodutööde kaitsmine ja kabeprogrammide võistlus | ||
+ | --> | ||
+ | |||
+ | <!-- | ||
+ | ** Näidismaterjal: [[Media:ITI0021_Praktikum_2.pl|Tea'''Ainekood''': ITI0021<br> | ||
+ | '''Link''': http://courses.cs.ttu.ee/pages/ITI0021<br> | ||
+ | |||
+ | '''Õppejõud''': prof. Jüri Vain<br> | ||
+ | '''Kontakt''': juri.vain ätt ttu.ee, ICT-418, Vastuvõtu aeg: esmaspäeval kl. 16:00 - 17:00 eelneval kokkuleppel e-maili kaudu<br> | ||
+ | |||
+ | |||
+ | <!-- Kursus varasematel aastatel: [[Loogiline programmeerimine (2014)]] [http://vana.cs.ttu.ee/tiki-index.php?page=ITI0020 2013]<br> --> | ||
+ | |||
+ | ==Kodutöö 2017== | ||
+ | * Kodutööks on kabeprogrammi programmeerimine Prologis | ||
+ | * Kood laadida git-i salve: KABE | ||
+ | * Kabe | ||
+ | ** [[Media: Kodutöö_kabe2015.pdf|Tööülesande kirjeldus]] | ||
+ | ** Mängu üldkirjeldus: [https://en.wikipedia.org/wiki/Russian_draughts] | ||
+ | ** Ametlikud võistlusreeglid:[http://fmjd64.org/rules-of-the-game/] | ||
+ | |||
+ | ** Graafiline Arbiiter: | ||
+ | *** [[Media:GraphicArbiter.zip |Arbiiter (Graafiline)]] | ||
+ | |||
+ | ** Programm Arbiiter juhib mängu. | ||
+ | *** Arbiiter UTF-8 kodeeringus:[[Media:arbiiterutf32.zip |Arbiiter (Prolog32)]] | ||
+ | *** Arbiiter UTF-8 kodeeringus:[[Media:arbiiterutf64.zip |Arbiiter (Prolog64)]] | ||
+ | *** Arbiiter turniiriks:[[Media:arbiiter_1.zip |Arbiiter (Prolog64)]] | ||
+ | *** Arbiiter arendus:[[Media:arbiiter_arendus.zip |Arbiiter (Arendus)]] | ||
+ | |||
+ | |||
+ | <!-- | ||
+ | ** Programm [[Media:kabeprogramm.pl | Näidisprogramm]]<br> | ||
+ | --> | ||
+ | Kodutöö esitamise tähtaeg on eelviimane ja viimane praktikum, mil toimub kabeturniir (programmikood panna moodle-sse) | ||
+ | |||
+ | ==Lisamaterjalid== | ||
+ | * [http://www.learnprolognow.org/lpnpage.php?pageid=top Learn Prolog Now] | ||
+ | * [http://www.youtube.com/watch?v=09zlcS49zL0 Web Testing with Logic Programming - Daniel Gregoire] | ||
+ | * [https://www.amzistore.com/dcm_bookstore.php Uut lugemist Prologis ja selle rakendustest!] [[Pilt:Näidis.jpg]] |
Redaktsioon: 3. september 2018, kell 07:34
Ainekood: ITI0021
Link: http://courses.cs.ttu.ee/pages/ITI0021
Õppejõud: prof. Jüri Vain
Kontakt: juri.vain ätt ttu.ee, ICT-418, Vastuvõtu aeg: esmaspäeval kl. 16:00 - 17:00 eelneval kokkuleppel e-maili kaudu
Kursus varasematel aastatel: Sügis 2015
Sügis 2017
NB! Praktikumide järelkaitsmine toimub 9. jaanuaril kell 10.00 (ICT-401)
NB! Kontrolltööde järeltööd s.h. koondtest 16. jaanuaril kell 10.00 (ICT-411)
- Loeng: Teisipäeval kl. 10:00 - 11:30 ruumis U02-102 (õppejõud prof. Jüri Vain)
- Praktikumid ruumis ICT-401: (õppejõud: prof. Jüri Vain, Sven Nõmm, Evelin Halling)
- IAPB51, IAPB52, IAPB53, IAPB54, IAPB55
- Rühm A: Teisipäeval kl. 12:00-13:30
- Rühm B: Teisipäeval kl. 14:00-15:30
- Rühm C: Teisipäeval kl. 16:00-17:30
- IAPB51, IAPB52, IAPB53, IAPB54, IAPB55
Hindamiskriteeriumid
- HINDAMISKRITEERIUMID vt siit
- Järeltööd kontrolltöödele 1-3 toimuvad semestri viimaste loengute aegadel
- 12.12.2017 järeltööd kontrolltööle 1 ja kontrolltööle 2
- 19.12.2017 järeltööd kontrolltööle 2 ja kontrolltööle 3
- Järeltööde sooritamise tingimused:
- Esimesel katsel tuleb teha järeltööd konkreetselt sellele tööle, mille tulemus oli alla 51%.
- Kui ka järeltöö ebaõnnestub, tuleb sooritada koondtöö kursuse kogu materjali peale.
- Arvestuse hinnet tõstab see, kui kodutööna valminud kabeprogramm saavutab viimase praktikumi ajal toimuval võistlusel auhinnalise koha: I koht +3 (mod 5) palli; II koht +2(mod 5) palli; III koht +1(mod 5) pall.
- Testide ja praktikumide jooksvad tulemused asuvad Moodles (ained.ttu.ee)
Loengud
- Loeng 1: Mis on loogiline programmeerimine?
- Loeng 2.1: Loogika alusmõisted: lauseloogika
- Loeng 2.2: Loogika alusmõisted: predikaatloogika
- Loeng 3: Loogilise programmeerimise keel Prolog
- Loeng 4: Resolutsioon ja unifitseerimine
- Loeng 5: Prologi andmestruktuurid: listid, freimid (lisamaterjal [1] vt Chapter 10)
- Kontrolltöö 1 (10.10.2017): Loengute 1-4 materjalile: teadmiste formaliseerimine 1st järku predikaatloogikas, Horni lause, resolutsioon, unifitseerimine, mgu, literaal, term, rekursiivne reegel,lihtsamate päringute ja rekursiivsete reeglite koostamine.
- Loeng 6: Hulgateooria ja algebra mõistete programmeerimine
- Loeng 7: Prolog programmi täitmine ja täitmise juhtimine
- Kontrolltöö 2 (7.11.2017): Loengute 5, 6 ja 7 materjalile: rekursioon, listid, rekursiivsed reeglid listidel, otsingu juhtimine
- Loeng 8: DCG grammatika reeglid ja loomuliku keele parsimine (lisamaterjal [2] ja[3]
- Loeng 9: Mängu ja otsingustrateegiate programmeerimine
- Loeng 10: Prologi liidestamine C ja Java programmidega
- Loeng 11: Tehisintellekti algoritmide programmeerimine Prologis
- Kontrolltöö 3 (05.12.2017): Loengute 5,6,7,8,9 materjalile
- Algebra ja hulgateooria mõisted
- DCG grammatikareeglid, reeglite Prologi sisekuju
- Programmeerimisülesanded: otsingu juhtimine predikaatide repeat, fail ja cut abil (vt. Praktikum PR10 juhendit).
Praktikumid
Praktikumides kasutame SWI-Prologi SWI-Prolog.
Eclipse plugin: Prolog Development Tool - PDT.
GIT
Mine aadressile https://gitlab.cs.ttu.ee/ ja logi sisse oma UNI-ID kasutajanimega.
Loo endale projekt nimega "iti0021" (NB!! Väikesed tähed).
https://gitlab.cs.ttu.ee/dashboard/projects -> "New Project". Visibility las olla "private".
Kui projekt tehtud, siis mine üleval menüüst "Members".
Lisa kasutajatena 'hodor-live' ja 'Evelin.Halling'. Määra "access level" "Developer".
Nüüd saavad kursuse õppejõud sinu repole ligi. Samuti saab sinu repole ligi tester.
Lisa webhook. Ülevalt "Settings" -> "Integrations". Sinna kirjuta
URL: https://ained.ttu.ee/mod/charon/api/git_callback
Jäta peale "Push events"
Võta maha linnuke "Enable SSL verification"
Nüüd nupp "Add webhook"
Praktikumi ülesanded tuleb laadida mainitud tähtajaks git'i vastavasse kausta (PR0x, kus x on praktikumi number [1, 2, 3, 4]). Kaustas peab olema fail nimega prax0x.pl (kus x on praktikumi number [1, 2, 3, 4]). Kaustas võib olla ka teisi faile, mis imporditakse prax0x.pl poolt.
- Praktikum 1: Tutvumine loogilise programmeerimise keskkonnaga SWI-Prolog
- Praktikumi 1 juhend
- Näidismaterjal: Objektid ja nende omadused
- NB! Seda ülesannet ei tule laadida git-i
- Praktikum 2: Prologi teadmusbaasi koostamine PR02
- Praktikum 3: Rekursioon PR03
- Praktikum 4: Rekursioon PR04
- Praktikumi 4 juhend
- Näidismaterjal: Klassid ja pärimine
- Lisamaterjal: ISCO ametite klassifikatsioon
- Praktikum PR05: Listid
- Praktikum PR06: Semantilised võrgud ja freimid
- Praktikumi PR06 juhend
- Näidismaterjal: Klassid ja pärimine
- Praktikum PR07: Hulgateoreetilised tehted
- Praktikum PR08: Otsingu juhtimine
- Praktikum PR09: Reisi marsuudi leidimine
- Praktikum PR10: DCG grammatika ja loomuliku keele interpreteerimine
- Praktikum PR11: Faktide hulgal otsingu programmeerimine
- Praktikumi PR11 juhend
- Näidismaterjal: Otsing kabe näitel
- Tuleb implementeerida predikaadid 'vota' ja 'tee_kaik'
- Praktikum PR12: Tammi programmeerimine
- Programmeerida Tammi käigud. Kasuta eelmises praktikumis (Praktikumis PR11) loodud kabe programmi.
- Tammi käikude programmeerimise algoritm on toodud kodutöö ülesande kirjelduses.
- predikaat 'kaigu_variandid' peab toetama tammiga käimist ja võtmist
Kodutöö 2017
- Kodutööks on kabeprogrammi programmeerimine Prologis
- Kood laadida git-i salve: KABE
- Kabe
- Tööülesande kirjeldus
- Mängu üldkirjeldus: [6]
- Ametlikud võistlusreeglid:[7]
- Graafiline Arbiiter:
- Programm Arbiiter juhib mängu.
- Arbiiter UTF-8 kodeeringus:Arbiiter (Prolog32)
- Arbiiter UTF-8 kodeeringus:Arbiiter (Prolog64)
- Arbiiter turniiriks:Arbiiter (Prolog64)
- Arbiiter arendus:Arbiiter (Arendus)
- Programm Arbiiter juhib mängu.
Kodutöö esitamise tähtaeg on eelviimane ja viimane praktikum, mil toimub kabeturniir (programmikood panna moodle-sse)