Iti0101 2022
...ajalugu, suunad, põhialused, tehnoloogia, äri.
Ainekood: ITI0101 Õppejõud: Tanel Tammet |
Sisukord
- 1 NB! See on 2022 arhiiv, mitte kehtivad materjalid!
- 1.1 Eksamitulemused
- 1.2 Eksamite kava ja ajad
- 1.3 Kursuse eesmärk
- 1.4 Videosalvestused
- 1.5 Maht, aeg, tulemus
- 1.6 Kontrolltööd ja koduülesanded
- 1.7 Loengute plaan ja materjalid
- 1.7.1 1. nädal. Sissejuhatus: arvuti ja info, ajaloo algus ... 1940
- 1.7.2 2. nädal: Keskajalugu 1940-1960 ja arvuti riistvara
- 1.7.3 3. nädal: Keskajalugu 1970 ... 1990 ja masinalähedane programmeerimine
- 1.7.4 4. nädal: Algoritmid ja andmebaasid
- 1.7.5 5. nädal: Lähiajalugu 1990-2009 ja andmetüübid masinalähedaselt
- 1.7.6 6. nädal: Operatsioonisüsteemid ja tekstitöötlus
- 1.7.7 7. nädal: Interneti funktsioneerimine ja tabelarvutus
- 1.7.8 8. nädal: Programmeerimiskeeled ja veebirakendused.
- 1.7.9 9. nädal: Tarkvara arhitektuur ja tehisintellekt
- 1.7.10 10. nädal: Masinõpe ja plokiahelad
- 1.7.11 11. nädal: Andmevood ja andmelaod + ise-järelvaatamine: kuidas saada heaks programmeerijaks.
- 1.7.12 12. nädal: Küberkaitse ja algoritmid: lahenduvus.
- 1.7.13 13. nädal: Rekursioon, funktsionaal- ja loogiline progemine + loeng Wise (endine Transferwise) poolt
- 1.7.14 14. nädal: Plokiahelate jätk. Ajuteadus.
- 1.7.15 15. nädal: Konsultatsioon eksamiks, tarkvaraarendusprotsess ja IT äri + järelvaatamine: andmekaevandamine
- 1.8 Näiteid vanadest eksamitest
- 1.9 Kohustuslikud lugemismaterjalid
- 1.10 Loe iga päev
- 1.11 Kuula
NB! See on 2022 arhiiv, mitte kehtivad materjalid!
Eksamitulemused
Siin on
- IT sissejuhatuse tulemused 4. jaanuari eksami järel (2023)
- IT sissejuhatuse teise eksami (11. jaanuar) tulemused (2023). NB! Esimese, 4. jaanuari eksami tulemusi selles tabelis ei ole.
- IT sissejuhatuse kolmanda eksami (18. jaanuar) tulemused (2023). NB! Esimese ja teise eksami tulemusi selles tabelis ei ole.
Eksamite kava ja ajad
NB! Eksamile võta kaasa pildiga dokument (see esita õppejõule, kui valmis töö üle annad).
Eksamid teeme 2023 jaanuari eksamisessioonil kohapeal audikas, tehes igal eksamipäeval kaks sessiooni, iga sessiooni jaoks aega kaks tundi. Eeldatavalt piisab enamusele ühest tunnist.
Eksamipäevi on kolm ja eksamid toimuvad igal päeval kell 11:00 ja 14:00 IT kolledzhi auditooriumis ICO-314. Eksamipäevad on:
- 4. jaanuar: kell 11 IADB ja avatud ülikool, kell 14 kõik ülejäänud
- 11. jaanuar: kell 11 mitte (IADB või avatud ülikool), kell 14 IADB ja avatud ülikool
- 18. jaanuar: kell 11 IADB ja avatud ülikool, kell 14 kõik ülejäänud
Ehk siis tudengid on jaotatud eksamiaja (kell 11 või 14) järgi kaheks grupiks : A: IADB ja avatud ülikool, B: kõik ülejäänud.
Kui kellaaeg ei sobi, saab seda mõjuval põhjusel eelnevalt muuta õppejõule kirjutades (peab saama õppejõult kinnituse).
Kindlasti tulge eksamit tegema 4 või 11 jaanuaril, siis saate 18 jaanuari aega vajadusel kasutada järeleksamiks: see on mõeldud eeskätt uuesti tegemiseks, kui teil esimene eksam ebaõnnestus, või kui teil ei olnud võimalik tulla esimesel kellaajal. Kui eksam 4. või 11. jaanuaril läks OK, siis ei ole mõtet 18. jaanuaril uuesti tulla. Pärast 18. jaanuari enam eksameid/järeleksameid ei ole.
Eksamile registreerida ei ole vaja: järgi lihtsalt oma kellaaegasid.
Mida ja kuidas eksamiks õppida:
- Vaata korra üle siin lehel allpool olevad vanad näite-eksamid: eksami formaat tuleb samasugune, küsimused arusaadavalt veidi teistsugused.
- Eksamil küsitakse ainult asju, mis on loengumaterjalides (ppt, pdf) kirjas. Lisamaterjalide/linkide kohta küsimusi ei tule.
- Konkreetselt on iga nädala loengumaterjalide all kirjas, mis alamteemade kohta materjalidest küsimusi tuleb: st kõigi asjade kohta ei tule.
- Üldpõhimõttena ei tule eksamil küsimusi nö väikeste asjade või aastaarvude vms kohta materjalides: küsimusi tuleb asjade kohta, millele on pühendatud a la terve lehekülg.
- Ajaloo-teemade puhul ei tule küsimusi konkreetsete aastaarvude kohta, vaid pikema vahemiku kohta (mida vanem teema, seda pikem vahemik) millal umbes see-ja-see tehti/juhtus.
- Kindlasti tuleb küsimusi, kus te peate täitma tõeväärtustabeli ja / või ehitama paberil väikese elektroonikaskeemi, rehkendama lambda-termi või funktsionaalse keele avaldise tulemuse.
- Kindlasti tuleb üks lugemis-kontrolli küsimus siin lehel allpool toodud kohustusliku kirjanduse kohta.
Kursuse eesmärk
- Anda kokkusurutud ülevaade informaatikast tervikuna.
- Anda ajalooline ülevaade IT teooria, tehnoloogia ja äri arengust.
- Tutvustada edaspidiseid teemasid/loengukursusi stuudiumi vältel.
Videosalvestused
Loengu ajal on kättesaadav live feed.
Videoalvestuste lingid leiad allpool nädalate loengupresentatsioonide järel.
Maht, aeg, tulemus
Kaks järjestikkust loengut nädalas reedeti kuuenda korpuse auditooriumis U06A-229.
- Reedel kell 12:00: loeng eksamiks vajalike materjalide ja koduülesannetega. Õppejõud Tanel Tammet.
- Reedel kell 13:45: süvaloengud kitsamatel teemadel, tervikkursuste ülevaated ja teemasid tööstusest. Erinevad õppejõud. Ka siin antakse vahel koduülesandeid.
Sessiooniõppe sissejuhatav loeng on reedel, 2 septembril kell 17:45-19:15 ruumis ICT-315 (Akadeemia tee 15A)
Kursus lõpeb eksamiga. Eksam on kirjalik, kaks või enam tundi, kümme küsimust ja ülesannet.
Kursuse käigus on iga nädal vaja võrgus täita valikvastustega paarikümne küsimusega mikro-kontrolltöö ühe nädala materjalide kohta, aega selleks on loengupäevast kuni järgmise loengupäevani (siis tulevad uued materjalid). Koduülesanded - kui neid antakse - on kontrolltöö üheks osaks.
Nädala kontrolltööd publitseeritakse loengupäeva õhtul või järgmise päeva hommikul.
Samuti antakse kursuse käigus teha väikeseid harjutusi: need tuleb teha iseseisvalt ja tulemused vastata samades mikro-kontrolltöödes.
Kursuse hinne arvutatakse nii: eksamipunktid (0...100) + kontrolltööde summaarne tulemus. Positiivsed hinded algavad 50 punktist. Kaks viga kontrolltöös on üks veapunkt, neli kaks veapunkti jne, tegemata kontrolltöö on viis veapunkti. Tudengi kõigi kontrolltööde miinuspunktide summast lahutatakse keskmine kontrolltööde miinuspunktide summa, vahe ongi summaarne tulemus.
Kontrolltööd ja koduülesanded
Siin 2022 it sissejuhatuse kontrolltööde tulemused.
Kui sulle paistab, et kontrolltööd on valesti arvestatud või sul on selge sisuline põhjus mõnest puudumiseks (näiteks, olid kaitseväes, olid pikalt haige ja sul on arstitõend, jne), siis palun saada õppejõule email (tanel.tammet@ttu.ee) ja selgita probleemi detailselt ja konkreetselt.
Osadel kontrolltöid teinud tudengitel paistab olema puudu kehtiv deklareering it sissejuhatuse ainesse. Kui sinu tudengikood on järgmises loetelus ja sa tegelikult reaalselt õpid ja eksamile tuled, siis võta ühendust dekanaadiga, et olukorda kontrollida ja vajadusel oma deklaratsioon korda teha: 2022 it sissejuhatuse deklareerimata tudengid.
Loengute plaan ja materjalid
Kursusel ei ole ühtegi konkreetset õpikut. Järgnevas on toodud iga loenguga seotud materjalid eraldi.
Kursus jaguneb kaheks blokiks: esimene, lühem blokk on sissejuhatus ja ajaloopõhine tehnoloogiaülevaade, järgmised, põhiblokid on erinevad tehnoloogiad, arvutiteadus ja äri.
Loengute plaan on esialgne, töö käigus ilmub siia kindlasti muutusi. Seega, täpselt adekvaatsed ja õiged on need materjalid, mille loeng on kas juba läbi või tuleb järgmisena: kõik tuleviku-loenguid puudutavad materjalid on vanad, ning saavad loengu kättejõudmise ajaks mingil määral modifitseeritud ja täiendatud.
1. nädal. Sissejuhatus: arvuti ja info, ajaloo algus ... 1940
2. september.
- Kell 12: Sissejuhatus. Arvuti ja info kodeerimise põhimõtted.
- Loengumaterjal: itsissejuhatus1a22.ppt, itsissejuhatus1a22.pdf.
- Kell 14: Varane ajalugu. Industrialiseerimine. Teoreetilised alused. Loogika. Esimesed arvutid.
- Loengumaterjal: itsissejuhatus2a2.ppt, itsissejuhatus2a2.pdf
- Eksamiks: pead teadma suuruse-numbreid ja mida nad tähendavad: bitt, bait, kilobait, megabait jne; oskad selgitada, kuidas tähti kodeeritakse, mis on algoritm ja mis programm. Ajaloost: Kreeka loogikud, induktsioon, deduktsioon, süllogismid, lausearvutus (pead mh oskama tõeväärtustabelit koostada), Pascal, Leibniz, perfokaardid, kangasteljed, Babbage, Hollerith, colossus ja saksa krüptomasinad, Turing, Shannon, Zuse, esimesed programmeeritavad arvutid.
Lisaks esimesele loengule:
- vaata väikest Turingi masina videot
- loe läbi mõni nendest Paul Grahami (Y combinatori asutaja) esseedest: Why nerds are unpopular?, The lesson to unlearn, How to think for yourself.
- valdkonnad
Lisaks teisele loengule:
- Kruusi diskreetse matemaatika kursus!
- Paul Graham: What you'll wish you'd known
- Sama asi diskreetse matemaatika kursuses: harjuta lausearvutuse tõeväärtustabelite tegemist: vaata vanu eksamiülesandeid (1, 2, 3) tee ülesandeid ise juurde ja kasuta logictools.org/prop.html enesekontrolliks. Vajuta algul "help" nuppu, siis näed, kuidas valemeid kirjutada. Tõeväärtustabeli jaoks vajuta '"Build" a truth table' nuppu.
- Turingi masina simulaator ja alternatiivne simulaator
- Alustada: Loogika aine ja ajalugu
- lõpmatuse osa BBC dokumentaalsarjast
- Varastest masinatest:
- Jacquard'i kangasteljed
- QWERTY klaviatuuri päritolust ja teistsugune arvamus ja mõne eritähe ajalugu
- Näide olulisest analoogarvutist: Norden bombsight
- Inglise krüptosaaga: Colossus, Turing, sakslaste Enigma ja Lorenz SZ 40
- Esimesed digitaalsed elektriga töötavad arvutid:
- Konrad Zuse
- Atanasoffi elektronarvuti
- Mark I: esimene programmeeritav elektromehaaniline arvuti.
- Kuula Jim Kelleri episoodi "Moore’s Law, Microprocessors, Abstractions, and First Principles"
2. nädal: Keskajalugu 1940-1960 ja arvuti riistvara
9. september.
- Kell 12: Keskajalugu : II maailmasõda kuni kuuekümnendateni. Arvutid ja programmeerimine. Keeled ja rakendused. Integraalskeemid.
- Loengumaterjal: Itsissejuhatus3o.ppt, Itsissejuhatus3o.pdf.
- Kell 14:00: arvuti riistvara: transistorid, loogikalülitused, aritmeetika, mälu, programmid.
- Loengumaterjal: Itsissejuhatus_proc_21a.ppt, Itsissejuhatus_proc_21a.pdf.
- Eksamiks: transistor, Samuel, Shockley semiconductor, Fortran, Fairchild, Sage, Texas instruments, integraalskeem, cobol, lisp, pdp-1, system 360, moore's law, intel, amd, Engelbart, Unix, esimene mikroprotsessor. Relee, lihtsad elektroonikaskeemid, mitme biti liitja ja lahutaja, lihtsad mälutüübid. Peaksid oskama ehitada väikese loogikavalemi järgi loogikakomponentidest elektroonikaskeemi, mis seda realiseerib, samuti koostada paaribitiste sisendite liitjat/lahutajat, samuti kolme eraldi biti liitjat ja trigerit.
Lisaks esimesele loengule:
- Paul Graham: Undergraduation pluss järelmärkused: more advice for undergrads
- IBM-i varased mehaanilised tabulaatorid
- ferriitmälu
- Fortran ja IBM 704 ja taustaks raadiolampidega arvutite suur tabel
- Brittide varaseimad arvutid Manchesteris
- PDP-1 restoration project, ,Spacewar: esimene graafiline arvutimäng, ja ajaloo-video,töötav versioon javascriptis ja taustaks esimeste arvutimängude tabel
- Ivan Sutherland's sketchpad video vt ka sketchpadi artikkel
- Douglas Engelbart "mother of all demos"
- SAGE
- Counterculture
- Silicon Valley vt ka seda kaarti
- Whole earth catalog wikis
Lisaks teisele loengule riistvarast:
- Jim Kelleri episood A.I. podcastist
- lühike lugu transistoride kasutamisest loogikalülituste ehitamiseks ja vaata veidi täienduseks siit
- logic.ly demo (also 4-bit adder) or try 4-bit adder tutorial in detail: you can try out and edit half-built parts. See also this.
- Tore mõte on teha D.Ecki harjutusi, osad siit: Eck laborid. Need simulaatorid on väga vanad, aga töötavad endiselt OK. Vajavad javat ja kõige parem on nad alla laadida ja oma masinas käivitada: siit leiad õpetuse, kuidas seda teha. Süvene 4-biti liitjasse, kuni sa temast korralikult aru saad. Seejärel loe ise läbi, proovi ja tee mõlemist osast vähemalt üks harjutus, kus tuleb ise elektroonikaskeem ehitada:
- Head alternatiivsed simulaatorid katsetamiseks ja skeemide ehitamiseks:
- Minecraft: redstone ja arvutid
- introd siin ja siin ja loogikalülitused
- shock and awe: täielik 4-bitine arvuti minecraftis
- Veidi tutvuda nende saitidega:
- Loe, kuidas ARM chipid alguse said ja olid inspireeritud 6502 protsessorist:
- Protsessori simuleerimine ja ise ehitamine:
- Ecki xComputer: lihtne simulaator 6502 stiilis
- easy6502.org: päris täpne 6502 simulaator
- visual6502.org vt ka slaidid
- Build an 8-bit computer from scratch
- Mikrokontrollerid ja system on a chip:
- mikrokontrollerite ülevaade detailidega: kõik alla 1 dollari
- Raspberry Pi SOC
3. nädal: Keskajalugu 1970 ... 1990 ja masinalähedane programmeerimine
16. september
- Kell 12: Keskajalugu jätkub: seitsmekümnendad, kaheksakümnendad. Mikroprotsessorid. Mini-, mikro- ja persionaalarvutid.
- Loengumaterjal: Itsissejuhatus4o.ppt, Itsissejuhatus4o.pdf.
- Kell 14:00: Masinalähedane programmeerimine: assembler ja C.
- NB! Loengu powerpointi algus on hetkel põhiliselt kordamine: tegelik uus osa algab ca lk 21 ja seda kaetakse põhiliselt loengus interaktiivse demona, st materjalis on infot vähe. Väga soovitav on ise lugeda ja veidi harjutada Easy 6502 pisiõpikuga.
- Loengumaterjal: Itsissejuhatus_progealused_20.ppt, Itsissejuhatus_progealused_20.pdf.
- Tööta läbi nii palju Easy 6502 pisiõpikust kui jõuad.
- Loe The infinite space between words
- Loe Latency numbers ja soovitavalt lisaks palju detailsemalt
- Eksamiks: esimene mikroprotsessor, sql, arpanet, atari, cp/m, winchester, altair, alto, unix ja C, microsofti algus, apple algus, 1977 koduarvutid, visicalc, apple II, symbolics, ibm pc, sun, oracle, macintosh, apple ja microsofti tooteliinid. Riistvarast mälu tehnoloogia, cache ja mälu hierarhia, mis on assembler ja seos riistvaraga, mis on kompileerimine, linkimine, mis teeb loader.
Lisaks esimesele loengule:
- Jätk küsimusele "mida ülikoolis teha?". Joel Spolsky: Advice for Computer Science College Students
- soovitav kuulata: episood arvutimängudest MindScape podcastist ja mängi episoodi külalise paperclips mängu ja loe tausta
- Apple 1984 Macintosh: reklaamklipp ja Steve Jobs esitlemas ja 1985 mac office lemmings ja wiki
- intel 4004 skeemid, simulaatorid ja ajalugu, simulaator
- MOS 6502 simulaator ja easy 6502 pisiõpik ja terminaator oli progetud 6502 assembleris klipp
- Spacewar: esimene graafiline arvutimäng,töötav versioon javascriptis
- Atari muuseum
- mehaaniline pong ja taustaks
- SRI international
- Bell labs
- What the dormouse said raamatu täistekst ehk "how the 60s counterculture shaped the personal computer"
- Eric Raymond: How to become a hacker
- Colossal Cave (adventure) teksti-seiklusmäng online ja veidi vigane javascripti versioon. Vaata ka suuremat kollektsiooni vanade teksti-seiklusmängude javascripti-versioonidest.
- Magnavox odyssey
- Apple II Karateka simu (mängimiseks qwaszx(? või all paremal klahvid ?), tühik ja nooleklahvid). Vaata taustaks Karateka, Jordan Mechner ja Prince of Persia
Lisaks teisele loengule:
- Segaduses algajad
- Väga hea raamat riistvaralähedasest programmeerimisest: Computer Systems: A Programmer's Perspective. Randal E. Bryant and David R. O'Hallaron, Carnegie Mellon University
- Vaata, kuidas eri kompilaatorid assemblerit genereerivad
- Loe veidi ja uuri What every programmer should know about memory
- Väga vanade koduarvutite lag oli väiksem, kui praegustel: Computer latency: 1977-2017
4. nädal: Algoritmid ja andmebaasid
30. september
- Kell 12: Algoritmid: keerukus. Ülevaade kursusest. Õppejõud Marko Kääramees.
- Loengumaterjal: Algoritmid_2019.pdf.
- Kell 14 (mitte 13:45!): Erki Eessaar räägib andmebaasidest. Andmed, informatsioon, andmebaas, andmebaasisüsteem, SQL, NoSQL. SQLis (PostgreSQL) väike näide tabelite loomise ning andmete otsimise ja muutmise kohta.
- Loengumaterjal: Andmebaasidest_s2021.pdf ja täiendavalt xlsx ja sql näitefailid
- Eksamiks: mis on algoritmide keerukus, mida tähendab suur-O (a la O(n**2)) notatsioon, mis on sorteerimisalgoritmi parim keerukus halvimal juhul, mis on erinevus merge sorti ja selection sorti vahel: algoritmi ja keerukuse mõttes, mis operatsioonid on massiividel kiiremad / aeglasemad kui listil. (2) Mis asi on: andmebaas, andmebaasisüsteem, SQL.
Täiendavalt algoritmide teemal:
- sorteerimisalgoritmide visualiseeringud siin ja siin ja siin
- Eriliselt tore ja ilus visualiseeringutega jutt mitmete algoritmidega
- Väga paljude algoritmide ja andmestruktuuride visualiseeringud
- Suur O wikipedias ja lihtne cheatsheet
- Travelling salesman problem, [https://www.fourmilab.ch/documents/travelling/anneal/ simul
5. nädal: Lähiajalugu 1990-2009 ja andmetüübid masinalähedaselt
7. oktoober
- Kell 12: Lähiajalugu: kaheksakümnendate teine pool kuni 2009. IBM PC, Macintosh, uued vanad opsüsteemid, võrgundus ja veeb, market crash, iPhone, Android, Bitcoin, e-valimised.
- Loengumaterjal a osa:Itsissejuhatus5oa.ppt, Itsissejuhatus5oa.pdf.
- Loengumaterjal b osa:Itsissejuhatus5ob.ppt, Itsissejuhatus5ob.pdf.
- Loengumaterjal c osa:Itsissejuhatus5oc1.ppt, Itsissejuhatus5oc1.pdf.
- Kell 14:00: loeng andmetüüpidest masinalähedaselt: täisarvud, komadega arvud, stringid, massiivid, listid, puud, hashid jne.
- Loengumaterjal: itsissejuhatus6b.ppt, itsissejuhatus6b.pdf
- Eksamiks: Python, html ja http, internet eestis, linux, netscape, usenet, php, päevalehed eestis, palm pilot, google, deep blue, wikipedia, x-tee. Lihtsad andmetüübid, stringid, massiivid, puud, mis on pointer.
Lisaks produktiivsuse kasvu ja innovatsiooni aeglustumisest:
- global productivity slowdown
- Peter Thiel: we wanted flying cars, instead we got 140 characters ja hariduse eesmärkidest ja kommentaare sellele
- biotechi innovatsiooni aeglustumine ja kiirelt kasvavad kulud
- has progress in science and technology come to a halt?
- freakonomicsi podcast samal teemal
Lisaks ajaloost:
- Arvutimuuseum Tartu ülikoolis
- GUI ajalugu
- 101 arvutireklaami
- Arvutite ajaloolised tv-reklaamid
- "Teejuht võrgumeediasse" toorik aastatest 1995-1996. Pakub eeskätt ajaloolist huvi.
- Tutvu: J.Penjami lühiülevaade Eestis tehtud ja olnud varastest arvutitest
- Apple Macintoshi reklaamfilm: 1984
Lisaks andmete esitusest:
- ujukoma-arvude seletus ja detailsemalt wikipedias ja ajaloost
- how to implement strings
- ja kuidas python stringe optimeerib
- pythoni listid sisemiselt
- kataloog puude visualiseerimise viisidest
- hulk eri andmetüüpide visualiseeringuid
Muud huvitavat:
6. nädal: Operatsioonisüsteemid ja tekstitöötlus
14. oktoober.
- Kell 12: Operatsioonisüsteemid
- Loengumaterjal: Itsissejuhatus8a9.ppt, Itsissejuhatus8a9.pdf.
- Kell 13:45: Tekstitöötlus: Ivari Horm
- Esialgne loengumaterjal: teksti toimetamine. Lisaks (mittekohustuslik) on siin allpool lingid näitefailide algfailidele ja tulemustele.
- Eksamiks: Opsüsteemi roll, mis on distro, mis on Linux, mis on mac OS X, Android, protsessid, multitasking, paralleeltöö, wait/run, mis on interrupt, mis on virtuaalmälu. Tekstitöötlus: lihttekst, WYSIWYG, kooditabel, ascii, unicode, utf-8, mis on latex, markdown, nende plussid ja miinused, kus kasutatakse.
- Loenguvideo (teises loengus ei ole ekraanipilti kaasas: vaata paralleelselt ülalolevat loengumaterjali juurde)
Soovitavat katsetamist opsüsteemidega:
- levinux: eksperimenteerimiseks mõeldud mikro-linux: "tiny virtual Linux server that runs from USB or Dropbox with a double-click (no install or admin rights required) on Macs, Windows or Linux PCs"
- Linux windowsis - WSL - Microsofti õpetus
Eriti soovitavat lugemist opsüsteemidest:
Muidu soovitavat lugemist opsüsteemidest:
- Wikipedia artikkel opsüsteemidest
- Linux distributions
- päris hea opsüsteemide ehituse pisi-tutorial
- Ulrich Drepperi cache-lühiülevaade ja paralleelsuse-ülevaade
- üldse mitte kohustuslik (algajatel raske mõista :-) The Art of Unix Programming
- Minix: Linuxi inspiratsiooniks olnud mini-UNIX ja loe seda! ja viimase taustaks ja lisaks
- Unix history
- virtuaalmälu vikipeedias
- multitasking vikipeedias
- Väga detailne ülevaade mälu organiseerimisest
- Hea väike tehniline raamat sise-ehitusest
- Unixi autorite väike varane ülevaade põhi-ideedest
7. nädal: Interneti funktsioneerimine ja tabelarvutus
21. oktoober
- Kell 12: interneti funktsioneerimine: Ivo Müürsepp
- Loengumaterjal: Arvutivorgud_3.pdf: see on 2021 aasta Ivo materjal.
- Kell 13:45: tabelarvutus: Ivari Horm. Loengumaterjalide leht.
- Loenguvideo
- Eksamiks: Arvutivõrgud: mac aadress, ip aadress, port, ethernet, ip, tcp, udp, kapseldamine (mis mille sees). Päiste detailide kohta ei küsita. Tabelarvutuse teema: mismoodi kirjutatakse Excelis lihtsamaid valemeid.
Tutvuda lühidalt interneti funktsioneerimise teemal:
- Veeluste internetikaablite zoomitav kaart ja veel detailsem zoomitav kaart
- Kuidas veealused kaablid välja näevad
- Suurimad veebisaidid
- https://en.wikipedia.org/wiki/Internet_protocol_suite
- https://en.wikipedia.org/wiki/Internet_of_things
- steampunk film pakettide liikumisest
- How does the internet work?
- Huvi korral loe mahukamast protokollinduse kursusest lisa: Andmeside protokollid
8. nädal: Programmeerimiskeeled ja veebirakendused.
28. oktoober.
- Kell 12: Erinevad programmeerimiskeeled ja kompileerimine/interpreteerimine.
- Loengumaterjal: itsissejuhatus_keeled.ppt, itsissejuhatus_keeled.pdf,
- Kell 13:45: Veebirakendused. Loengumaterjal: Itsissejuhatus10a20.ppt, Itsissejuhatus10a20.pdf.
- Eksamiks: Kompileerimine, interpreteerimine, parsimine, jit, vahekood, programmeerimiskeeled vs kirjelduskeeled, json, html, sql, keelte äratundmine (assembler, fortran, cobol, lisp, C, modula/pascal, python). Veebirakendused: mis on http, https, html, css, javascript, ajax, json, xml, kuidas üldjoontes töötab klassikaline veebirakendus ja kuidas single-page app (koodinäiteid / nende detaile ei küsita).
- Loengusalvestus Echos ja alternatiivselt teamsis
Tillukeste interpretaatorite ja kompilaatorite koodinäited:
- õppejõu mikro-interpretaator pythonis
- tilluke lispi-interpretaator pythonis ja selle lähtekood. Autoriks Peter Norvig, vt ka Norvigi oma veebileht.
- tilluke lispi kompilaator pythonis
- pythonis kirjutatud pythoni interpretaator
- Keerukam: põhjalik interpretaatori-kirjutamise veebiraamat algajatele ja veel põhjalikum veebiraamat ja lihtsa kompilaatori näide ja õpetus
Tutvu veidi nende progekeelte populaarsus-võrdlustega:
- Tiobe programmeerimiskeelte populaarsusindeks
- Githubi progekeelte populaarsusindeks
- PYPL: populaarsus tutorialite Google-otsingute järgi
- Põhjalik Githubi repode analüüs mh keelte kaupa
- Nõudluse järgi üks populaarsusindeks
Siis vaata veidi neid asju:
Veebirakenduste teemal vaata veel:
Muud huvitavat:
- "technology is our hope if we can accept it as our enemy, but as our friend, it will destroy us"
- sissejuhatus optimeerimisse
- veel veidi sügavamalt optimeerimisest
- gcc optimeerimisparameetrid
- Why is SQLite written in C
- Pikk raamat päris tarkvarast päris algajatele
- Toredad Pythoni pisi-mängud programmeerimise harjutustena
- How Python works: esimene osa, teine osa
9. nädal: Tarkvara arhitektuur ja tehisintellekt
4. november.
- Kell 12: Tarkvara arhitektuur. Teegid, komponendid, andmebaasid, litsentsid jms.
- Loengumaterjal: Itsissejuhatus9a21.ppt, Itsissejuhatus9a21.pdf.
- Kell 13:45: Tehisintellekt.
- Loengumaterjal: ai_sissejuhatus_c.pdf.
- Eksamiks: Tarkvara arhitektuur: kohustuslik lugemine siin all, mis on teek ja mis raamistik, nende näited, arusaamine põhilistest litsentsitüüpidest (vabavaralised (gpl vs mit ja bsd) ja mitte-vabavaralised), gpl-i põhipoindid. Mis on tugev ja mis nõrk AI, mis on turingi test ja mis on eliza. Mis on otsimeetodites minimax ja alpha-beta (tehnilisi detaile ja näiteid ei tule). Mis on peamise tehisintellekti arendamise meetodid/lähenemised. Mis sorti ülesandeid praegused tehisintellektisüsteemid suudavad ok/väga hästi/väga halvasti lahendada? Mis on IBM Watson, GPT3, AlphaZero.
Kohustuslikku lugemist arhitektuuri teemal eksamiks:
- Martin Fowler tarkvara arhitektuurist
- The law of leaky abstractions
- No silver bullet ja lühem kokkuvõte
- Paul Reeves: What is software design? vana artikkel ja What Is Software Design: 13 Years Later
- mis on vabatarkvara Gnu interpretatsiooni kohaselt
Lisaks mittekohustuslikku, aga eriti soovitavat lugemist arhitektuurist, tähtsuse järjekorras:
- Software architecture is overrated ja HN kommentaarid
- Out of the tar pit
- Stack Overflow serveerimise ülesehitusest eriti selle esimene osa
- veidi Facebooki arhitektuurist
- Fundamentals of software architecture: see ei ole vähetähtis, aga on pikk ja detailne hästi illustreeritud jutt.
Lisaks: täiesti mittekohustuslikke ideid lugemiseks:
Lisaks tehisintellekti teemal:
- Väga hea mõte on teha ise läbi lihtne sissejuhatav MOOC-kursus tehisintellektist: eestikeelne või https://www.elementsofai.com/ inglisekeelne].
- GPT-3 ja DALL-E api ise katsetamiseks: rega ja proovi! Tasuline, aga (a) suur hulk krediiti algul (st algus tasuta) (b) katsetamiseks ka edasi väga odav
- Boston Dynamics atlas ja valus variant ja big dog. Eriti soovitav Marc Raiberti TED talk: vaata kindlasti valusat faili hetkel 5:28 :)
- Darpa grand challenge 2005 ja darpa robotics challenge (2012-2015) fails compilation
- Miks mitte karta super-tehisintellekti
- Rodney Brooksi väike tehisintellekti-sari osa 1, osa 2, osa 3, osa 4
- How networks become conscious ja Why can't my computer understand me
- Marvin Minsky The Society of Mind
- Õppimisalgoritmidest ja Google artiklid õppimisalgoritmidest
- Teadmiste integraatorid Ibm Watson, Wolfram Alpha ja Siri
- allen AI: vaata ka projektide ülamenüüst Demo lingi alt online demosid
- Päris hea võrgust lugev ja õppiv süsteem NELL vt ka seniõpitut ja olulist alus-meetodit
- Klassikaline vestlev pseudointellekt Eliza ja modernsem vestlev pseudointellekt
- A.I. filosoofia osas loe peamist wikiartiklit ja wikiartiklit funktsionalismist
- Loe Matrix, Skynet ja sõda teispoolsusega, Dennetti artikleid, tuntud õpikut,
Taustakuulamiseks soovitavaid podcastiepisoode:
- Eriti soovitav filosoofia/praktika kokkupuutepunktina Steven Pinkeri episood väga heast ja populaarsest ai podcastist.
- Neurorehkenduste ja sümbolrehkenduste vaidluse teemal kuula Gary Marcuse episoodi AI podcastist ja vastupidi, David Silveri episoodi Alphago, Alphazero jms teemadel. Lisaks videona Yoshua Bengio ja Gary Marcuse diskussioon-
- Praktilise AI ehitamise teemal kuula David Ferrucci ibm watsoni episoodi
- Vali neist A.I. podcastist mõned ja kuula: Goertzel, Poggio,Dawkins, Chomsky, Bostrom, Hawkins, Pearl
- Soovitavaid A.I. podcaste üldse: endise nimega A.I. podcast ja siis tehnilisemad ajuteaduse-fookusega A.I. podcast, Alleni instituudi NLP podcast. Viimase kohta veel soovitavaid episoode episode 89 about dialog systems, episode 91 about executable semantic parsing, episode 59 about semantic parsing ja lõpuks demod, eriti Rover demo
10. nädal: Masinõpe ja plokiahelad
11. november.
- Kell 12: Priit Järv räägib masinõppest: Loenguslaidid. Priit õpetab kursust Tehisintellekti ja masinõppe alused
- Kell 13:45: Dirk Draheim räägib plokiahelate, Bitcoini, Web 3 jms tehnoloogiast ja teooriast: inglise keeles. Loenguslaidid.
- Loenguvideo: heli algab ca 7. minutil. Teise loengu presentatsiooni-osa muutub nähtavaks ca 1:52.
- Eksamiks: mis põhiosadest koosnevad tehis-närvivõrgud, mida kasutatakse masinõppes. Mida närvivõrkudega õppe käigus tegelikult tehniliselt muudetakse? Mis on supervised learning, reinforcement learning, unsupervised learning (eeskätt, mille poolest nad üksteisest erinevad)? Mis on peer-to-peer network, kuidas plokiahel võltsimatust tagab, mis asi on distributed ledger (hajusraamat) ja mida selles kontekstis mõeldakse konsensuse all.
Lisaks uuri masinõppe kohta:
- Elements of AI eestikeelsed masinõppe ja närvivõrkude blokid.
- Neural networks from scratch
- Masinõpe vikipeedias
- Deep learning otse brauseris
- Brain inspired podcast neuroteaduse ja veidi masinõppe teemadel: jutuajamised päris neuroteadlastega.
- Kaggle competitions ja iseõppe kursused
- GPT-3 vikipeedias ja selle baasil tehtud Github copilot vikipeedias ja otselink.
- GPT-3 ja DALL-E api ise katsetamiseks: rega ja proovi! Tasuline, aga (a) suur hulk krediiti algul (st algus tasuta) (b) katsetamiseks ka edasi väga odav
ja plokiahelate kohta:
- Vaata Bitcoini tehnoloogiajuppide interaktiivset demo: vaata videosid ja peamise asjana: võta ülamenüüst järjest "Hash", "Block", "Blockchain" jne ja proovi ise järgi.
- päris hea ülevaade ja seletus: kuidas plokiahelad töötavad
- bitcoini ledgeri uute blokkide hetke-ülevaade
11. nädal: Andmevood ja andmelaod + ise-järelvaatamine: kuidas saada heaks programmeerijaks.
18. november.
- Kell 12: Orion Governance kaasasutaja ja chief data scientist Kalle Tomingas räägib väga suurte infosüsteemide andmeladudest, andmevoogudest ja analüüsist.
- Kell 13:45 ainult järelvaatamine, saalis loengut ei toimu: Margus Freudenthal (X-tee/UXP arendusjuht) Cyberneticast räägib sellest (järelvaadatav) kuidas saada heaks programmeerijaks?. Saadaval ka loenguslaidid. Kuulake mõttega: see on hästi hea ja täpne jutt.
- Loenguvideo: Kalle Tominga loeng kell 12.
12. nädal: Küberkaitse ja algoritmid: lahenduvus.
25. november.
- Kell 12: Olaf Maennel räägib küberkaitsest inglise keeles: The evolving world of cyber-operations. Abstract:
“Cyber”, as the 5th domain of warfare, is getting more awareness recently. Our unpreparedness is also becoming apparent. In this talk, we will revisit some recent developments in the sector and discuss the underlying fundamentals of the problems we are seeing. How can we increase our cybersecurity posture as individuals and organisations? Simple cybersecurity awareness changes, combined with some common sense and essential critical thinking, can already bring us quite far. We will discuss some examples of offensive methods and understand how to build the required defensive culture.
- Kell 13:45: Algoritmid: lahenduvus.
- Loengumaterjal: Itsissejuhatus13a.ppt, Itsissejuhatus13a.pdf.
- Eksamiks: lahenduvus teoreetilises ja tavamõttes, mis on lahenduvad ülesanded. Positiivsete täisarvude, positiivsete/negatiivsete ja murdarvude võimsuse võrdlemine ja tõestamine. Reaalarvude suurem võimsus kui täisarvude võimsus (Cantori teoreem): tõestuse idee. Mis on peatumisprobleem, selle lahendamatuse tõestuse idee. Küberkaitse teemad täpsustuvad loengute järel.
Vaata lisaks lahenduvuse teemal:
- Kardinaal
- Cantori teoreem
- Halting problem
- Incompleteness theorems
- Raamat Gödeli tõestus koos õppejõu järelsõnaga täiendavate seostega nii lõpmatuse kui mittelahenduvusega.
13. nädal: Rekursioon, funktsionaal- ja loogiline progemine + loeng Wise (endine Transferwise) poolt
2. detsember
- Kell 12:00.Rekursioon, funktsionaal- ja loogiline progemine. Loengumaterjal: Itsissejuhatus11.ppt, Itsissejuhatus11.pdf.
- Kell 13:45. Uku Wisest räägib tarkvara-toodete ehitamise - product engineering - ja vajalike/abiks/super oskuste teemal. Presentatsioon taustaks: Media:wise_taltech_talk.pdf
- Eksamiks: rekursiooni äratundmine, baasjuht ja rekursiivne juht, rekursiooni ekvivalentsus tsükliga, arusaamine funktsionaalse keele näitejuppidest loengus: mida mingi näitekood teeb / mis on rehkendamise tulemus. Mis on lambda-arvutus. Prologi ja lambda-arvutuse näited tuleb ära tunda ja aru saada. Ettevõtetest: mis on tootefirma / traditsioonilise "agency" põhierinevused. Mida tähendab data-driven tootearendus. Mis on MVP. Mis stsenaariumites/olukordades on mõistlik kasutada "asynchronous messaging"-u?
Loenguga mitte seotud soovitus: Lex Fridmani podcastis (varem A.I. podcast) on uus episood Pythoni autori Guido van Rossumiga: saad päris palju teada Pythoni sise-elust.
Lisaks proovi ja loe veidi:
- Fraktaalid wikipedias
- Mandelbub ja selle videoklipid Mandelbox and Flying Lights, Like in a dream II, Weird planet II. Taustaks veel Geometric visual hallucinations, Euclidean symmetry and the functional architecture of striate cortex
- kiire Mandelbroti fraktaal online ja veidi aeglasem
- Mandelbroti hulga (pildi) joonistamise programme mitmes eri keeles
- Lihtne fraktaal-puu javascriptis draw.html ja keerulisem moving fractal trees in javascript. Siit edasi arvutigraafika veebiraamat.
- Tower of Hanoi
- Lambda-arvutus
- Vaata ja proovi näiteid modifitseerida:
- Vaata ja modifitseeri Ecki mandelbroti joonistajat ja kilpkonnagraafikat. Viimasest võta menüüst recursion tutorial ja recursive bush näide.
- Huvi korral katseta
- Lambda-arvutuse kalkulaator näidete ja detailsete sammudega
- Proovi Prolog online või installeeri SWI Prolog.
14. nädal: Plokiahelate jätk. Ajuteadus.
9. detsember
- Kell 12: Dirk Draheim jätkab plokiahelate teemaga - nende uuemad arengud - inglise keeles. Eelmise loengu loenguslaidid.
- Kell 13:45: Ajuteadus. Ülevaade päris aju (mitte tehis) kohta teadaolevast, põhiteooriatest ja lähenemistest.
- Loengumaterjal: Brain_science.pdf. Plaanitud Innar Liivi loeng jääb seekord ära, kuna Innar jäi haigeks.
- Loenguvideo vahepeal ca 10 min on õppejõu taustal youtube heli kogemata lisaks, hiljem see lõppeb.
15. nädal: Konsultatsioon eksamiks, tarkvaraarendusprotsess ja IT äri + järelvaatamine: andmekaevandamine
16. detsember.
- Kell 12: Konsultatsioon eksamiks ja seejärel lühem loeng: tarkvaraarendusprotsess, projektid ja IT äri. Loengumaterjal: Itsissejuhatus_projektid_raha_22.pdf.
- Kell 13:45: iseseisev järelvaatamine (auditooriumis loengut enam ei ole): Innari eelmise aasta loeng andmekaevandamisest.
- Loenguvideo: poolteist tundi
- Eksamiks: Projekti jaotus etappideks, kosemudel vs agiilne arendus. Alltoodud kohustuslike projektide/äri-artiklite läbilugemine.
Lisaks vaata andmekaevandamisest:
Lisaks projektidest:
- How projects really work ja selle pikk ajalugu
- Agile, agile manifesto ja selle põhimõtted ja lisaks selle juurde Martin Fowleri vana artikkel ja uus artikkel
- Paul Graham alustamisest: do things that do not scale
- Sam Altmani startup-kursuse loenguvideod
- Kohustuslikud artiklid (toodud ka sellel lehel allpool,kohustuslike lugemismaterjalide osas):
- Paul Graham: How to start a startup?
- Paul Graham: Great hackers
- Joel Spolsky: The iceberg secret revealed
- Joel Spolsky: IT firma töökorraldus: 12 steps
- Paul Reeves: What is software design? vana artikkel ja What Is Software Design: 13 Years Later
- Fred Brooks 1986: No Silver Bullet
- Random ramblings: Top ten geek business myths
- 20 aastat kogemust tarkvara arendusmeetoditega
Näiteid vanadest eksamitest
Siin on näited väga ammu tehtud eksamitest. Tegelikud eksamiküsimused tulevad teistsugused, formaat on sama.
Kohustuslikud lugemismaterjalid
Järgnevate materjalide läbilugemine on kursuse läbimisel kohustuslik ja nende kohta tuleb eksamil lugemiskontrolli-küsimusi:
- Loogika ainest ja ajaloost: T.Tammet: Loogika aine ja ajalugu: sissejuhatus T.Tamme, T.Tammeti ja R.Prangi loogikaõpikule "Mõtlemisest tõestamiseni".
- Alan Turing Computing Machinery and intelligence
- Abstraktsioonidest ja tehnoloogiatükkidest: Law of leaky abstractions
- Paul Graham Hackers and painters
- Stiilist või midagi: The Tao of Programming. Selle teksti inspiratsiooniks/taustaks on daodejing, see tausta-originaal-daodejing ei ole kohustulik lugemine.
- Kohustuslikud artiklid IT projektide, ideoloogia, äri ja juhtimise teemal on järgmised. Neid "ära õppida" vms pole vaja, piisab lihtsast mõnusast kiirest läbilugemisest:
- Paul Graham: How to start a startup?
- Paul Graham: Great hackers
- Joel Spolsky: The iceberg secret revealed
- Joel Spolsky: IT firma töökorraldus: 12 steps
- Paul Reeves: What is software design? vana artikkel ja What Is Software Design: 13 Years Later
- Gnu manifestid The Free Software Definition ja Selling Free Software
- Fred Brooks 1986: No Silver Bullet
- Random ramblings: Top ten geek business myths
- 20 aastat kogemust tarkvara arendusmeetoditega
Loe iga päev
- http://news.ycombinator.com/
- http://www.reddit.com (hea mõte on registreeruda ja valida sobivad alamredditid, näiteks
Kuula
Mh vaata läbi varasemate episoodide loetelu ja kuula, kui tundub põnev:
- ai podcasti, näiteks Steven Pinkeri episoodi.
- Mindscape podcasti
Mõned valikepisoodid mujalt: