<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
		<id>https://strudel.pld.ttu.ee/wiki/e/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Hkinks</id>
		<title>ATI public wiki - User contributions [en]</title>
		<link rel="self" type="application/atom+xml" href="https://strudel.pld.ttu.ee/wiki/e/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Hkinks"/>
		<link rel="alternate" type="text/html" href="https://strudel.pld.ttu.ee/wiki/e/index.php/Special:Contributions/Hkinks"/>
		<updated>2026-05-20T15:12:10Z</updated>
		<subtitle>User contributions</subtitle>
		<generator>MediaWiki 1.26.4</generator>

	<entry>
		<id>https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAX0583_-_Programmeerimine_I&amp;diff=2537</id>
		<title>IAX0583 - Programmeerimine I</title>
		<link rel="alternate" type="text/html" href="https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAX0583_-_Programmeerimine_I&amp;diff=2537"/>
				<updated>2017-09-14T11:34:41Z</updated>
		
		<summary type="html">&lt;p&gt;Hkinks: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[IAG0581 - Programming I|In English]] [[File:United Kingdom.png | 32px | link=IAG0581 - Programming I]]&lt;br /&gt;
== Viited == &lt;br /&gt;
* [https://ois.ttu.ee/portal/page?_pageid=35,428610&amp;amp;_dad=portal&amp;amp;_schema=PORTAL&amp;amp;p_msg=&amp;amp;p_public=1&amp;amp;p_what=1&amp;amp;p_lang=ET&amp;amp;p_open_node2=&amp;amp;p_id=100807&amp;amp;p_mode=1&amp;amp;p_pageid=OKM_AINE_WEB_OTSING&amp;amp;_ainer_kood=iag0581 Ainekaart]&lt;br /&gt;
* [http://ati.ttu.ee/index.php?page=4110&amp;amp;aine=IAG0581 Aine leht TTÜ lehel]&lt;br /&gt;
* '''[https://docs.google.com/document/d/1uf-X2HZC73b0U4mVBCY7D9wrrgBvu5UtlQJ5yvSJ90I/pub Teated]'''&lt;br /&gt;
* '''[https://docs.google.com/spreadsheets/d/1MSrsvUsdJUbMzJ5MYUwNSj0BjIJKyZVvDaLv8uKlTMM/pubhtml?gid=882379455&amp;amp;single=true Tulemused]'''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* [http://ati.ttu.ee/wiki/index.php/Git_manual Git manual EN]&lt;br /&gt;
&lt;br /&gt;
=== Materjalid ===&lt;br /&gt;
==== Aine õppejõudude materjalid ====&lt;br /&gt;
[http://www.tud.ttu.ee/im/Vladimir.Viies/materials/IAX0583%2cIAG0581%2cIAG0582%2cPROGRAMMEERIMINE/ Vladimir Viies]&lt;br /&gt;
&lt;br /&gt;
[http://www.blue.pri.ee/ttu/programmeerimine-i/ Risto Heinsar]&lt;br /&gt;
&lt;br /&gt;
====Vanad materjalid====&lt;br /&gt;
[http://www.tud.ttu.ee/im/Vladimir.Viies/materials/Helena_materjalid/iag0581/ Helena Kruus]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[IAG0581 - Programmeerimine I (2015)|Eelmise aasta materjalid]]&lt;br /&gt;
&lt;br /&gt;
==== Moodle materjalid ====&lt;br /&gt;
Ise registeerumisega kursususele &amp;quot;IAG0581 Programmeerimine I&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
https://moodle.e-ope.ee/&lt;br /&gt;
&lt;br /&gt;
==I Kodutöö ülesanne==&lt;br /&gt;
[http://ati.ttu.ee/~hkinks/iag0581/hw1/hw1_et.pdf Ülesande kirjeldus]&lt;br /&gt;
&lt;br /&gt;
[http://ati.ttu.ee/~hkinks/iag0581/hw1/hw1.html I kodutöö ülesande genereerimine ]&lt;br /&gt;
&lt;br /&gt;
[http://www.tud.ttu.ee/im/Vladimir.Viies/materials/T%d6%d6%20VORMISTAMINE.doc Vormistamisnõuded]&lt;br /&gt;
&lt;br /&gt;
[http://blue.pri.ee/ttu/koodimisstiil/ Koodimisstiil]&lt;br /&gt;
&lt;br /&gt;
I kodutöö tähtaeg on '''8. nädal'''. Esitades hiljem, läheb iga järgnev nädal puntkisummast maha 1 punkt.&lt;br /&gt;
&lt;br /&gt;
== Praktikumid ==&lt;br /&gt;
[https://docs.google.com/spreadsheets/d/1ggPGaLoDZTMfcEZGdBHwqsp22uVnHzeHVvmytX3-EuM/pubhtml?gid=558301184&amp;amp;single=true Tunnitöö punktitabel]&lt;br /&gt;
&lt;br /&gt;
Jooksvad pratkikumi materjalid tekivad GITi repositooriumi: &lt;br /&gt;
&lt;br /&gt;
http://gitlab.pld.ttu.ee/Hannes.Kinks/iag0581&lt;br /&gt;
&lt;br /&gt;
== Töö praktikumis ==&lt;br /&gt;
&lt;br /&gt;
Arvutiklassis töötamise kohta üldiselt: [[Arvutiklassis töötamise juhend]]&lt;br /&gt;
&lt;br /&gt;
Üksikasjalik kaugtöö juhend piltidega [http://ati.ttu.ee/wiki/images/Kaugtoo_juhend.pdf EST] [http://mini.li.ttu.ee/~priit/IAY0340.2013/ssh_setup/putty_guide.html ENG]&lt;br /&gt;
&lt;br /&gt;
Töö alustamisel terminalis on vaja paika seada töökeskkond käsuga '''cad'''&lt;br /&gt;
&lt;br /&gt;
=== Versioonihaldus ===&lt;br /&gt;
Praktikumitundides on kohustuslik kasutada oma koodi hoiustamiseks versioonihaldustarkvara Git ja hoiustada seda serveris&lt;br /&gt;
&lt;br /&gt;
'''[http://gitlab.pld.ttu.ee gitlab.pld.ttu.ee] '''&lt;br /&gt;
&lt;br /&gt;
Sisselogimiseks tuleks kasutada oma ülikooli Uni-ID kasutajat ja parooli. Kui te ei tea oma kasutajat või parooli, siis Uni-ID saamiseks või parooli vahetamiseks on järgmised võimalused:&lt;br /&gt;
*Logides sisse ID-kaardiga aadressil http://pass.ttu.ee&lt;br /&gt;
*Pöörduda ruumi ICT-410 või SOC-128&lt;br /&gt;
&lt;br /&gt;
Esmakordsel sisenemisel tuleks kõige pealt kursuse tarbeks luua oma projekt. Selleks tuleks vajutada nupul '''New project'''. &lt;br /&gt;
[[File:Git_create_project.png|200px|thumb|none|Nupp projekti loomiseks]]&lt;br /&gt;
Seejärel avaneval lehel tuleks oma projektile anda nimi '''iag0581'''. Lisaks tuleks veenduda, et projekti avalikuse seade on '''internal'''. &lt;br /&gt;
Vastav nimi ja avalik projekt on oluline selleks, et me leiaksime teie tehtud tööd üles. Lõpuks vajutage '''Create project'''. &lt;br /&gt;
[[File:Git_create_repo.png|200px|thumb|none|Projekti loomise leht]]&lt;br /&gt;
Sellega on repositoorium loodud.&lt;br /&gt;
&lt;br /&gt;
====Mis on Git?====&lt;br /&gt;
Git on enimkasutatav versioonihaldustarkvara, mis võimaldab hõlpsasti programmikoodi sisaldavaid projekte hallata. Git on väärtuslik tööriist just suurte projektide puhul, mis hõlmab palju erinevaid arendajaid, kuid on hea vahend ka väikeste projektide paremaks organiseerimiseks. Ta võimaldab meeles hoida ajalugu erinevatest projekti versioonidest ja arendusharudest ning neid liita vajadusel. &lt;br /&gt;
Giti repositoorium on lisaks üks variant oma programmi lähtekoodi avalikustamiseks või tehtud projektide portfoolio hoidmiseks.&lt;br /&gt;
Oma Giti repositooriumi hoidmiseks on erinevaid veebisaite, kus on võimalik oma koodi tasuta hoida. Näiteks: [https://github.com github], [https://bitbucket.org bitbucket], [https://gitlab.com gitlab].&lt;br /&gt;
&lt;br /&gt;
====Git-i allalaadimine====&lt;br /&gt;
Kõikides klassiarvutites on Git eelnevalt paigaldatud ja selle kasutamiseks tuleks avada lihtsalt terminal.&lt;br /&gt;
&lt;br /&gt;
Kodus kasutamiseks tuleks Git kõigepealt alla laadida lingilt &lt;br /&gt;
&lt;br /&gt;
https://git-scm.com/downloads&lt;br /&gt;
&lt;br /&gt;
Installeerimisel küsitavad sätted võib jätta vaikimisi nii nagu on.&lt;br /&gt;
&lt;br /&gt;
====Git-i kasutamine====&lt;br /&gt;
Alustada tuleks sellest, et avame terminali (või Git bash Windows-i puhul).&lt;br /&gt;
&lt;br /&gt;
===== Kloonimine =====&lt;br /&gt;
Eeldades, et Git-i repositoorium on tehtud (kui ei ole, vaata [[IAG0581 - Programmeerimine I#Versioonihaldus|Versioonihaldus]]), tuleks see kõigepealt omale kohalikku arvutisse alla kloonida. &lt;br /&gt;
Oletades, et teie Uni-ID on ''Heli.Kopter'', siis repositoorium peaks asuma ''http://gitlab.pld.ttu.ee/heli.kopter/iag0581.git'' ning selle alla kloonimiseks on käsk ''git clone'':&lt;br /&gt;
&amp;lt;source lang=&amp;quot;bash&amp;quot; collapse=&amp;quot;false&amp;quot;&amp;gt;git clone http://gitlab.pld.ttu.ee/heli.kopter/iag0581.git&amp;lt;/source&amp;gt;&lt;br /&gt;
Järgnevalt küsitakse teilt kasutajanime ja parooli. Nagu mainitud eelnevalt, siis selleks on teie Uni-ID. Lisaks, parooli sisestamisel ei maksa välja teha sellest, et tärne (*) ei teki parooli kohale - sisestus toimib sellegipoolest nagu peab.&lt;br /&gt;
Kui kasutaja ja parool klapivad, siis peaks esmakordsel kloonimisel tekkima sõnum&lt;br /&gt;
 warning: You appear to have clone and empty repository.&lt;br /&gt;
 Checking connectivity.. done.&lt;br /&gt;
Järgnevalt liigume äsja loodud kausta kasutades ''cd'' käsku (Change Directory).&lt;br /&gt;
&amp;lt;source lang=&amp;quot;bash&amp;quot; collapse=&amp;quot;false&amp;quot;&amp;gt;cd iag0581&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===== Staging area =====&lt;br /&gt;
Nüüd on võimalik meil kausta ''iag0581'' lisada faile. Kausta võiks organiseerida kaustadesse järgnevalt:&lt;br /&gt;
* Kodutöö 1&lt;br /&gt;
* Kodutöö 2&lt;br /&gt;
* Praktikum 1&lt;br /&gt;
* Praktikum 2&lt;br /&gt;
* ....&lt;br /&gt;
Alustame näiteks sellest, et laeme koduse töö kirjelduse alla lehelt http://ati.ttu.ee/~hkinks/iag0581/hw1/hw1_et.pdf ning paigutame selle esimese kodutöö kausta.&lt;br /&gt;
Järgmisena tuleks märku anda ka Gitile, et lisasime uue faili kasutades käsku ''git add &amp;lt;faili nimi&amp;gt;''. Lihtsaim viis lisamaks kõik failid, mille oleme lisanud on kasutada käsku:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;bash&amp;quot; collapse=&amp;quot;false&amp;quot;&amp;gt;git add .&amp;lt;/source&amp;gt;&lt;br /&gt;
Selleks, et veenduda kas Git tõepoolest sai sellest aru ja lisas, võime kirjutada &lt;br /&gt;
&amp;lt;source lang=&amp;quot;bash&amp;quot; collapse=&amp;quot;false&amp;quot;&amp;gt;git status&amp;lt;/source&amp;gt;&lt;br /&gt;
Selle peale peaks tulema vastus:&lt;br /&gt;
 $&amp;gt; git status&lt;br /&gt;
 On branch master&lt;br /&gt;
 &lt;br /&gt;
 Initial commit&lt;br /&gt;
 &lt;br /&gt;
 Changes to be committed:&lt;br /&gt;
   (use &amp;quot;git rm --cached &amp;lt;file&amp;gt;...&amp;quot; to unstage)&lt;br /&gt;
 &lt;br /&gt;
         new file:   Kodune1/hw1_et.pdf&lt;br /&gt;
&lt;br /&gt;
===== Commit =====&lt;br /&gt;
Järgmisena tuleks teha ''commit'', millega sisuliselt tekitame ühe versiooni oma repositooriumis olevatest failidest ja kuhu saame tulevikus tagasi pöörduda vajadusel.&lt;br /&gt;
&amp;lt;source lang=&amp;quot;bash&amp;quot; collapse=&amp;quot;false&amp;quot;&amp;gt;git commit -m &amp;quot;Kommentaar versiooni kohta, milliseid muudatusi tehti.&amp;quot;&amp;lt;/source&amp;gt;&lt;br /&gt;
 git commit -m &amp;quot;esimene commit&amp;quot;&lt;br /&gt;
 [master (root-commit) 630c631] esimene commit&lt;br /&gt;
  1 file changed, 0 insertions(+), 0 deletions(-)&lt;br /&gt;
  create mode 100644 Kodune1/hw1_et.pdf&lt;br /&gt;
&lt;br /&gt;
Selle toiminguga on fail kindlalt Git-i ajaloos kirjas. Et näha Git-i ajalugu, kirjuta sisse käsk:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;bash&amp;quot; collapse=&amp;quot;false&amp;quot;&amp;gt;git log&amp;lt;/source&amp;gt;&lt;br /&gt;
Et log vaatest väljuda, tuleb vajutada klaviatuuril Q klahvi.&lt;br /&gt;
&lt;br /&gt;
===== Push =====&lt;br /&gt;
Nüüd kui muudatused on salvestatud lokaalselt, tuleks need ka üles laadida serverisse, kust neid oleks võimalik hiljem alla laadida ka teistest arvutitest.&lt;br /&gt;
Muudatuste üles laadimiseks on käsk ''git push''. ''Origin'' on välise repositooriumi aadress, kust algselt selle alla laadisime. ''Master'' on peamise haru nimi. Peale esimest pushi võib need ära jätta, kuna siis Git oskab ise eeldada kuhu soovime üles laadida. &lt;br /&gt;
&amp;lt;source lang=&amp;quot;bash&amp;quot; collapse=&amp;quot;false&amp;quot;&amp;gt;git push origin master&amp;lt;/source&amp;gt;&lt;br /&gt;
  git push origin master&lt;br /&gt;
 Username for 'http://gitlab.pld.ttu.ee': test&lt;br /&gt;
 Password for 'http://test@gitlab.pld.ttu.ee':&lt;br /&gt;
 Counting objects: 4, done.&lt;br /&gt;
 Delta compression using up to 8 threads.&lt;br /&gt;
 Compressing objects: 100% (2/2), done.&lt;br /&gt;
 Writing objects: 100% (4/4), 255.45 KiB | 0 bytes/s, done.&lt;br /&gt;
 Total 4 (delta 0), reused 0 (delta 0)&lt;br /&gt;
 To http://gitlab.pld.ttu.ee/test/iag0581.git&lt;br /&gt;
  * [new branch]      master -&amp;gt; master&lt;br /&gt;
&lt;br /&gt;
Peale käsu sisestamist ja enterile vajutamist küsitakse taaskord kasutajat ja parooli.&lt;br /&gt;
Kui soovite kindlaks teha, et kõik õnnestus edukalt, saate minna repositooriumile ligi kasutades veebibrauserit ja veenduda, et lisatud failid on sealt nähtavad.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| [[File:Git_files1.png|200px|thumb|none|Projektis olevate failide nägemiseks kliki 'Files'.]]&lt;br /&gt;
| [[File:Git_files2.png|200px|thumb|none|Järgneval lehel peaks näha olema lisatud failid.]]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===== Pull =====&lt;br /&gt;
Viimase põhilise Git-i käsu selgitamiseks eeldame, et teil on oma Git-i repositoorium alla kloonitud nii kodu- kui klassiarvutisse. Nüüd kui te teete muudatusi oma failides praktikumitunni jooksul, siis kodus olevas arvutis on repositoorium endiselt vanas seisus. Selleks, et uuendada oma kodus oleva repositooriumi seisu, on vaja muudatused alla laadida kasutades käsku ''git pull''.&lt;br /&gt;
&amp;lt;source lang=&amp;quot;bash&amp;quot; collapse=&amp;quot;false&amp;quot;&amp;gt;git pull&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Et vältida võimalikke konflikte, siis tuleks kindlasti enne uute muudatuste tegemiseks tööd alustada sellega, et annate käsu ''git pull''.&lt;br /&gt;
&lt;br /&gt;
===== Lisainfo =====&lt;br /&gt;
Siinkohal on selgitatud ainult Git-i põhifunktsionaalsuse kasutamine, kuid tegelikult on tal palju teisigi funktsioone, mille kohta saate iseseisvalt juurde lugeda.&lt;br /&gt;
&lt;br /&gt;
*Git-i ametlik dokumentatsioon  - https://git-scm.com/doc&lt;br /&gt;
*Spikker - https://training.github.com/kit/downloads/github-git-cheat-sheet.pdf&lt;br /&gt;
&lt;br /&gt;
=== Programmeerimistarkvara ===&lt;br /&gt;
====Kompileerimine terminalis====&lt;br /&gt;
&lt;br /&gt;
Terminalis kompileerimiseks on käsk '''gcc'''.&lt;br /&gt;
&lt;br /&gt;
Näiteks kui programmikood on failis hello.c, siis kompileerimiseks tuleks anda käsk&lt;br /&gt;
&lt;br /&gt;
 gcc –o hello hello.c&lt;br /&gt;
&lt;br /&gt;
See tekitab binaarfaili hello, milles võime veenduda kasutades käsku ls. Järgnevalt on see võimalik tööle panna käsuga &lt;br /&gt;
&lt;br /&gt;
 ./hello&lt;br /&gt;
&lt;br /&gt;
Windowsi all käsitsi gcc-ga kompileerimiseks võib kasutada nt: &lt;br /&gt;
&lt;br /&gt;
* MinGW	- http://www.mingw.org/&lt;br /&gt;
* Cygwin - http://www.cygwin.com/&lt;br /&gt;
&lt;br /&gt;
====C/C++ Integreeritud programmeerimiskeskkonnad (IDE)====&lt;br /&gt;
* Code::Blocks - http://www.codeblocks.org/ (Windows, Linux, Mac OS)&lt;br /&gt;
&lt;br /&gt;
Klassi arvutites terminali käsk '''codeblocks'''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Geany - http://www.geany.org/ (Windows, Linux)&lt;br /&gt;
Klassi arvutites terminali käsk '''geany'''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Orwell Dev-C++ - http://sourceforge.net/projects/orwelldevcpp/ (Windows)&lt;br /&gt;
&lt;br /&gt;
=== Süntaksi värvimisega tekstiredaktorid ===&lt;br /&gt;
[[File:Scite.png|200px|thumb|none|SciTE]]&lt;br /&gt;
* SciTE - http://www.scintilla.org/SciTE.html (Windows, Linux, Mac OS)&lt;br /&gt;
&lt;br /&gt;
Klassi arvutites terminali käsk '''SciTE'''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Notepad++ - http://notepad-plus-plus.org/ (Windows)&lt;br /&gt;
&lt;br /&gt;
=== Diagrammide joonistamisvahendid ===&lt;br /&gt;
&lt;br /&gt;
* ArgoUML - http://argouml.tigris.org/ (Windows, Linux)&lt;br /&gt;
&lt;br /&gt;
Klassi arvutites terminali käsk '''argouml'''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Astah Community - http://astah.net/download#community (Windows, Linux, Mac OS)&lt;br /&gt;
&lt;br /&gt;
Klassi arvutites terminali käsk '''astah-com'''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* yEd - http://www.yworks.com/en/products_yed_about.html. (Windows, Linux, Mac OS)&lt;br /&gt;
&lt;br /&gt;
Klassi arvutites terminali käsk '''yEd'''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Jackson System Programming (JSP) Editor - http://www.his.se/english/university/contact/staff/henrik-engstrom/jsp-editor/ (Windows, Linux, Mac OS)&lt;br /&gt;
&lt;br /&gt;
Klassi arvutites terminali käsk '''jsp'''&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| [[File:Argouml.png|200px|thumb|none|argoUML]]&lt;br /&gt;
| [[File:Yed.png|200px|thumb|none|yEd]]&lt;br /&gt;
| [[File:Jsp.png|thumb|none|Jackson System Programming (JSP) Editor]]&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Hkinks</name></author>	</entry>

	<entry>
		<id>https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programming_II&amp;diff=2489</id>
		<title>IAG0582 - Programming II</title>
		<link rel="alternate" type="text/html" href="https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programming_II&amp;diff=2489"/>
				<updated>2017-02-02T10:07:38Z</updated>
		
		<summary type="html">&lt;p&gt;Hkinks: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[IAG0582 - Programmeerimine II|Eesti keelne leht]] [[File:Estonia.png | 32px | link=IAG0582 - Programmeerimine II]]&lt;br /&gt;
=General Information=&lt;br /&gt;
==Tests==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| I test || 5. week || files and structs || 20 points&lt;br /&gt;
|-&lt;br /&gt;
| II test || 12. week || dynamic memory allocation || 20 points&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&amp;lt;!-- Tests will be held in lectures. --&amp;gt;&lt;br /&gt;
== Homeworks ==&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| I homework || files and structs || 15 points&lt;br /&gt;
|-&lt;br /&gt;
| II homework || dynamic memory allocation || 15 points&lt;br /&gt;
|-&lt;br /&gt;
| III homework || optional || 10 points&lt;br /&gt;
|-&lt;br /&gt;
| || Database task||&lt;br /&gt;
|- &lt;br /&gt;
| || Microcontroller task||&lt;br /&gt;
|- &lt;br /&gt;
|}&lt;br /&gt;
First two homeworks must be done before thursday of 16. week. Third homework's deadline is until the end of the semester.&lt;br /&gt;
&lt;br /&gt;
'''If there is a suspicion of plagiarism for any submitted work of student, the grade for that submission will be 0 points. To improve the score, the submission must be defended.'''&lt;br /&gt;
&lt;br /&gt;
== Practice classes ==&lt;br /&gt;
It is possible to gather up to 36 points from practice classes&lt;br /&gt;
* 1p for participation (total can be maximum of 14p)&lt;br /&gt;
* practice class tasks up to 22, from which 4p will be from guest practice classes:&lt;br /&gt;
** Database task 2p&lt;br /&gt;
** Microcontroller task 2p&lt;br /&gt;
&lt;br /&gt;
More information about the practice classes can be found on your practice class teacher's homepage&lt;br /&gt;
* Margit Aarna and Risto Heinsar http://blue.pri.ee/ttu&lt;br /&gt;
&lt;br /&gt;
== Requirements for exam ==&lt;br /&gt;
# Pre-exam requirement is 61p before the start of exam session&lt;br /&gt;
# Exam requirement is 50p ( practice + test I + test 2 + bonus )&lt;br /&gt;
&lt;br /&gt;
== Exam ==&lt;br /&gt;
Exam's grade is the result of the following points:&lt;br /&gt;
&lt;br /&gt;
Homework I + homework II + homework III + written examination (max 65p)&lt;br /&gt;
=3. Homework=&lt;br /&gt;
==Database homework==&lt;br /&gt;
* There has been given a PostgreSQL database, which consists of a simple student information system data.&lt;br /&gt;
* To take the task, you first have to register with your student code. This is necessary for creating an user for you and an user specific database, which has been filled with sample structure and data. You will have rights to insert, modify and delete rows in your database and feel free to do so.&lt;br /&gt;
&lt;br /&gt;
 '''[http://ewis.pld.ttu.ee/reg Registration]'''&lt;br /&gt;
&lt;br /&gt;
* Connection parameters:&lt;br /&gt;
 Host: ewis.pld.ttu.ee&lt;br /&gt;
 Database: ''&amp;lt;student code&amp;gt;''&lt;br /&gt;
 Port: 5432&lt;br /&gt;
 User: ''&amp;lt;student code&amp;gt;''&lt;br /&gt;
 Password: ''&amp;lt;password you chose during registration&amp;gt;''&lt;br /&gt;
&lt;br /&gt;
* For managing the database, you can use some of postgre database clients, like:&lt;br /&gt;
** '''PgAdmin III''' (Windows, Linux, Mac OS)&lt;br /&gt;
** [http://ewis.pld.ttu.ee/mywebsql/ MyWebSQL] (web client)&lt;br /&gt;
** [http://ewis.pld.ttu.ee/phpPgAdmin/ phpPgAdmin] (web client)&lt;br /&gt;
* Data structure has been given with the image&lt;br /&gt;
[[File:Is_struct.png]]&lt;br /&gt;
* If there is a need to reset the initial database, you can use the following SQL statements for that - [http://ati.ttu.ee/~hkinks/iag0582/3%20kodune/create_tables_en.sql Link]&lt;br /&gt;
&lt;br /&gt;
===Tasks===&lt;br /&gt;
Create a text based user interface program, that would have the following functionality:&lt;br /&gt;
# Adding a student. User will be asked: first name, last name, date of birth. Program has to generate unique student code for each student. (2p)&lt;br /&gt;
# Modifying and deleting a student. (2p)&lt;br /&gt;
# Adding, modifying and deleting a course. (2p)&lt;br /&gt;
# Giving grade for a student for a specific course. When inserting a grade, the average grade should also be updated taking account the credit points. (2p)&lt;br /&gt;
# Searching students based on their weighted average grade. (2p) For example, if we want to find the best students we could specify condition 'avg &amp;gt; 4.6'&lt;br /&gt;
&lt;br /&gt;
Program has to communicate with the given database and use it for reading and storing data.&lt;br /&gt;
&lt;br /&gt;
Finished homework should be sent to '''reijo.olavi.komu@gmail.com'''&lt;br /&gt;
&lt;br /&gt;
===Compiling code with PostgreSQL library===&lt;br /&gt;
To connect the PostgreSQL database within your C code, you have to have the connector libraries installed and the compiler has to know where to find them.&lt;br /&gt;
&lt;br /&gt;
The easiest way to compile your program is using TUT's lab computers, where PostgreSQL is previously installed and the library can be easily included.&lt;br /&gt;
[http://mini.li.ttu.ee/~priit/IAY0340.2013/ssh_setup/putty_guide.html Guide] for connecting to lab computers over SSH&lt;br /&gt;
&lt;br /&gt;
It is of course possible to install the PostgreSQL C libraries also on your own computer independent of your OS, but this can be time consuming on the first try.&lt;br /&gt;
&lt;br /&gt;
For more information about setting it up yourself, you can see [[PostgreSQL setup]]&lt;br /&gt;
&lt;br /&gt;
When compiling, you should include the header file in your C code:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;C&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;pgsql/libpg-fe.h&amp;gt;&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
Keep in mind that the location could be different if you choose to compile it from your own computer.&lt;br /&gt;
&lt;br /&gt;
While compiling you should also give the linker argument '''-lpq'''. For example '''gcc -o program main.c -lpq'''.&lt;br /&gt;
===Helping materials===&lt;br /&gt;
* [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/db_tutorial.pdf Database task from practice class]&lt;br /&gt;
* [http://www.postgresql.org/docs/9.1/interactive/index.html PostgreSQL documentation]&lt;br /&gt;
* [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/sql-cheat-sheet.pdf SQL cheatsheet]&lt;br /&gt;
===C sample===&lt;br /&gt;
[http://ati.ttu.ee/~hkinks/iag0582/praktikum11/psql.c Sample] - Creates a connection with a database and queries 10 first rows.&lt;/div&gt;</summary>
		<author><name>Hkinks</name></author>	</entry>

	<entry>
		<id>https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programmeerimine_II&amp;diff=2488</id>
		<title>IAG0582 - Programmeerimine II</title>
		<link rel="alternate" type="text/html" href="https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programmeerimine_II&amp;diff=2488"/>
				<updated>2017-02-02T10:06:21Z</updated>
		
		<summary type="html">&lt;p&gt;Hkinks: /* Andmebaasi kodutöö */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[IAG0582 - Programming II|English course page]] [[File:United Kingdom.png|32px|link=IAG0582 - Programming II]]&lt;br /&gt;
&lt;br /&gt;
== Materjalid == &lt;br /&gt;
[https://ois.ttu.ee/portal/page?_pageid=35,428610&amp;amp;_dad=portal&amp;amp;_schema=PORTAL&amp;amp;p_msg=&amp;amp;p_public=1&amp;amp;p_what=3&amp;amp;p_lang=ET&amp;amp;p_open_node2=107&amp;amp;p_session_id=2886060&amp;amp;p_id=100821&amp;amp;p_mode=1&amp;amp;p_pageid=OKM_AINE_WEB_OTSING Ainekaart]&lt;br /&gt;
&lt;br /&gt;
Vladimir Viies - http://www.tud.ttu.ee/im/Vladimir.Viies/materials/IAG0581,IAG0582,PROGRAMMEERIMINE/PR2/&lt;br /&gt;
&lt;br /&gt;
Risto Heinsar - http://www.blue.pri.ee/ttu/&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Lembit Jürimägi - http://ati.ttu.ee/~lembit/prog2/&lt;br /&gt;
&lt;br /&gt;
===Vanad materjalid===&lt;br /&gt;
&lt;br /&gt;
Hannes Kinks - http://ati.ttu.ee/~hkinks/iag0582, http://git.hkinks.com/hkinks/iag0582/tree/master&lt;br /&gt;
&lt;br /&gt;
''&amp;lt;u&amp;gt;Helena Kruus - http://www.tud.ttu.ee/im/Vladimir.Viies/materials/Helena_materjalid/iag0582/&amp;lt;/u&amp;gt;''&lt;br /&gt;
&lt;br /&gt;
===Moodle materjalid===&lt;br /&gt;
Ise registreerumisega kursusele &amp;quot;IAG0582 Programmeerimine II&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
https://moodle.hitsa.ee/course/view.php?id=4710&lt;br /&gt;
&lt;br /&gt;
==Üldstruktuur==&lt;br /&gt;
Antud kursus on jätk kursusele „Programmeerimine I“, milles pearõhk oli pööratud ülesande lahendusalgoritmi koostamisele. „Programmeerimine II“ annab lisaks vajalike teadmisi algoritmi realiseerimisele  kõrgkeele(C,C++,Java) keskkonnas.&lt;br /&gt;
&lt;br /&gt;
Kursus on jaotatud 4ks mooduliks, kus iga moodul sisaldab näiteülesandeid, mis tuleb õppimise käigus kindlasti läbi lahendada.&lt;br /&gt;
Kahes esimeses moodulis on komplektid teemaakohaseid  ülesandeid, millest vähemalt ühe lahenduse peaks saatma kursuse tuutorile, et kontrollida enda mõttekäiku. &lt;br /&gt;
&lt;br /&gt;
Kahes viimases moodulis on testid koos vastustega – soovitus:vastuseid mitte eelnevalt piiluda. Vastasel juhul võib tekkida näiv tunne ülesande lihtsuse ja materjali arusaadavuse kohta.&lt;br /&gt;
&lt;br /&gt;
Kolmandas moodulis on individuaalne kohustuslik kodune töö, mille lahendus tuleb vormistada vastavalt kursuse üldosas toodud juhendile.&lt;br /&gt;
Neljas moodul sisaldab  kodust ülesannet, mille lahendamist tuleks teha rühmatööna. Rühm peaks koosnema 3 liikmest ja selle moodustamine võiks toimuda kas foorumi kaudu või siis tuutori poolt. Ülesandes on jällegi kindlalt eristatavad osad: 1- sideandmebaasiga, päringud  2- andmetöötlus, vastavalt ülesandele 3-kasutajaliides algandmete sisestamiseks ja tulemuse kuvamiseks.&lt;br /&gt;
&lt;br /&gt;
Erandjuhuna võib õppija sooritada selle kodutöö üksinda, viimane on reegliks mikrokontrolleri programmeerimise valimisel kodutööks.&lt;br /&gt;
&lt;br /&gt;
===Ainerõhud moodulites===&lt;br /&gt;
C programmi koostamisel on eriline koht viitadel, millede asjatundlik kasutamine muudab programmi kiiremaks ja effektiivsemaks.&lt;br /&gt;
Programmi töö käigus saab andmete poole pöörduda kas muutuja nime kaudu(keskkond seostab ise asukohaga mälus) või viida kaudu(sisaldab andmete asukoha mäluaadressit). Eriti selgelt väljendub viimase kasutamise effektiivsus töös massiividega. On selge, et ühest programmi moodulist , teise programmi moodulisse  massiivi edastamine palju ressursinõudlikum, kui ainult selle esimese elemendi edastus. Viidaga teeme aga just viimast!&lt;br /&gt;
&lt;br /&gt;
Teine tee andmetöötluse effektiivsuse tõstmiseks on andmete ühildamine ühtseks muutujaks. Näiteks kui on meil ülesanne, kus nõutakse üliõpilaste keskmiste hinnete leidmist, on sellise struktuurse  muutuja kasutamine, mis sisaldab nii üliõpilase identifikaatorit, kui tema hindeid, tunduvalt arusaadavam, kui mitme erineva massiivi kasutuselevõtt. Objektorienteeritud programmeerimises(OOP) minnakse aga veelgi edasi ja ühendatakse struktuursed andmed neid töötlevate programmimoodulitega.&lt;br /&gt;
Kahes esimeses moodulis tuleb peatähelepanu keskendada viida mõistele ja selle kasutamise võimalustele.&lt;br /&gt;
Operatsioonisüsteem eraldab igale programmile sisemälus teatud mälu. Andmetele eraldavat osa juhib programm, kasutades kas statilist või dünaamilist mälueraldamist. Esimesel juhul peab kogu eraldatav mälu olema kirjeldatud programmi töö alguseks. Teisel juhul ei , töö käigus  saab mälu vajadus muutuda.&lt;br /&gt;
&lt;br /&gt;
Kolmas moodul ongi pühendatud dünaamilisele mälujaotusele, mis sisaldab alati kahte tegevust: mälu hõivamist ja selle vabastamist.  Üheks mälu dünaamilise kasutamise võtteks on rekursiooni kasutamine. Viimane võimaldab veel taandada ülesande keerukust, näiteks n! leidmine  asendub (n-1)! Leidmisega.Rekursiooni vale kasutamine aga „kurnab“ arvutiressursse. Selle temaatika kinnistamiseks tuleb sooritada esimene kodutöö.&lt;br /&gt;
&lt;br /&gt;
Neljas moodul on kokkuvõtlik ja võimaldab teise kodutöö sooritamisel kontrollida eelnenu omandamise taset. Samuti lõppeb neljas moodul kontrolltöö sooritamisega, mis annab eelduse edukaks eksamiks.&lt;br /&gt;
Moodulis pakutav , OOP tutvustav materjal, on lisamaterjali staatuses ja selle valdamine eksamil ei ole kohustuslik, kuid meeldiv võimalus näidata enda häid teadmisi.&lt;br /&gt;
&lt;br /&gt;
== Õppetöö ==&lt;br /&gt;
=== Kontrolltööd ===&lt;br /&gt;
I kontrolltöö 5. nädal kirjed ja failid (20p)&lt;br /&gt;
&lt;br /&gt;
II kontrolltöö 12. nädal dünaamiline mälujaotus (20p)&lt;br /&gt;
&lt;br /&gt;
Kontrolltööd toimuvad loengus.&lt;br /&gt;
&lt;br /&gt;
=== Kodused tööd ===&lt;br /&gt;
I kodune töö - 15p kirjed ja failid&lt;br /&gt;
&lt;br /&gt;
II kodune töö - 15p dünaamiline mälujaotus, rekursiivsus&lt;br /&gt;
&lt;br /&gt;
III kodune töö - 10p valikuline:&lt;br /&gt;
* mikrokontrolleri ülesanne&lt;br /&gt;
* andmebaasi ülesanne&lt;br /&gt;
Esimesed kaks kodust tööd peavad olema tehtud enne eeleksamit 16 nädal neljapäev. Kolmanda koduse töö tähtaeg kuni eksamisessiooni lõpuni.&lt;br /&gt;
&lt;br /&gt;
=== Praktika ===&lt;br /&gt;
Kokku on praktika eest võimalik kokku saada 36p&lt;br /&gt;
* kohaloleku eest 1p (kokku max 14p)&lt;br /&gt;
* tunniülesanded kokku max 22p. Sellest 4p moodustavad kaks külalispraktikumi:&lt;br /&gt;
** andmebaasi ülesanne max 2p&lt;br /&gt;
** mikrokontrolleri ülesanne max 2p&lt;br /&gt;
&lt;br /&gt;
=== Eksamieeldus === &lt;br /&gt;
# Eeleksami soorituse eelduseks on 61p enne 01.05.2017.&lt;br /&gt;
# Eksami soorituse eelduseks eksamisessioonil on 50p (praktika + kontrolltöö 1 + kontrolltöö 2 + boonus (max 10p))&lt;br /&gt;
&lt;br /&gt;
=== Eksam === &lt;br /&gt;
Eksami hinne kujuneb välja järgmiste punktide arvelt:&lt;br /&gt;
Kodutöö 1 + kodutöö 2 + kodutöö 3 + kirjalik eksamitöö(max 65p)&lt;br /&gt;
&lt;br /&gt;
Plagiaadikahtluse puhul on esitatud töö hindeks 1p. Punktide parandamiseks tuleb osata oma tööd kaitsta.&lt;br /&gt;
&lt;br /&gt;
==3. Kodutöö==&lt;br /&gt;
Kolmanda kodutöö tegemiseks on üliõpilasel valikuvabadus. Mõlemad kodutööd on sissejuhatuseks spetsiifilisematesse teemadesse. &lt;br /&gt;
# Andmebaasi ülesanne - Suunaga rohkem tarkvara ja infosüsteemide poole andes ülevaate andmebaaside kasutusest ja PostgreSQL andmebaasimootorist. Ülesande käigus tuleb luua minimalistlik õppeinfosüsteem, mis suhtleks andmebaasiga.&lt;br /&gt;
# Mikrokontrolleri ülesanne - Suunaga riistvaralähedasema programmeerimise poole. Ülesande käigus õpitakse mikrokontrollerit programmeerima.&lt;br /&gt;
===Andmebaasi kodutöö===&lt;br /&gt;
''Teemat puudutav [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/db_praks.pdf tunniülesanne]''&lt;br /&gt;
&lt;br /&gt;
* Antud ülesande kaal on 10p.&lt;br /&gt;
* Ette on antud olemasolev PostgreSQL andmebaas, mis sisaldab endas lihtsa kursuste haldamiseks mõeldud infosüsteemi andmeid. &lt;br /&gt;
Kõigepealt tuleks registreerida oma tudengikoodiga, mille tulemusena loodakse tudengikoodi nimega kasutaja ja sellele vastav andmebaas. Loodavas andmebaasis on olemas õigused nii kirjete lugemiseks, kui ka lisamiseks, muutmiseks ja kustutamiseks.&lt;br /&gt;
 '''[http://ewis.pld.ttu.ee/reg Registreerimine]'''&lt;br /&gt;
* Andmed ühendumiseks:&lt;br /&gt;
 Host: ewis.pld.ttu.ee&lt;br /&gt;
 Andmebaas: ''&amp;lt;tudengikood&amp;gt;''&lt;br /&gt;
 Port: 5432&lt;br /&gt;
 Kasutaja: ''&amp;lt;tudengikood&amp;gt;''&lt;br /&gt;
 Parool: ''&amp;lt;registreerimisel valitud parool&amp;gt;''&lt;br /&gt;
* Andmebaasi visuaalseks haldamiseks võib kasutada mõnda selleks ettenähtud tarkvara, nt&lt;br /&gt;
** PgAdmin III&lt;br /&gt;
** [http://ewis.pld.ttu.ee/mywebsql/ MyWebSQL]&lt;br /&gt;
** [http://ewis.pld.ttu.ee/phpPgAdmin/ phpPgAdmin]&lt;br /&gt;
* Andmestruktuur&lt;br /&gt;
[[File:Is_struct.png]]&lt;br /&gt;
* Kui on vajadus algne andmebaas taastada, siis selleks võib kasutada järgnevat SQL koodi - [http://ati.ttu.ee/~hkinks/iag0582/3%20kodune/create_tables.sql Link]&lt;br /&gt;
* Kodutöö saata aadressile '''reijo.olavi.komu@gmail.com'''&lt;br /&gt;
====Ülesanded====&lt;br /&gt;
Koostada tekstipõhise kasutajaliidesega programm, mis võimaldaks kasutada järgmist funktsionaalsust:&lt;br /&gt;
# Tudengi lisamine. Kasutajalt küsitakse: eesnimi, perekonnanimi, sünnikuupäev. Programm peaks looma iga tudengi jaoks unikaalse tudengikoodi. (2p)&lt;br /&gt;
# Tudengi muutmine ja kustutamine. (2p)&lt;br /&gt;
# Aine lisamine, muutmine, kustutamine. (2p)&lt;br /&gt;
# Hinde lisamine õpilasele vastava aine eest. Hinde lisamisel peaks ka uuendama kaalutud keskhinnet (student.average_grade) võttes arvesse ainepunkte (subject.credits). (2p)&lt;br /&gt;
# Tudengite otsing kkh põhjal. Nt. otsimaks keda eksmatrikuleerida, peaks saama anda ette tingimuse ''kaalutud keskhinne &amp;lt; 1'' või kellele cum laude anda tingimusel ''kaalutud keskhinne &amp;gt; 4.8''. (2p)&lt;br /&gt;
&lt;br /&gt;
Programm peab liidestuma etteantud andmebaasiga ning kasutama seda andmete lugemiseks ja hoiustamiseks.&lt;br /&gt;
&lt;br /&gt;
Suureks plussiks on:&lt;br /&gt;
* Sisendi valideerimine ehk programm ei jookse kokku ega lähe tsüklisse, kui sisestatakse näiteks numbri asemel täht.&lt;br /&gt;
* Makefile kasutus kompileerimisel.&lt;br /&gt;
&lt;br /&gt;
====PostgreSQL teegiga koodi kompileerimine====&lt;br /&gt;
Selleks, et kirjutada C koodi, mis ühenduks PostgreSQL andmebaasiga, on vaja eelnevalt paigaldada vastav ''connector'' teek (libpq) ja kompilaatorile selgeks teha, kust neid leida.&lt;br /&gt;
&lt;br /&gt;
Kompileerida on kõige lihtsam kasutades TTÜ klassiarvuteid, kus on PostgreSQL eelnevalt paigaldatud. Selleks tuleks SSH abil ühenduda mõnda klassiarvutisse. Selle kohta on põhjalikumad juhendid:&lt;br /&gt;
*[http://ati.ttu.ee/wiki/index.php/Arvutiklassis_t%C3%B6%C3%B6tamise_juhend#Ligip.C3.A4.C3.A4s_v.C3.A4ljastpoolt_.C3.BClikooli_sisev.C3.B5rke Üldisem info väljastpoolt sisevõrku töötamise kohta]&lt;br /&gt;
*[http://mini.li.ttu.ee/~priit/IAY0340.2013/ssh_setup/putty_guide.html Piltidega juhend Putty kohta]&lt;br /&gt;
&lt;br /&gt;
Kui on sellegipoolest soovi enda arvutis kõnealune libpq teek ise paigaldada, siis abiks on järgnev juhend:&lt;br /&gt;
*[[PostgreSQL setup]]&lt;br /&gt;
&lt;br /&gt;
Kompileerides tuleks kindlasti lisada oma C koodis vastav teek:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;C&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;pgsql/libpg-fe.h&amp;gt;&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
Kui olete teegi ise paigaldanud, siis selle asukoht võib varieeruda ja peaksite asendama nt ''#include &amp;lt;libpg-fe.h&amp;gt;''.&lt;br /&gt;
&lt;br /&gt;
Kompileerimisel tuleb anda ka lisaargument linkerile '''-lpq'''. Näiteks ''gcc -o program main.c -lpq''.&lt;br /&gt;
====Abimaterjalid====&lt;br /&gt;
* [http://www.postgresql.org/docs/9.1/interactive/index.html PostgreSQL dokumentatsioon]&lt;br /&gt;
* [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/sql-cheat-sheet.pdf SQL cheatsheet]&lt;br /&gt;
* Ülesannet võib lahendada meelepärases programmeerimiskeeles. C kohta on olemas näidiskood ja põhjalikum juhis kompileerimiseks. Java puhul on toodud samuti näidisprogramm, kuid ülejäänud keelte puhul tuleks PostgreSQL andmebaasiga ühenduse loomine iseseisvalt selgeks teha.&lt;br /&gt;
&lt;br /&gt;
=====C Näidiskood=====&lt;br /&gt;
[http://ati.ttu.ee/~hkinks/iag0582/praktikum11/psql.c Näidiskood] - loob ühenduse eelnimetatud PostgreSQL andmebaasiga ja pärib 10 esimest kirjet.&lt;br /&gt;
&lt;br /&gt;
=== Mikrokontrolleri ülesanne ===&lt;br /&gt;
Juhendi leiab aadressilt [http://blue.pri.ee/ttu/ http://blue.pri.ee/ttu/]&lt;/div&gt;</summary>
		<author><name>Hkinks</name></author>	</entry>

	<entry>
		<id>https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programmeerimine_II&amp;diff=2487</id>
		<title>IAG0582 - Programmeerimine II</title>
		<link rel="alternate" type="text/html" href="https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programmeerimine_II&amp;diff=2487"/>
				<updated>2017-02-02T09:45:27Z</updated>
		
		<summary type="html">&lt;p&gt;Hkinks: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[IAG0582 - Programming II|English course page]] [[File:United Kingdom.png|32px|link=IAG0582 - Programming II]]&lt;br /&gt;
&lt;br /&gt;
== Materjalid == &lt;br /&gt;
[https://ois.ttu.ee/portal/page?_pageid=35,428610&amp;amp;_dad=portal&amp;amp;_schema=PORTAL&amp;amp;p_msg=&amp;amp;p_public=1&amp;amp;p_what=3&amp;amp;p_lang=ET&amp;amp;p_open_node2=107&amp;amp;p_session_id=2886060&amp;amp;p_id=100821&amp;amp;p_mode=1&amp;amp;p_pageid=OKM_AINE_WEB_OTSING Ainekaart]&lt;br /&gt;
&lt;br /&gt;
Vladimir Viies - http://www.tud.ttu.ee/im/Vladimir.Viies/materials/IAG0581,IAG0582,PROGRAMMEERIMINE/PR2/&lt;br /&gt;
&lt;br /&gt;
Risto Heinsar - http://www.blue.pri.ee/ttu/&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Lembit Jürimägi - http://ati.ttu.ee/~lembit/prog2/&lt;br /&gt;
&lt;br /&gt;
===Vanad materjalid===&lt;br /&gt;
&lt;br /&gt;
Hannes Kinks - http://ati.ttu.ee/~hkinks/iag0582, http://git.hkinks.com/hkinks/iag0582/tree/master&lt;br /&gt;
&lt;br /&gt;
''&amp;lt;u&amp;gt;Helena Kruus - http://www.tud.ttu.ee/im/Vladimir.Viies/materials/Helena_materjalid/iag0582/&amp;lt;/u&amp;gt;''&lt;br /&gt;
&lt;br /&gt;
===Moodle materjalid===&lt;br /&gt;
Ise registreerumisega kursusele &amp;quot;IAG0582 Programmeerimine II&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
https://moodle.hitsa.ee/course/view.php?id=4710&lt;br /&gt;
&lt;br /&gt;
==Üldstruktuur==&lt;br /&gt;
Antud kursus on jätk kursusele „Programmeerimine I“, milles pearõhk oli pööratud ülesande lahendusalgoritmi koostamisele. „Programmeerimine II“ annab lisaks vajalike teadmisi algoritmi realiseerimisele  kõrgkeele(C,C++,Java) keskkonnas.&lt;br /&gt;
&lt;br /&gt;
Kursus on jaotatud 4ks mooduliks, kus iga moodul sisaldab näiteülesandeid, mis tuleb õppimise käigus kindlasti läbi lahendada.&lt;br /&gt;
Kahes esimeses moodulis on komplektid teemaakohaseid  ülesandeid, millest vähemalt ühe lahenduse peaks saatma kursuse tuutorile, et kontrollida enda mõttekäiku. &lt;br /&gt;
&lt;br /&gt;
Kahes viimases moodulis on testid koos vastustega – soovitus:vastuseid mitte eelnevalt piiluda. Vastasel juhul võib tekkida näiv tunne ülesande lihtsuse ja materjali arusaadavuse kohta.&lt;br /&gt;
&lt;br /&gt;
Kolmandas moodulis on individuaalne kohustuslik kodune töö, mille lahendus tuleb vormistada vastavalt kursuse üldosas toodud juhendile.&lt;br /&gt;
Neljas moodul sisaldab  kodust ülesannet, mille lahendamist tuleks teha rühmatööna. Rühm peaks koosnema 3 liikmest ja selle moodustamine võiks toimuda kas foorumi kaudu või siis tuutori poolt. Ülesandes on jällegi kindlalt eristatavad osad: 1- sideandmebaasiga, päringud  2- andmetöötlus, vastavalt ülesandele 3-kasutajaliides algandmete sisestamiseks ja tulemuse kuvamiseks.&lt;br /&gt;
&lt;br /&gt;
Erandjuhuna võib õppija sooritada selle kodutöö üksinda, viimane on reegliks mikrokontrolleri programmeerimise valimisel kodutööks.&lt;br /&gt;
&lt;br /&gt;
===Ainerõhud moodulites===&lt;br /&gt;
C programmi koostamisel on eriline koht viitadel, millede asjatundlik kasutamine muudab programmi kiiremaks ja effektiivsemaks.&lt;br /&gt;
Programmi töö käigus saab andmete poole pöörduda kas muutuja nime kaudu(keskkond seostab ise asukohaga mälus) või viida kaudu(sisaldab andmete asukoha mäluaadressit). Eriti selgelt väljendub viimase kasutamise effektiivsus töös massiividega. On selge, et ühest programmi moodulist , teise programmi moodulisse  massiivi edastamine palju ressursinõudlikum, kui ainult selle esimese elemendi edastus. Viidaga teeme aga just viimast!&lt;br /&gt;
&lt;br /&gt;
Teine tee andmetöötluse effektiivsuse tõstmiseks on andmete ühildamine ühtseks muutujaks. Näiteks kui on meil ülesanne, kus nõutakse üliõpilaste keskmiste hinnete leidmist, on sellise struktuurse  muutuja kasutamine, mis sisaldab nii üliõpilase identifikaatorit, kui tema hindeid, tunduvalt arusaadavam, kui mitme erineva massiivi kasutuselevõtt. Objektorienteeritud programmeerimises(OOP) minnakse aga veelgi edasi ja ühendatakse struktuursed andmed neid töötlevate programmimoodulitega.&lt;br /&gt;
Kahes esimeses moodulis tuleb peatähelepanu keskendada viida mõistele ja selle kasutamise võimalustele.&lt;br /&gt;
Operatsioonisüsteem eraldab igale programmile sisemälus teatud mälu. Andmetele eraldavat osa juhib programm, kasutades kas statilist või dünaamilist mälueraldamist. Esimesel juhul peab kogu eraldatav mälu olema kirjeldatud programmi töö alguseks. Teisel juhul ei , töö käigus  saab mälu vajadus muutuda.&lt;br /&gt;
&lt;br /&gt;
Kolmas moodul ongi pühendatud dünaamilisele mälujaotusele, mis sisaldab alati kahte tegevust: mälu hõivamist ja selle vabastamist.  Üheks mälu dünaamilise kasutamise võtteks on rekursiooni kasutamine. Viimane võimaldab veel taandada ülesande keerukust, näiteks n! leidmine  asendub (n-1)! Leidmisega.Rekursiooni vale kasutamine aga „kurnab“ arvutiressursse. Selle temaatika kinnistamiseks tuleb sooritada esimene kodutöö.&lt;br /&gt;
&lt;br /&gt;
Neljas moodul on kokkuvõtlik ja võimaldab teise kodutöö sooritamisel kontrollida eelnenu omandamise taset. Samuti lõppeb neljas moodul kontrolltöö sooritamisega, mis annab eelduse edukaks eksamiks.&lt;br /&gt;
Moodulis pakutav , OOP tutvustav materjal, on lisamaterjali staatuses ja selle valdamine eksamil ei ole kohustuslik, kuid meeldiv võimalus näidata enda häid teadmisi.&lt;br /&gt;
&lt;br /&gt;
== Õppetöö ==&lt;br /&gt;
=== Kontrolltööd ===&lt;br /&gt;
I kontrolltöö 5. nädal kirjed ja failid (20p)&lt;br /&gt;
&lt;br /&gt;
II kontrolltöö 12. nädal dünaamiline mälujaotus (20p)&lt;br /&gt;
&lt;br /&gt;
Kontrolltööd toimuvad loengus.&lt;br /&gt;
&lt;br /&gt;
=== Kodused tööd ===&lt;br /&gt;
I kodune töö - 15p kirjed ja failid&lt;br /&gt;
&lt;br /&gt;
II kodune töö - 15p dünaamiline mälujaotus, rekursiivsus&lt;br /&gt;
&lt;br /&gt;
III kodune töö - 10p valikuline:&lt;br /&gt;
* mikrokontrolleri ülesanne&lt;br /&gt;
* andmebaasi ülesanne&lt;br /&gt;
Esimesed kaks kodust tööd peavad olema tehtud enne eeleksamit 16 nädal neljapäev. Kolmanda koduse töö tähtaeg kuni eksamisessiooni lõpuni.&lt;br /&gt;
&lt;br /&gt;
=== Praktika ===&lt;br /&gt;
Kokku on praktika eest võimalik kokku saada 36p&lt;br /&gt;
* kohaloleku eest 1p (kokku max 14p)&lt;br /&gt;
* tunniülesanded kokku max 22p. Sellest 4p moodustavad kaks külalispraktikumi:&lt;br /&gt;
** andmebaasi ülesanne max 2p&lt;br /&gt;
** mikrokontrolleri ülesanne max 2p&lt;br /&gt;
&lt;br /&gt;
=== Eksamieeldus === &lt;br /&gt;
# Eeleksami soorituse eelduseks on 61p enne 01.05.2017.&lt;br /&gt;
# Eksami soorituse eelduseks eksamisessioonil on 50p (praktika + kontrolltöö 1 + kontrolltöö 2 + boonus (max 10p))&lt;br /&gt;
&lt;br /&gt;
=== Eksam === &lt;br /&gt;
Eksami hinne kujuneb välja järgmiste punktide arvelt:&lt;br /&gt;
Kodutöö 1 + kodutöö 2 + kodutöö 3 + kirjalik eksamitöö(max 65p)&lt;br /&gt;
&lt;br /&gt;
Plagiaadikahtluse puhul on esitatud töö hindeks 1p. Punktide parandamiseks tuleb osata oma tööd kaitsta.&lt;br /&gt;
&lt;br /&gt;
==3. Kodutöö==&lt;br /&gt;
Kolmanda kodutöö tegemiseks on üliõpilasel valikuvabadus. Mõlemad kodutööd on sissejuhatuseks spetsiifilisematesse teemadesse. &lt;br /&gt;
# Andmebaasi ülesanne - Suunaga rohkem tarkvara ja infosüsteemide poole andes ülevaate andmebaaside kasutusest ja PostgreSQL andmebaasimootorist. Ülesande käigus tuleb luua minimalistlik õppeinfosüsteem, mis suhtleks andmebaasiga.&lt;br /&gt;
# Mikrokontrolleri ülesanne - Suunaga riistvaralähedasema programmeerimise poole. Ülesande käigus õpitakse mikrokontrollerit programmeerima.&lt;br /&gt;
===Andmebaasi kodutöö===&lt;br /&gt;
''Teemat puudutav [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/db_praks.pdf tunniülesanne]''&lt;br /&gt;
&lt;br /&gt;
* Antud ülesande kaal on 10p.&lt;br /&gt;
* Ette on antud olemasolev PostgreSQL andmebaas, mis sisaldab endas lihtsa kursuste haldamiseks mõeldud infosüsteemi andmeid. &lt;br /&gt;
Kõigepealt tuleks registreerida oma tudengikoodiga, mille tulemusena loodakse tudengikoodi nimega kasutaja ja sellele vastav andmebaas. Loodavas andmebaasis on olemas õigused nii kirjete lugemiseks, kui ka lisamiseks, muutmiseks ja kustutamiseks.&lt;br /&gt;
 '''[http://ewis.pld.ttu.ee/reg Registreerimine]'''&lt;br /&gt;
* Andmed ühendumiseks:&lt;br /&gt;
 Host: ewis.pld.ttu.ee&lt;br /&gt;
 Andmebaas: ''&amp;lt;tudengikood&amp;gt;''&lt;br /&gt;
 Port: 5432&lt;br /&gt;
 Kasutaja: ''&amp;lt;tudengikood&amp;gt;''&lt;br /&gt;
 Parool: ''&amp;lt;registreerimisel valitud parool&amp;gt;''&lt;br /&gt;
* Andmebaasi visuaalseks haldamiseks võib kasutada mõnda selleks ettenähtud tarkvara, nt&lt;br /&gt;
** PgAdmin III&lt;br /&gt;
** [http://ewis.pld.ttu.ee/mywebsql/ MyWebSQL]&lt;br /&gt;
** [http://ewis.pld.ttu.ee/phpPgAdmin/ phpPgAdmin]&lt;br /&gt;
* Andmestruktuur&lt;br /&gt;
[[File:Is_struct.png]]&lt;br /&gt;
* Kui on vajadus algne andmebaas taastada, siis selleks võib kasutada järgnevat SQL koodi - [http://ati.ttu.ee/~hkinks/iag0582/3%20kodune/create_tables.sql Link]&lt;br /&gt;
* Kodutöö saata aadressile '''hkinks@ati.ttu.ee'''&lt;br /&gt;
====Ülesanded====&lt;br /&gt;
Koostada tekstipõhise kasutajaliidesega programm, mis võimaldaks kasutada järgmist funktsionaalsust:&lt;br /&gt;
# Tudengi lisamine. Kasutajalt küsitakse: eesnimi, perekonnanimi, sünnikuupäev. Programm peaks looma iga tudengi jaoks unikaalse tudengikoodi. (2p)&lt;br /&gt;
# Tudengi muutmine ja kustutamine. (2p)&lt;br /&gt;
# Aine lisamine, muutmine, kustutamine. (2p)&lt;br /&gt;
# Hinde lisamine õpilasele vastava aine eest. Hinde lisamisel peaks ka uuendama kaalutud keskhinnet (student.average_grade) võttes arvesse ainepunkte (subject.credits). (2p)&lt;br /&gt;
# Tudengite otsing kkh põhjal. Nt. otsimaks keda eksmatrikuleerida, peaks saama anda ette tingimuse ''kaalutud keskhinne &amp;lt; 1'' või kellele cum laude anda tingimusel ''kaalutud keskhinne &amp;gt; 4.8''. (2p)&lt;br /&gt;
&lt;br /&gt;
Programm peab liidestuma etteantud andmebaasiga ning kasutama seda andmete lugemiseks ja hoiustamiseks.&lt;br /&gt;
&lt;br /&gt;
Suureks plussiks on:&lt;br /&gt;
* Sisendi valideerimine ehk programm ei jookse kokku ega lähe tsüklisse, kui sisestatakse näiteks numbri asemel täht.&lt;br /&gt;
* Makefile kasutus kompileerimisel.&lt;br /&gt;
&lt;br /&gt;
====PostgreSQL teegiga koodi kompileerimine====&lt;br /&gt;
Selleks, et kirjutada C koodi, mis ühenduks PostgreSQL andmebaasiga, on vaja eelnevalt paigaldada vastav ''connector'' teek (libpq) ja kompilaatorile selgeks teha, kust neid leida.&lt;br /&gt;
&lt;br /&gt;
Kompileerida on kõige lihtsam kasutades TTÜ klassiarvuteid, kus on PostgreSQL eelnevalt paigaldatud. Selleks tuleks SSH abil ühenduda mõnda klassiarvutisse. Selle kohta on põhjalikumad juhendid:&lt;br /&gt;
*[http://ati.ttu.ee/wiki/index.php/Arvutiklassis_t%C3%B6%C3%B6tamise_juhend#Ligip.C3.A4.C3.A4s_v.C3.A4ljastpoolt_.C3.BClikooli_sisev.C3.B5rke Üldisem info väljastpoolt sisevõrku töötamise kohta]&lt;br /&gt;
*[http://mini.li.ttu.ee/~priit/IAY0340.2013/ssh_setup/putty_guide.html Piltidega juhend Putty kohta]&lt;br /&gt;
&lt;br /&gt;
Kui on sellegipoolest soovi enda arvutis kõnealune libpq teek ise paigaldada, siis abiks on järgnev juhend:&lt;br /&gt;
*[[PostgreSQL setup]]&lt;br /&gt;
&lt;br /&gt;
Kompileerides tuleks kindlasti lisada oma C koodis vastav teek:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;C&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;pgsql/libpg-fe.h&amp;gt;&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
Kui olete teegi ise paigaldanud, siis selle asukoht võib varieeruda ja peaksite asendama nt ''#include &amp;lt;libpg-fe.h&amp;gt;''.&lt;br /&gt;
&lt;br /&gt;
Kompileerimisel tuleb anda ka lisaargument linkerile '''-lpq'''. Näiteks ''gcc -o program main.c -lpq''.&lt;br /&gt;
====Abimaterjalid====&lt;br /&gt;
* [http://www.postgresql.org/docs/9.1/interactive/index.html PostgreSQL dokumentatsioon]&lt;br /&gt;
* [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/sql-cheat-sheet.pdf SQL cheatsheet]&lt;br /&gt;
* Ülesannet võib lahendada meelepärases programmeerimiskeeles. C kohta on olemas näidiskood ja põhjalikum juhis kompileerimiseks. Java puhul on toodud samuti näidisprogramm, kuid ülejäänud keelte puhul tuleks PostgreSQL andmebaasiga ühenduse loomine iseseisvalt selgeks teha.&lt;br /&gt;
&lt;br /&gt;
=====C Näidiskood=====&lt;br /&gt;
[http://ati.ttu.ee/~hkinks/iag0582/praktikum11/psql.c Näidiskood] - loob ühenduse eelnimetatud PostgreSQL andmebaasiga ja pärib 10 esimest kirjet.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Mikrokontrolleri ülesanne ===&lt;br /&gt;
Juhendi leiab aadressilt [http://blue.pri.ee/ttu/ http://blue.pri.ee/ttu/]&lt;/div&gt;</summary>
		<author><name>Hkinks</name></author>	</entry>

	<entry>
		<id>https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programmeerimine_II&amp;diff=2486</id>
		<title>IAG0582 - Programmeerimine II</title>
		<link rel="alternate" type="text/html" href="https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programmeerimine_II&amp;diff=2486"/>
				<updated>2017-02-02T09:45:03Z</updated>
		
		<summary type="html">&lt;p&gt;Hkinks: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[IAG0582 - Programming II|English course page]] [[File:United Kingdom.png|32px|link=IAG0582 - Programming II]]&lt;br /&gt;
&lt;br /&gt;
== Materjalid == &lt;br /&gt;
[https://ois.ttu.ee/portal/page?_pageid=35,428610&amp;amp;_dad=portal&amp;amp;_schema=PORTAL&amp;amp;p_msg=&amp;amp;p_public=1&amp;amp;p_what=3&amp;amp;p_lang=ET&amp;amp;p_open_node2=107&amp;amp;p_session_id=2886060&amp;amp;p_id=100821&amp;amp;p_mode=1&amp;amp;p_pageid=OKM_AINE_WEB_OTSING Ainekaart]&lt;br /&gt;
&lt;br /&gt;
Vladimir Viies - http://www.tud.ttu.ee/im/Vladimir.Viies/materials/IAG0581,IAG0582,PROGRAMMEERIMINE/PR2/&lt;br /&gt;
&lt;br /&gt;
Risto Heinsar - http://www.blue.pri.ee/ttu/&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Lembit Jürimägi - http://ati.ttu.ee/~lembit/prog2/&lt;br /&gt;
&lt;br /&gt;
''Vanad materjalid''&lt;br /&gt;
&lt;br /&gt;
Hannes Kinks - http://ati.ttu.ee/~hkinks/iag0582, http://git.hkinks.com/hkinks/iag0582/tree/master&lt;br /&gt;
&lt;br /&gt;
''&amp;lt;u&amp;gt;Helena Kruus - http://www.tud.ttu.ee/im/Vladimir.Viies/materials/Helena_materjalid/iag0582/&amp;lt;/u&amp;gt;''&lt;br /&gt;
&lt;br /&gt;
===Moodle materjalid===&lt;br /&gt;
Ise registreerumisega kursusele &amp;quot;IAG0582 Programmeerimine II&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
https://moodle.hitsa.ee/course/view.php?id=4710&lt;br /&gt;
&lt;br /&gt;
==Üldstruktuur==&lt;br /&gt;
Antud kursus on jätk kursusele „Programmeerimine I“, milles pearõhk oli pööratud ülesande lahendusalgoritmi koostamisele. „Programmeerimine II“ annab lisaks vajalike teadmisi algoritmi realiseerimisele  kõrgkeele(C,C++,Java) keskkonnas.&lt;br /&gt;
&lt;br /&gt;
Kursus on jaotatud 4ks mooduliks, kus iga moodul sisaldab näiteülesandeid, mis tuleb õppimise käigus kindlasti läbi lahendada.&lt;br /&gt;
Kahes esimeses moodulis on komplektid teemaakohaseid  ülesandeid, millest vähemalt ühe lahenduse peaks saatma kursuse tuutorile, et kontrollida enda mõttekäiku. &lt;br /&gt;
&lt;br /&gt;
Kahes viimases moodulis on testid koos vastustega – soovitus:vastuseid mitte eelnevalt piiluda. Vastasel juhul võib tekkida näiv tunne ülesande lihtsuse ja materjali arusaadavuse kohta.&lt;br /&gt;
&lt;br /&gt;
Kolmandas moodulis on individuaalne kohustuslik kodune töö, mille lahendus tuleb vormistada vastavalt kursuse üldosas toodud juhendile.&lt;br /&gt;
Neljas moodul sisaldab  kodust ülesannet, mille lahendamist tuleks teha rühmatööna. Rühm peaks koosnema 3 liikmest ja selle moodustamine võiks toimuda kas foorumi kaudu või siis tuutori poolt. Ülesandes on jällegi kindlalt eristatavad osad: 1- sideandmebaasiga, päringud  2- andmetöötlus, vastavalt ülesandele 3-kasutajaliides algandmete sisestamiseks ja tulemuse kuvamiseks.&lt;br /&gt;
&lt;br /&gt;
Erandjuhuna võib õppija sooritada selle kodutöö üksinda, viimane on reegliks mikrokontrolleri programmeerimise valimisel kodutööks.&lt;br /&gt;
&lt;br /&gt;
===Ainerõhud moodulites===&lt;br /&gt;
C programmi koostamisel on eriline koht viitadel, millede asjatundlik kasutamine muudab programmi kiiremaks ja effektiivsemaks.&lt;br /&gt;
Programmi töö käigus saab andmete poole pöörduda kas muutuja nime kaudu(keskkond seostab ise asukohaga mälus) või viida kaudu(sisaldab andmete asukoha mäluaadressit). Eriti selgelt väljendub viimase kasutamise effektiivsus töös massiividega. On selge, et ühest programmi moodulist , teise programmi moodulisse  massiivi edastamine palju ressursinõudlikum, kui ainult selle esimese elemendi edastus. Viidaga teeme aga just viimast!&lt;br /&gt;
&lt;br /&gt;
Teine tee andmetöötluse effektiivsuse tõstmiseks on andmete ühildamine ühtseks muutujaks. Näiteks kui on meil ülesanne, kus nõutakse üliõpilaste keskmiste hinnete leidmist, on sellise struktuurse  muutuja kasutamine, mis sisaldab nii üliõpilase identifikaatorit, kui tema hindeid, tunduvalt arusaadavam, kui mitme erineva massiivi kasutuselevõtt. Objektorienteeritud programmeerimises(OOP) minnakse aga veelgi edasi ja ühendatakse struktuursed andmed neid töötlevate programmimoodulitega.&lt;br /&gt;
Kahes esimeses moodulis tuleb peatähelepanu keskendada viida mõistele ja selle kasutamise võimalustele.&lt;br /&gt;
Operatsioonisüsteem eraldab igale programmile sisemälus teatud mälu. Andmetele eraldavat osa juhib programm, kasutades kas statilist või dünaamilist mälueraldamist. Esimesel juhul peab kogu eraldatav mälu olema kirjeldatud programmi töö alguseks. Teisel juhul ei , töö käigus  saab mälu vajadus muutuda.&lt;br /&gt;
&lt;br /&gt;
Kolmas moodul ongi pühendatud dünaamilisele mälujaotusele, mis sisaldab alati kahte tegevust: mälu hõivamist ja selle vabastamist.  Üheks mälu dünaamilise kasutamise võtteks on rekursiooni kasutamine. Viimane võimaldab veel taandada ülesande keerukust, näiteks n! leidmine  asendub (n-1)! Leidmisega.Rekursiooni vale kasutamine aga „kurnab“ arvutiressursse. Selle temaatika kinnistamiseks tuleb sooritada esimene kodutöö.&lt;br /&gt;
&lt;br /&gt;
Neljas moodul on kokkuvõtlik ja võimaldab teise kodutöö sooritamisel kontrollida eelnenu omandamise taset. Samuti lõppeb neljas moodul kontrolltöö sooritamisega, mis annab eelduse edukaks eksamiks.&lt;br /&gt;
Moodulis pakutav , OOP tutvustav materjal, on lisamaterjali staatuses ja selle valdamine eksamil ei ole kohustuslik, kuid meeldiv võimalus näidata enda häid teadmisi.&lt;br /&gt;
&lt;br /&gt;
== Õppetöö ==&lt;br /&gt;
=== Kontrolltööd ===&lt;br /&gt;
I kontrolltöö 5. nädal kirjed ja failid (20p)&lt;br /&gt;
&lt;br /&gt;
II kontrolltöö 12. nädal dünaamiline mälujaotus (20p)&lt;br /&gt;
&lt;br /&gt;
Kontrolltööd toimuvad loengus.&lt;br /&gt;
&lt;br /&gt;
=== Kodused tööd ===&lt;br /&gt;
I kodune töö - 15p kirjed ja failid&lt;br /&gt;
&lt;br /&gt;
II kodune töö - 15p dünaamiline mälujaotus, rekursiivsus&lt;br /&gt;
&lt;br /&gt;
III kodune töö - 10p valikuline:&lt;br /&gt;
* mikrokontrolleri ülesanne&lt;br /&gt;
* andmebaasi ülesanne&lt;br /&gt;
Esimesed kaks kodust tööd peavad olema tehtud enne eeleksamit 16 nädal neljapäev. Kolmanda koduse töö tähtaeg kuni eksamisessiooni lõpuni.&lt;br /&gt;
&lt;br /&gt;
=== Praktika ===&lt;br /&gt;
Kokku on praktika eest võimalik kokku saada 36p&lt;br /&gt;
* kohaloleku eest 1p (kokku max 14p)&lt;br /&gt;
* tunniülesanded kokku max 22p. Sellest 4p moodustavad kaks külalispraktikumi:&lt;br /&gt;
** andmebaasi ülesanne max 2p&lt;br /&gt;
** mikrokontrolleri ülesanne max 2p&lt;br /&gt;
&lt;br /&gt;
=== Eksamieeldus === &lt;br /&gt;
# Eeleksami soorituse eelduseks on 61p enne 01.05.2017.&lt;br /&gt;
# Eksami soorituse eelduseks eksamisessioonil on 50p (praktika + kontrolltöö 1 + kontrolltöö 2 + boonus (max 10p))&lt;br /&gt;
&lt;br /&gt;
=== Eksam === &lt;br /&gt;
Eksami hinne kujuneb välja järgmiste punktide arvelt:&lt;br /&gt;
Kodutöö 1 + kodutöö 2 + kodutöö 3 + kirjalik eksamitöö(max 65p)&lt;br /&gt;
&lt;br /&gt;
Plagiaadikahtluse puhul on esitatud töö hindeks 1p. Punktide parandamiseks tuleb osata oma tööd kaitsta.&lt;br /&gt;
&lt;br /&gt;
==3. Kodutöö==&lt;br /&gt;
Kolmanda kodutöö tegemiseks on üliõpilasel valikuvabadus. Mõlemad kodutööd on sissejuhatuseks spetsiifilisematesse teemadesse. &lt;br /&gt;
# Andmebaasi ülesanne - Suunaga rohkem tarkvara ja infosüsteemide poole andes ülevaate andmebaaside kasutusest ja PostgreSQL andmebaasimootorist. Ülesande käigus tuleb luua minimalistlik õppeinfosüsteem, mis suhtleks andmebaasiga.&lt;br /&gt;
# Mikrokontrolleri ülesanne - Suunaga riistvaralähedasema programmeerimise poole. Ülesande käigus õpitakse mikrokontrollerit programmeerima.&lt;br /&gt;
===Andmebaasi kodutöö===&lt;br /&gt;
''Teemat puudutav [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/db_praks.pdf tunniülesanne]''&lt;br /&gt;
&lt;br /&gt;
* Antud ülesande kaal on 10p.&lt;br /&gt;
* Ette on antud olemasolev PostgreSQL andmebaas, mis sisaldab endas lihtsa kursuste haldamiseks mõeldud infosüsteemi andmeid. &lt;br /&gt;
Kõigepealt tuleks registreerida oma tudengikoodiga, mille tulemusena loodakse tudengikoodi nimega kasutaja ja sellele vastav andmebaas. Loodavas andmebaasis on olemas õigused nii kirjete lugemiseks, kui ka lisamiseks, muutmiseks ja kustutamiseks.&lt;br /&gt;
 '''[http://ewis.pld.ttu.ee/reg Registreerimine]'''&lt;br /&gt;
* Andmed ühendumiseks:&lt;br /&gt;
 Host: ewis.pld.ttu.ee&lt;br /&gt;
 Andmebaas: ''&amp;lt;tudengikood&amp;gt;''&lt;br /&gt;
 Port: 5432&lt;br /&gt;
 Kasutaja: ''&amp;lt;tudengikood&amp;gt;''&lt;br /&gt;
 Parool: ''&amp;lt;registreerimisel valitud parool&amp;gt;''&lt;br /&gt;
* Andmebaasi visuaalseks haldamiseks võib kasutada mõnda selleks ettenähtud tarkvara, nt&lt;br /&gt;
** PgAdmin III&lt;br /&gt;
** [http://ewis.pld.ttu.ee/mywebsql/ MyWebSQL]&lt;br /&gt;
** [http://ewis.pld.ttu.ee/phpPgAdmin/ phpPgAdmin]&lt;br /&gt;
* Andmestruktuur&lt;br /&gt;
[[File:Is_struct.png]]&lt;br /&gt;
* Kui on vajadus algne andmebaas taastada, siis selleks võib kasutada järgnevat SQL koodi - [http://ati.ttu.ee/~hkinks/iag0582/3%20kodune/create_tables.sql Link]&lt;br /&gt;
* Kodutöö saata aadressile '''hkinks@ati.ttu.ee'''&lt;br /&gt;
====Ülesanded====&lt;br /&gt;
Koostada tekstipõhise kasutajaliidesega programm, mis võimaldaks kasutada järgmist funktsionaalsust:&lt;br /&gt;
# Tudengi lisamine. Kasutajalt küsitakse: eesnimi, perekonnanimi, sünnikuupäev. Programm peaks looma iga tudengi jaoks unikaalse tudengikoodi. (2p)&lt;br /&gt;
# Tudengi muutmine ja kustutamine. (2p)&lt;br /&gt;
# Aine lisamine, muutmine, kustutamine. (2p)&lt;br /&gt;
# Hinde lisamine õpilasele vastava aine eest. Hinde lisamisel peaks ka uuendama kaalutud keskhinnet (student.average_grade) võttes arvesse ainepunkte (subject.credits). (2p)&lt;br /&gt;
# Tudengite otsing kkh põhjal. Nt. otsimaks keda eksmatrikuleerida, peaks saama anda ette tingimuse ''kaalutud keskhinne &amp;lt; 1'' või kellele cum laude anda tingimusel ''kaalutud keskhinne &amp;gt; 4.8''. (2p)&lt;br /&gt;
&lt;br /&gt;
Programm peab liidestuma etteantud andmebaasiga ning kasutama seda andmete lugemiseks ja hoiustamiseks.&lt;br /&gt;
&lt;br /&gt;
Suureks plussiks on:&lt;br /&gt;
* Sisendi valideerimine ehk programm ei jookse kokku ega lähe tsüklisse, kui sisestatakse näiteks numbri asemel täht.&lt;br /&gt;
* Makefile kasutus kompileerimisel.&lt;br /&gt;
&lt;br /&gt;
====PostgreSQL teegiga koodi kompileerimine====&lt;br /&gt;
Selleks, et kirjutada C koodi, mis ühenduks PostgreSQL andmebaasiga, on vaja eelnevalt paigaldada vastav ''connector'' teek (libpq) ja kompilaatorile selgeks teha, kust neid leida.&lt;br /&gt;
&lt;br /&gt;
Kompileerida on kõige lihtsam kasutades TTÜ klassiarvuteid, kus on PostgreSQL eelnevalt paigaldatud. Selleks tuleks SSH abil ühenduda mõnda klassiarvutisse. Selle kohta on põhjalikumad juhendid:&lt;br /&gt;
*[http://ati.ttu.ee/wiki/index.php/Arvutiklassis_t%C3%B6%C3%B6tamise_juhend#Ligip.C3.A4.C3.A4s_v.C3.A4ljastpoolt_.C3.BClikooli_sisev.C3.B5rke Üldisem info väljastpoolt sisevõrku töötamise kohta]&lt;br /&gt;
*[http://mini.li.ttu.ee/~priit/IAY0340.2013/ssh_setup/putty_guide.html Piltidega juhend Putty kohta]&lt;br /&gt;
&lt;br /&gt;
Kui on sellegipoolest soovi enda arvutis kõnealune libpq teek ise paigaldada, siis abiks on järgnev juhend:&lt;br /&gt;
*[[PostgreSQL setup]]&lt;br /&gt;
&lt;br /&gt;
Kompileerides tuleks kindlasti lisada oma C koodis vastav teek:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;C&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;pgsql/libpg-fe.h&amp;gt;&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
Kui olete teegi ise paigaldanud, siis selle asukoht võib varieeruda ja peaksite asendama nt ''#include &amp;lt;libpg-fe.h&amp;gt;''.&lt;br /&gt;
&lt;br /&gt;
Kompileerimisel tuleb anda ka lisaargument linkerile '''-lpq'''. Näiteks ''gcc -o program main.c -lpq''.&lt;br /&gt;
====Abimaterjalid====&lt;br /&gt;
* [http://www.postgresql.org/docs/9.1/interactive/index.html PostgreSQL dokumentatsioon]&lt;br /&gt;
* [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/sql-cheat-sheet.pdf SQL cheatsheet]&lt;br /&gt;
* Ülesannet võib lahendada meelepärases programmeerimiskeeles. C kohta on olemas näidiskood ja põhjalikum juhis kompileerimiseks. Java puhul on toodud samuti näidisprogramm, kuid ülejäänud keelte puhul tuleks PostgreSQL andmebaasiga ühenduse loomine iseseisvalt selgeks teha.&lt;br /&gt;
&lt;br /&gt;
=====C Näidiskood=====&lt;br /&gt;
[http://ati.ttu.ee/~hkinks/iag0582/praktikum11/psql.c Näidiskood] - loob ühenduse eelnimetatud PostgreSQL andmebaasiga ja pärib 10 esimest kirjet.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Mikrokontrolleri ülesanne ===&lt;br /&gt;
Juhendi leiab aadressilt [http://blue.pri.ee/ttu/ http://blue.pri.ee/ttu/]&lt;/div&gt;</summary>
		<author><name>Hkinks</name></author>	</entry>

	<entry>
		<id>https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programmeerimine_II&amp;diff=2485</id>
		<title>IAG0582 - Programmeerimine II</title>
		<link rel="alternate" type="text/html" href="https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programmeerimine_II&amp;diff=2485"/>
				<updated>2017-02-02T09:44:47Z</updated>
		
		<summary type="html">&lt;p&gt;Hkinks: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[IAG0582 - Programming II|English course page]] [[File:United Kingdom.png|32px|link=IAG0582 - Programming II]]&lt;br /&gt;
&lt;br /&gt;
== Materjalid == &lt;br /&gt;
[https://ois.ttu.ee/portal/page?_pageid=35,428610&amp;amp;_dad=portal&amp;amp;_schema=PORTAL&amp;amp;p_msg=&amp;amp;p_public=1&amp;amp;p_what=3&amp;amp;p_lang=ET&amp;amp;p_open_node2=107&amp;amp;p_session_id=2886060&amp;amp;p_id=100821&amp;amp;p_mode=1&amp;amp;p_pageid=OKM_AINE_WEB_OTSING Ainekaart]&lt;br /&gt;
&lt;br /&gt;
Vladimir Viies - http://www.tud.ttu.ee/im/Vladimir.Viies/materials/IAG0581,IAG0582,PROGRAMMEERIMINE/PR2/&lt;br /&gt;
&lt;br /&gt;
Risto Heinsar - http://www.blue.pri.ee/ttu/&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Lembit Jürimägi - http://ati.ttu.ee/~lembit/prog2/&lt;br /&gt;
&lt;br /&gt;
''Vanad materjalid''&lt;br /&gt;
Hannes Kinks - http://ati.ttu.ee/~hkinks/iag0582, http://git.hkinks.com/hkinks/iag0582/tree/master&lt;br /&gt;
''&amp;lt;u&amp;gt;Helena Kruus - http://www.tud.ttu.ee/im/Vladimir.Viies/materials/Helena_materjalid/iag0582/&amp;lt;/u&amp;gt;''&lt;br /&gt;
&lt;br /&gt;
===Moodle materjalid===&lt;br /&gt;
Ise registreerumisega kursusele &amp;quot;IAG0582 Programmeerimine II&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
https://moodle.hitsa.ee/course/view.php?id=4710&lt;br /&gt;
&lt;br /&gt;
==Üldstruktuur==&lt;br /&gt;
Antud kursus on jätk kursusele „Programmeerimine I“, milles pearõhk oli pööratud ülesande lahendusalgoritmi koostamisele. „Programmeerimine II“ annab lisaks vajalike teadmisi algoritmi realiseerimisele  kõrgkeele(C,C++,Java) keskkonnas.&lt;br /&gt;
&lt;br /&gt;
Kursus on jaotatud 4ks mooduliks, kus iga moodul sisaldab näiteülesandeid, mis tuleb õppimise käigus kindlasti läbi lahendada.&lt;br /&gt;
Kahes esimeses moodulis on komplektid teemaakohaseid  ülesandeid, millest vähemalt ühe lahenduse peaks saatma kursuse tuutorile, et kontrollida enda mõttekäiku. &lt;br /&gt;
&lt;br /&gt;
Kahes viimases moodulis on testid koos vastustega – soovitus:vastuseid mitte eelnevalt piiluda. Vastasel juhul võib tekkida näiv tunne ülesande lihtsuse ja materjali arusaadavuse kohta.&lt;br /&gt;
&lt;br /&gt;
Kolmandas moodulis on individuaalne kohustuslik kodune töö, mille lahendus tuleb vormistada vastavalt kursuse üldosas toodud juhendile.&lt;br /&gt;
Neljas moodul sisaldab  kodust ülesannet, mille lahendamist tuleks teha rühmatööna. Rühm peaks koosnema 3 liikmest ja selle moodustamine võiks toimuda kas foorumi kaudu või siis tuutori poolt. Ülesandes on jällegi kindlalt eristatavad osad: 1- sideandmebaasiga, päringud  2- andmetöötlus, vastavalt ülesandele 3-kasutajaliides algandmete sisestamiseks ja tulemuse kuvamiseks.&lt;br /&gt;
&lt;br /&gt;
Erandjuhuna võib õppija sooritada selle kodutöö üksinda, viimane on reegliks mikrokontrolleri programmeerimise valimisel kodutööks.&lt;br /&gt;
&lt;br /&gt;
===Ainerõhud moodulites===&lt;br /&gt;
C programmi koostamisel on eriline koht viitadel, millede asjatundlik kasutamine muudab programmi kiiremaks ja effektiivsemaks.&lt;br /&gt;
Programmi töö käigus saab andmete poole pöörduda kas muutuja nime kaudu(keskkond seostab ise asukohaga mälus) või viida kaudu(sisaldab andmete asukoha mäluaadressit). Eriti selgelt väljendub viimase kasutamise effektiivsus töös massiividega. On selge, et ühest programmi moodulist , teise programmi moodulisse  massiivi edastamine palju ressursinõudlikum, kui ainult selle esimese elemendi edastus. Viidaga teeme aga just viimast!&lt;br /&gt;
&lt;br /&gt;
Teine tee andmetöötluse effektiivsuse tõstmiseks on andmete ühildamine ühtseks muutujaks. Näiteks kui on meil ülesanne, kus nõutakse üliõpilaste keskmiste hinnete leidmist, on sellise struktuurse  muutuja kasutamine, mis sisaldab nii üliõpilase identifikaatorit, kui tema hindeid, tunduvalt arusaadavam, kui mitme erineva massiivi kasutuselevõtt. Objektorienteeritud programmeerimises(OOP) minnakse aga veelgi edasi ja ühendatakse struktuursed andmed neid töötlevate programmimoodulitega.&lt;br /&gt;
Kahes esimeses moodulis tuleb peatähelepanu keskendada viida mõistele ja selle kasutamise võimalustele.&lt;br /&gt;
Operatsioonisüsteem eraldab igale programmile sisemälus teatud mälu. Andmetele eraldavat osa juhib programm, kasutades kas statilist või dünaamilist mälueraldamist. Esimesel juhul peab kogu eraldatav mälu olema kirjeldatud programmi töö alguseks. Teisel juhul ei , töö käigus  saab mälu vajadus muutuda.&lt;br /&gt;
&lt;br /&gt;
Kolmas moodul ongi pühendatud dünaamilisele mälujaotusele, mis sisaldab alati kahte tegevust: mälu hõivamist ja selle vabastamist.  Üheks mälu dünaamilise kasutamise võtteks on rekursiooni kasutamine. Viimane võimaldab veel taandada ülesande keerukust, näiteks n! leidmine  asendub (n-1)! Leidmisega.Rekursiooni vale kasutamine aga „kurnab“ arvutiressursse. Selle temaatika kinnistamiseks tuleb sooritada esimene kodutöö.&lt;br /&gt;
&lt;br /&gt;
Neljas moodul on kokkuvõtlik ja võimaldab teise kodutöö sooritamisel kontrollida eelnenu omandamise taset. Samuti lõppeb neljas moodul kontrolltöö sooritamisega, mis annab eelduse edukaks eksamiks.&lt;br /&gt;
Moodulis pakutav , OOP tutvustav materjal, on lisamaterjali staatuses ja selle valdamine eksamil ei ole kohustuslik, kuid meeldiv võimalus näidata enda häid teadmisi.&lt;br /&gt;
&lt;br /&gt;
== Õppetöö ==&lt;br /&gt;
=== Kontrolltööd ===&lt;br /&gt;
I kontrolltöö 5. nädal kirjed ja failid (20p)&lt;br /&gt;
&lt;br /&gt;
II kontrolltöö 12. nädal dünaamiline mälujaotus (20p)&lt;br /&gt;
&lt;br /&gt;
Kontrolltööd toimuvad loengus.&lt;br /&gt;
&lt;br /&gt;
=== Kodused tööd ===&lt;br /&gt;
I kodune töö - 15p kirjed ja failid&lt;br /&gt;
&lt;br /&gt;
II kodune töö - 15p dünaamiline mälujaotus, rekursiivsus&lt;br /&gt;
&lt;br /&gt;
III kodune töö - 10p valikuline:&lt;br /&gt;
* mikrokontrolleri ülesanne&lt;br /&gt;
* andmebaasi ülesanne&lt;br /&gt;
Esimesed kaks kodust tööd peavad olema tehtud enne eeleksamit 16 nädal neljapäev. Kolmanda koduse töö tähtaeg kuni eksamisessiooni lõpuni.&lt;br /&gt;
&lt;br /&gt;
=== Praktika ===&lt;br /&gt;
Kokku on praktika eest võimalik kokku saada 36p&lt;br /&gt;
* kohaloleku eest 1p (kokku max 14p)&lt;br /&gt;
* tunniülesanded kokku max 22p. Sellest 4p moodustavad kaks külalispraktikumi:&lt;br /&gt;
** andmebaasi ülesanne max 2p&lt;br /&gt;
** mikrokontrolleri ülesanne max 2p&lt;br /&gt;
&lt;br /&gt;
=== Eksamieeldus === &lt;br /&gt;
# Eeleksami soorituse eelduseks on 61p enne 01.05.2017.&lt;br /&gt;
# Eksami soorituse eelduseks eksamisessioonil on 50p (praktika + kontrolltöö 1 + kontrolltöö 2 + boonus (max 10p))&lt;br /&gt;
&lt;br /&gt;
=== Eksam === &lt;br /&gt;
Eksami hinne kujuneb välja järgmiste punktide arvelt:&lt;br /&gt;
Kodutöö 1 + kodutöö 2 + kodutöö 3 + kirjalik eksamitöö(max 65p)&lt;br /&gt;
&lt;br /&gt;
Plagiaadikahtluse puhul on esitatud töö hindeks 1p. Punktide parandamiseks tuleb osata oma tööd kaitsta.&lt;br /&gt;
&lt;br /&gt;
==3. Kodutöö==&lt;br /&gt;
Kolmanda kodutöö tegemiseks on üliõpilasel valikuvabadus. Mõlemad kodutööd on sissejuhatuseks spetsiifilisematesse teemadesse. &lt;br /&gt;
# Andmebaasi ülesanne - Suunaga rohkem tarkvara ja infosüsteemide poole andes ülevaate andmebaaside kasutusest ja PostgreSQL andmebaasimootorist. Ülesande käigus tuleb luua minimalistlik õppeinfosüsteem, mis suhtleks andmebaasiga.&lt;br /&gt;
# Mikrokontrolleri ülesanne - Suunaga riistvaralähedasema programmeerimise poole. Ülesande käigus õpitakse mikrokontrollerit programmeerima.&lt;br /&gt;
===Andmebaasi kodutöö===&lt;br /&gt;
''Teemat puudutav [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/db_praks.pdf tunniülesanne]''&lt;br /&gt;
&lt;br /&gt;
* Antud ülesande kaal on 10p.&lt;br /&gt;
* Ette on antud olemasolev PostgreSQL andmebaas, mis sisaldab endas lihtsa kursuste haldamiseks mõeldud infosüsteemi andmeid. &lt;br /&gt;
Kõigepealt tuleks registreerida oma tudengikoodiga, mille tulemusena loodakse tudengikoodi nimega kasutaja ja sellele vastav andmebaas. Loodavas andmebaasis on olemas õigused nii kirjete lugemiseks, kui ka lisamiseks, muutmiseks ja kustutamiseks.&lt;br /&gt;
 '''[http://ewis.pld.ttu.ee/reg Registreerimine]'''&lt;br /&gt;
* Andmed ühendumiseks:&lt;br /&gt;
 Host: ewis.pld.ttu.ee&lt;br /&gt;
 Andmebaas: ''&amp;lt;tudengikood&amp;gt;''&lt;br /&gt;
 Port: 5432&lt;br /&gt;
 Kasutaja: ''&amp;lt;tudengikood&amp;gt;''&lt;br /&gt;
 Parool: ''&amp;lt;registreerimisel valitud parool&amp;gt;''&lt;br /&gt;
* Andmebaasi visuaalseks haldamiseks võib kasutada mõnda selleks ettenähtud tarkvara, nt&lt;br /&gt;
** PgAdmin III&lt;br /&gt;
** [http://ewis.pld.ttu.ee/mywebsql/ MyWebSQL]&lt;br /&gt;
** [http://ewis.pld.ttu.ee/phpPgAdmin/ phpPgAdmin]&lt;br /&gt;
* Andmestruktuur&lt;br /&gt;
[[File:Is_struct.png]]&lt;br /&gt;
* Kui on vajadus algne andmebaas taastada, siis selleks võib kasutada järgnevat SQL koodi - [http://ati.ttu.ee/~hkinks/iag0582/3%20kodune/create_tables.sql Link]&lt;br /&gt;
* Kodutöö saata aadressile '''hkinks@ati.ttu.ee'''&lt;br /&gt;
====Ülesanded====&lt;br /&gt;
Koostada tekstipõhise kasutajaliidesega programm, mis võimaldaks kasutada järgmist funktsionaalsust:&lt;br /&gt;
# Tudengi lisamine. Kasutajalt küsitakse: eesnimi, perekonnanimi, sünnikuupäev. Programm peaks looma iga tudengi jaoks unikaalse tudengikoodi. (2p)&lt;br /&gt;
# Tudengi muutmine ja kustutamine. (2p)&lt;br /&gt;
# Aine lisamine, muutmine, kustutamine. (2p)&lt;br /&gt;
# Hinde lisamine õpilasele vastava aine eest. Hinde lisamisel peaks ka uuendama kaalutud keskhinnet (student.average_grade) võttes arvesse ainepunkte (subject.credits). (2p)&lt;br /&gt;
# Tudengite otsing kkh põhjal. Nt. otsimaks keda eksmatrikuleerida, peaks saama anda ette tingimuse ''kaalutud keskhinne &amp;lt; 1'' või kellele cum laude anda tingimusel ''kaalutud keskhinne &amp;gt; 4.8''. (2p)&lt;br /&gt;
&lt;br /&gt;
Programm peab liidestuma etteantud andmebaasiga ning kasutama seda andmete lugemiseks ja hoiustamiseks.&lt;br /&gt;
&lt;br /&gt;
Suureks plussiks on:&lt;br /&gt;
* Sisendi valideerimine ehk programm ei jookse kokku ega lähe tsüklisse, kui sisestatakse näiteks numbri asemel täht.&lt;br /&gt;
* Makefile kasutus kompileerimisel.&lt;br /&gt;
&lt;br /&gt;
====PostgreSQL teegiga koodi kompileerimine====&lt;br /&gt;
Selleks, et kirjutada C koodi, mis ühenduks PostgreSQL andmebaasiga, on vaja eelnevalt paigaldada vastav ''connector'' teek (libpq) ja kompilaatorile selgeks teha, kust neid leida.&lt;br /&gt;
&lt;br /&gt;
Kompileerida on kõige lihtsam kasutades TTÜ klassiarvuteid, kus on PostgreSQL eelnevalt paigaldatud. Selleks tuleks SSH abil ühenduda mõnda klassiarvutisse. Selle kohta on põhjalikumad juhendid:&lt;br /&gt;
*[http://ati.ttu.ee/wiki/index.php/Arvutiklassis_t%C3%B6%C3%B6tamise_juhend#Ligip.C3.A4.C3.A4s_v.C3.A4ljastpoolt_.C3.BClikooli_sisev.C3.B5rke Üldisem info väljastpoolt sisevõrku töötamise kohta]&lt;br /&gt;
*[http://mini.li.ttu.ee/~priit/IAY0340.2013/ssh_setup/putty_guide.html Piltidega juhend Putty kohta]&lt;br /&gt;
&lt;br /&gt;
Kui on sellegipoolest soovi enda arvutis kõnealune libpq teek ise paigaldada, siis abiks on järgnev juhend:&lt;br /&gt;
*[[PostgreSQL setup]]&lt;br /&gt;
&lt;br /&gt;
Kompileerides tuleks kindlasti lisada oma C koodis vastav teek:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;C&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;pgsql/libpg-fe.h&amp;gt;&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
Kui olete teegi ise paigaldanud, siis selle asukoht võib varieeruda ja peaksite asendama nt ''#include &amp;lt;libpg-fe.h&amp;gt;''.&lt;br /&gt;
&lt;br /&gt;
Kompileerimisel tuleb anda ka lisaargument linkerile '''-lpq'''. Näiteks ''gcc -o program main.c -lpq''.&lt;br /&gt;
====Abimaterjalid====&lt;br /&gt;
* [http://www.postgresql.org/docs/9.1/interactive/index.html PostgreSQL dokumentatsioon]&lt;br /&gt;
* [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/sql-cheat-sheet.pdf SQL cheatsheet]&lt;br /&gt;
* Ülesannet võib lahendada meelepärases programmeerimiskeeles. C kohta on olemas näidiskood ja põhjalikum juhis kompileerimiseks. Java puhul on toodud samuti näidisprogramm, kuid ülejäänud keelte puhul tuleks PostgreSQL andmebaasiga ühenduse loomine iseseisvalt selgeks teha.&lt;br /&gt;
&lt;br /&gt;
=====C Näidiskood=====&lt;br /&gt;
[http://ati.ttu.ee/~hkinks/iag0582/praktikum11/psql.c Näidiskood] - loob ühenduse eelnimetatud PostgreSQL andmebaasiga ja pärib 10 esimest kirjet.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Mikrokontrolleri ülesanne ===&lt;br /&gt;
Juhendi leiab aadressilt [http://blue.pri.ee/ttu/ http://blue.pri.ee/ttu/]&lt;/div&gt;</summary>
		<author><name>Hkinks</name></author>	</entry>

	<entry>
		<id>https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programmeerimine_II&amp;diff=2484</id>
		<title>IAG0582 - Programmeerimine II</title>
		<link rel="alternate" type="text/html" href="https://strudel.pld.ttu.ee/wiki/e/index.php?title=IAG0582_-_Programmeerimine_II&amp;diff=2484"/>
				<updated>2017-02-02T09:40:59Z</updated>
		
		<summary type="html">&lt;p&gt;Hkinks: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[IAG0582 - Programming II|English course page]] [[File:United Kingdom.png|32px|link=IAG0582 - Programming II]]&lt;br /&gt;
&lt;br /&gt;
== Materjalid == &lt;br /&gt;
[https://ois.ttu.ee/portal/page?_pageid=35,428610&amp;amp;_dad=portal&amp;amp;_schema=PORTAL&amp;amp;p_msg=&amp;amp;p_public=1&amp;amp;p_what=3&amp;amp;p_lang=ET&amp;amp;p_open_node2=107&amp;amp;p_session_id=2886060&amp;amp;p_id=100821&amp;amp;p_mode=1&amp;amp;p_pageid=OKM_AINE_WEB_OTSING Ainekaart]&lt;br /&gt;
&lt;br /&gt;
Vladimir Viies - http://www.tud.ttu.ee/im/Vladimir.Viies/materials/IAG0581,IAG0582,PROGRAMMEERIMINE/PR2/&lt;br /&gt;
&lt;br /&gt;
Risto Heinsar - http://www.blue.pri.ee/ttu/&lt;br /&gt;
&lt;br /&gt;
Hannes Kinks - http://ati.ttu.ee/~hkinks/iag0582, http://git.hkinks.com/hkinks/iag0582/tree/master&lt;br /&gt;
&lt;br /&gt;
Lembit Jürimägi - http://ati.ttu.ee/~lembit/prog2/&lt;br /&gt;
&lt;br /&gt;
''Vanad materjalid''&lt;br /&gt;
&lt;br /&gt;
''Helena Kruus - http://www.tud.ttu.ee/im/Vladimir.Viies/materials/Helena_materjalid/iag0582/''&lt;br /&gt;
&lt;br /&gt;
===Moodle materjalid===&lt;br /&gt;
Ise registreerumisega kursusele &amp;quot;IAG0582 Programmeerimine II&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
https://moodle.hitsa.ee/course/view.php?id=4710&lt;br /&gt;
&lt;br /&gt;
==Üldstruktuur==&lt;br /&gt;
Antud kursus on jätk kursusele „Programmeerimine I“, milles pearõhk oli pööratud ülesande lahendusalgoritmi koostamisele. „Programmeerimine II“ annab lisaks vajalike teadmisi algoritmi realiseerimisele  kõrgkeele(C,C++,Java) keskkonnas.&lt;br /&gt;
&lt;br /&gt;
Kursus on jaotatud 4ks mooduliks, kus iga moodul sisaldab näiteülesandeid, mis tuleb õppimise käigus kindlasti läbi lahendada.&lt;br /&gt;
Kahes esimeses moodulis on komplektid teemaakohaseid  ülesandeid, millest vähemalt ühe lahenduse peaks saatma kursuse tuutorile, et kontrollida enda mõttekäiku. &lt;br /&gt;
&lt;br /&gt;
Kahes viimases moodulis on testid koos vastustega – soovitus:vastuseid mitte eelnevalt piiluda. Vastasel juhul võib tekkida näiv tunne ülesande lihtsuse ja materjali arusaadavuse kohta.&lt;br /&gt;
&lt;br /&gt;
Kolmandas moodulis on individuaalne kohustuslik kodune töö, mille lahendus tuleb vormistada vastavalt kursuse üldosas toodud juhendile.&lt;br /&gt;
Neljas moodul sisaldab  kodust ülesannet, mille lahendamist tuleks teha rühmatööna. Rühm peaks koosnema 3 liikmest ja selle moodustamine võiks toimuda kas foorumi kaudu või siis tuutori poolt. Ülesandes on jällegi kindlalt eristatavad osad: 1- sideandmebaasiga, päringud  2- andmetöötlus, vastavalt ülesandele 3-kasutajaliides algandmete sisestamiseks ja tulemuse kuvamiseks.&lt;br /&gt;
&lt;br /&gt;
Erandjuhuna võib õppija sooritada selle kodutöö üksinda, viimane on reegliks mikrokontrolleri programmeerimise valimisel kodutööks.&lt;br /&gt;
&lt;br /&gt;
===Ainerõhud moodulites===&lt;br /&gt;
C programmi koostamisel on eriline koht viitadel, millede asjatundlik kasutamine muudab programmi kiiremaks ja effektiivsemaks.&lt;br /&gt;
Programmi töö käigus saab andmete poole pöörduda kas muutuja nime kaudu(keskkond seostab ise asukohaga mälus) või viida kaudu(sisaldab andmete asukoha mäluaadressit). Eriti selgelt väljendub viimase kasutamise effektiivsus töös massiividega. On selge, et ühest programmi moodulist , teise programmi moodulisse  massiivi edastamine palju ressursinõudlikum, kui ainult selle esimese elemendi edastus. Viidaga teeme aga just viimast!&lt;br /&gt;
&lt;br /&gt;
Teine tee andmetöötluse effektiivsuse tõstmiseks on andmete ühildamine ühtseks muutujaks. Näiteks kui on meil ülesanne, kus nõutakse üliõpilaste keskmiste hinnete leidmist, on sellise struktuurse  muutuja kasutamine, mis sisaldab nii üliõpilase identifikaatorit, kui tema hindeid, tunduvalt arusaadavam, kui mitme erineva massiivi kasutuselevõtt. Objektorienteeritud programmeerimises(OOP) minnakse aga veelgi edasi ja ühendatakse struktuursed andmed neid töötlevate programmimoodulitega.&lt;br /&gt;
Kahes esimeses moodulis tuleb peatähelepanu keskendada viida mõistele ja selle kasutamise võimalustele.&lt;br /&gt;
Operatsioonisüsteem eraldab igale programmile sisemälus teatud mälu. Andmetele eraldavat osa juhib programm, kasutades kas statilist või dünaamilist mälueraldamist. Esimesel juhul peab kogu eraldatav mälu olema kirjeldatud programmi töö alguseks. Teisel juhul ei , töö käigus  saab mälu vajadus muutuda.&lt;br /&gt;
&lt;br /&gt;
Kolmas moodul ongi pühendatud dünaamilisele mälujaotusele, mis sisaldab alati kahte tegevust: mälu hõivamist ja selle vabastamist.  Üheks mälu dünaamilise kasutamise võtteks on rekursiooni kasutamine. Viimane võimaldab veel taandada ülesande keerukust, näiteks n! leidmine  asendub (n-1)! Leidmisega.Rekursiooni vale kasutamine aga „kurnab“ arvutiressursse. Selle temaatika kinnistamiseks tuleb sooritada esimene kodutöö.&lt;br /&gt;
&lt;br /&gt;
Neljas moodul on kokkuvõtlik ja võimaldab teise kodutöö sooritamisel kontrollida eelnenu omandamise taset. Samuti lõppeb neljas moodul kontrolltöö sooritamisega, mis annab eelduse edukaks eksamiks.&lt;br /&gt;
Moodulis pakutav , OOP tutvustav materjal, on lisamaterjali staatuses ja selle valdamine eksamil ei ole kohustuslik, kuid meeldiv võimalus näidata enda häid teadmisi.&lt;br /&gt;
&lt;br /&gt;
== Õppetöö ==&lt;br /&gt;
=== Kontrolltööd ===&lt;br /&gt;
I kontrolltöö 5. nädal kirjed ja failid (20p)&lt;br /&gt;
&lt;br /&gt;
II kontrolltöö 12. nädal dünaamiline mälujaotus (20p)&lt;br /&gt;
&lt;br /&gt;
Kontrolltööd toimuvad loengus.&lt;br /&gt;
&lt;br /&gt;
=== Kodused tööd ===&lt;br /&gt;
I kodune töö - 15p kirjed ja failid&lt;br /&gt;
&lt;br /&gt;
II kodune töö - 15p dünaamiline mälujaotus, rekursiivsus&lt;br /&gt;
&lt;br /&gt;
III kodune töö - 10p valikuline:&lt;br /&gt;
* mikrokontrolleri ülesanne&lt;br /&gt;
* andmebaasi ülesanne&lt;br /&gt;
Esimesed kaks kodust tööd peavad olema tehtud enne eeleksamit 16 nädal neljapäev. Kolmanda koduse töö tähtaeg kuni eksamisessiooni lõpuni.&lt;br /&gt;
&lt;br /&gt;
=== Praktika ===&lt;br /&gt;
Kokku on praktika eest võimalik kokku saada 36p&lt;br /&gt;
* kohaloleku eest 1p (kokku max 14p)&lt;br /&gt;
* tunniülesanded kokku max 22p. Sellest 4p moodustavad kaks külalispraktikumi:&lt;br /&gt;
** andmebaasi ülesanne max 2p&lt;br /&gt;
** mikrokontrolleri ülesanne max 2p&lt;br /&gt;
&lt;br /&gt;
=== Eksamieeldus === &lt;br /&gt;
# Eeleksami soorituse eelduseks on 61p enne 1. maid.&lt;br /&gt;
# Eksami soorituse eelduseks eksamisessioonil on 50p (praktika + kontrolltöö 1 + kontrolltöö 2 + boonus (max 10p))&lt;br /&gt;
&lt;br /&gt;
=== Eksam === &lt;br /&gt;
Eksami hinne kujuneb välja järgmiste punktide arvelt:&lt;br /&gt;
Kodutöö 1 + kodutöö 2 + kodutöö 3 + kirjalik eksamitöö(max 65p)&lt;br /&gt;
&lt;br /&gt;
Plagiaadikahtluse puhul on esitatud töö hindeks 0p. Punktide parandamiseks tuleb osata oma tööd kaitsta.&lt;br /&gt;
&lt;br /&gt;
==3. Kodutöö==&lt;br /&gt;
Kolmanda kodutöö tegemiseks on üliõpilasel valikuvabadus. Mõlemad kodutööd on sissejuhatuseks spetsiifilisematesse teemadesse. &lt;br /&gt;
# Andmebaasi ülesanne - Suunaga rohkem tarkvara ja infosüsteemide poole andes ülevaate andmebaaside kasutusest ja PostgreSQL andmebaasimootorist. Ülesande käigus tuleb luua minimalistlik õppeinfosüsteem, mis suhtleks andmebaasiga.&lt;br /&gt;
# Mikrokontrolleri ülesanne - Suunaga riistvaralähedasema programmeerimise poole. Ülesande käigus õpitakse mikrokontrollerit programmeerima.&lt;br /&gt;
===Andmebaasi kodutöö===&lt;br /&gt;
''Teemat puudutav [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/db_praks.pdf tunniülesanne]''&lt;br /&gt;
&lt;br /&gt;
* Antud ülesande kaal on 10p.&lt;br /&gt;
* Ette on antud olemasolev PostgreSQL andmebaas, mis sisaldab endas lihtsa kursuste haldamiseks mõeldud infosüsteemi andmeid. &lt;br /&gt;
Kõigepealt tuleks registreerida oma tudengikoodiga, mille tulemusena loodakse tudengikoodi nimega kasutaja ja sellele vastav andmebaas. Loodavas andmebaasis on olemas õigused nii kirjete lugemiseks, kui ka lisamiseks, muutmiseks ja kustutamiseks.&lt;br /&gt;
 '''[http://ewis.pld.ttu.ee/reg Registreerimine]'''&lt;br /&gt;
* Andmed ühendumiseks:&lt;br /&gt;
 Host: ewis.pld.ttu.ee&lt;br /&gt;
 Andmebaas: ''&amp;lt;tudengikood&amp;gt;''&lt;br /&gt;
 Port: 5432&lt;br /&gt;
 Kasutaja: ''&amp;lt;tudengikood&amp;gt;''&lt;br /&gt;
 Parool: ''&amp;lt;registreerimisel valitud parool&amp;gt;''&lt;br /&gt;
* Andmebaasi visuaalseks haldamiseks võib kasutada mõnda selleks ettenähtud tarkvara, nt&lt;br /&gt;
** PgAdmin III&lt;br /&gt;
** [http://ewis.pld.ttu.ee/mywebsql/ MyWebSQL]&lt;br /&gt;
** [http://ewis.pld.ttu.ee/phpPgAdmin/ phpPgAdmin]&lt;br /&gt;
* Andmestruktuur&lt;br /&gt;
[[File:Is_struct.png]]&lt;br /&gt;
* Kui on vajadus algne andmebaas taastada, siis selleks võib kasutada järgnevat SQL koodi - [http://ati.ttu.ee/~hkinks/iag0582/3%20kodune/create_tables.sql Link]&lt;br /&gt;
* Kodutöö saata aadressile '''hkinks@ati.ttu.ee'''&lt;br /&gt;
====Ülesanded====&lt;br /&gt;
Koostada tekstipõhise kasutajaliidesega programm, mis võimaldaks kasutada järgmist funktsionaalsust:&lt;br /&gt;
# Tudengi lisamine. Kasutajalt küsitakse: eesnimi, perekonnanimi, sünnikuupäev. Programm peaks looma iga tudengi jaoks unikaalse tudengikoodi. (2p)&lt;br /&gt;
# Tudengi muutmine ja kustutamine. (2p)&lt;br /&gt;
# Aine lisamine, muutmine, kustutamine. (2p)&lt;br /&gt;
# Hinde lisamine õpilasele vastava aine eest. Hinde lisamisel peaks ka uuendama kaalutud keskhinnet (student.average_grade) võttes arvesse ainepunkte (subject.credits). (2p)&lt;br /&gt;
# Tudengite otsing kkh põhjal. Nt. otsimaks keda eksmatrikuleerida, peaks saama anda ette tingimuse ''kaalutud keskhinne &amp;lt; 1'' või kellele cum laude anda tingimusel ''kaalutud keskhinne &amp;gt; 4.8''. (2p)&lt;br /&gt;
&lt;br /&gt;
Programm peab liidestuma etteantud andmebaasiga ning kasutama seda andmete lugemiseks ja hoiustamiseks.&lt;br /&gt;
&lt;br /&gt;
Suureks plussiks on:&lt;br /&gt;
* Sisendi valideerimine ehk programm ei jookse kokku ega lähe tsüklisse, kui sisestatakse näiteks numbri asemel täht.&lt;br /&gt;
* Makefile kasutus kompileerimisel.&lt;br /&gt;
&lt;br /&gt;
====PostgreSQL teegiga koodi kompileerimine====&lt;br /&gt;
Selleks, et kirjutada C koodi, mis ühenduks PostgreSQL andmebaasiga, on vaja eelnevalt paigaldada vastav ''connector'' teek (libpq) ja kompilaatorile selgeks teha, kust neid leida.&lt;br /&gt;
&lt;br /&gt;
Kompileerida on kõige lihtsam kasutades TTÜ klassiarvuteid, kus on PostgreSQL eelnevalt paigaldatud. Selleks tuleks SSH abil ühenduda mõnda klassiarvutisse. Selle kohta on põhjalikumad juhendid:&lt;br /&gt;
*[http://ati.ttu.ee/wiki/index.php/Arvutiklassis_t%C3%B6%C3%B6tamise_juhend#Ligip.C3.A4.C3.A4s_v.C3.A4ljastpoolt_.C3.BClikooli_sisev.C3.B5rke Üldisem info väljastpoolt sisevõrku töötamise kohta]&lt;br /&gt;
*[http://mini.li.ttu.ee/~priit/IAY0340.2013/ssh_setup/putty_guide.html Piltidega juhend Putty kohta]&lt;br /&gt;
&lt;br /&gt;
Kui on sellegipoolest soovi enda arvutis kõnealune libpq teek ise paigaldada, siis abiks on järgnev juhend:&lt;br /&gt;
*[[PostgreSQL setup]]&lt;br /&gt;
&lt;br /&gt;
Kompileerides tuleks kindlasti lisada oma C koodis vastav teek:&lt;br /&gt;
&amp;lt;source lang=&amp;quot;C&amp;quot;&amp;gt;&lt;br /&gt;
#include &amp;lt;pgsql/libpg-fe.h&amp;gt;&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
Kui olete teegi ise paigaldanud, siis selle asukoht võib varieeruda ja peaksite asendama nt ''#include &amp;lt;libpg-fe.h&amp;gt;''.&lt;br /&gt;
&lt;br /&gt;
Kompileerimisel tuleb anda ka lisaargument linkerile '''-lpq'''. Näiteks ''gcc -o program main.c -lpq''.&lt;br /&gt;
====Abimaterjalid====&lt;br /&gt;
* [http://www.postgresql.org/docs/9.1/interactive/index.html PostgreSQL dokumentatsioon]&lt;br /&gt;
* [http://ati.ttu.ee/~hkinks/iag0582/praktikum11/sql-cheat-sheet.pdf SQL cheatsheet]&lt;br /&gt;
* Ülesannet võib lahendada meelepärases programmeerimiskeeles. C kohta on olemas näidiskood ja põhjalikum juhis kompileerimiseks. Java puhul on toodud samuti näidisprogramm, kuid ülejäänud keelte puhul tuleks PostgreSQL andmebaasiga ühenduse loomine iseseisvalt selgeks teha.&lt;br /&gt;
&lt;br /&gt;
=====C Näidiskood=====&lt;br /&gt;
[http://ati.ttu.ee/~hkinks/iag0582/praktikum11/psql.c Näidiskood] - loob ühenduse eelnimetatud PostgreSQL andmebaasiga ja pärib 10 esimest kirjet.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Mikrokontrolleri ülesanne ===&lt;br /&gt;
Juhendi leiab aadressilt [http://blue.pri.ee/ttu/ http://blue.pri.ee/ttu/]&lt;/div&gt;</summary>
		<author><name>Hkinks</name></author>	</entry>

	</feed>