Skip to content

Files

Latest commit

 

History

History
194 lines (150 loc) · 8.77 KB

index.md

File metadata and controls

194 lines (150 loc) · 8.77 KB
layout title
home
Tiralabra
<script src="assets/fuu.js"></script>

Link to English materials

Link to English materials

Sivuston sisältö ei näy oikein ilman javascript tukea

Salli scriptit ainakin lähteestä tiralabra.github.io.

Ohjaaja

    <script> var script = document.scripts[document.scripts.length - 1]; tas.forEach(ta => { var elem = document.createElement("li"); s = ta.name; if (ta.fiEmail) { s = s + ", " + ta.fiEmail; } else if (ta.email) { s = s + ", " + ta.email; } else { s = s + ", (etunumi.sukunimi@helsinki.fi)" } if (ta.fiSocial) { s = s + ", " + ta.fiSocial; } else if (ta.social) { s = s + ", " + ta.social; } elem.innerHTML = s; script.parentElement.insertBefore(elem, script); }); </script>

📅 Aikataulu

Tarkempi aikataulu täällä.

<script> script = document.scripts[document.scripts.length - 1]; script.parentElement.insertBefore(makeCalendarFi(), script); </script>

📣 Ajankohtaista

  • <script> if (doodleSent) { if (timing["demo"]) { document.write("Demotilaisuuden ajankohdat on lyöty lukkoon. Ottakaa yhteyttä jos ette pääse paikalle.") } else { document.write("Doodle linkki demotilaisuuden aikatauluttamiseksi on lähetetty kurssille ilmoittautuneille opiskelijoille. Sähköposti on lähtenyt siihen osoitteseen mikä on labtooliin rekisteröity.") } } else { document.write("Kysely demotilaisuuden aikatauluttamiseksi lähetetään kurssin puolivälin paikkeilla.") } </script>
  • Lopullinen palautus <script>document.write(fiString(timing["end"].date));</script>, tähän ei ole saatavilla lisäaikaa.
  • Jos löydät kurssisivuilta jotain parannettavaa. Voit seurata täältä löytyviä ohjeita virheen korjaamisesksi. Hyvistä korjauksista on mahdollista saada yhden kurssipisteen "bug bounty" (max 1 per oppilas)

Linkkejä materiaaliin

🗒️ Labtool

Ohjaus

    <script> var script = document.scripts[document.scripts.length - 1]; if (timing["paja1"]) { var elem = document.createElement("li"); elem.innerHTML = "Pajaohjausta järjestetään kalenterissa näkyviin aikoihin."; script.parentElement.insertBefore(elem, script); elem = document.createElement("li"); elem.innerHTML = "Pajasta voi myös muihin aikoihin pyytää apua aloritmeihin liittyen."; script.parentElement.insertBefore(elem, script); } else { var elem = document.createElement("li"); elem.innerHTML = "Intensiivikursseilla ei järjestetä viikottaista pajaa. Jos haluat henkilökohtaista ohjausta kumpulassa niin ota yhteyttä ohjaajaan"; script.parentElement.insertBefore(elem, script); } </script>
  • Voit myös ottaa yhteyttä Telegramissa.
  • Tai tarvittaessa sähköpostilla.

Demotilaisuus

  • PAKOLLINEN! Ota yhteyttä jos et pääse demotilaisuuteen, se on läpipääsyyn pakollinen!
  • On erittäin suositeltavaa demota omalta kannettavalta. Tässa tapauksessa voi olla hyvä saapua demoon hyvissä ajoin ja varmistaa että projektori toimii koneen kanssa. Jos omaa kannettavaa ei ole kannattaa demoamisesta sopia kaverin tai ohjaajan kanssa erikseen.
  • Projektit ladataan myös etukäteen esityskoneelle. Osaston koneelta esittäminen ei perinteisesti onnistu kauhean hyvin. Esityskoneet eivät läheskään aina toimi ollenkaan, ja kun toimivat niin projektit eivät välttämättä toimi esityskoneen ympäristössä.
  • Korkeintaan 5min per projekti.
  • Ei tarvitse dioja, mutta halutessaan niitä voi käyttää, tosin ne vie aikaa, joten ei suositeltu, etenkään ellei tuo omaa konetta esitykseen.
<script> var elem = document.getElementById("demo"); if (timing["demo2"]) { elem.innerHTML = "Paikat ja ajat:"; var ulelem = document.createElement("ul"); Object.keys(timing).filter(name => name.startsWith("demo")).map(name => fiEvent(timing[name])).forEach(ev => { var lielem = document.createElement("li"); lielem.innerHTML = ev; ulelem.appendChild(lielem); }) elem.appendChild(ulelem); } else if (timing["demo"]) { elem.innerHTML = "Paikka ja aika: " + fiEvent(timing["demo"]) + "."; } else { elem.innerHTML = "Aika ja paikka vahvistuvat myöhemmin."; } </script>

Esimerkkiprojektit

  • Saskelin projekti Huom: että etenkin tämän jälkeen kurssi on jonkin verran muuttunut.
  • Ja Jussi sanoi että oma projektinsa oli kiireessä tehty mahdollisimman helpolla suoritettu.
  • Molemmat kuitenkin (kuulemma) projektirakenteiltaan hyviä, jos haluaa esimerkkejä.

🏆 Kurssin suorittaminen

Kurssin työmäärä on opintopisteiden (4) perusteella n. 107 tuntia. Varaudu siis käyttämään työhön 15-20 tuntia viikossa jokaisella viikolla.

Kurssilla opiskelija toteuttaa ohjelman, joka ratkaisee jonkin ohjelmointiongelman. Ongelmanratkaisuun käytetään sopivia algoritmeja sekä tietorakenteita. Oppimismatriisin tiedoista poiketen, opiskelja valitsee ratkaistavan ongelman yhdessä ohjaajan kanssa. Suoritus ei edellytä oman algoritmin kehittämistä. Tämäkin on mahdollista, mikäli opiskelija haluaa haastavamman aiheen. Keskeistä työssä on, että ohjelma on toimiva ja tehokas. Sen tulee kaikissa tapauksissa antaa nopeasti oikea vastaus. Työn aiheesta riippuu, miten suuria tapauksia ohjelman tulee pystyä käsittelemään. Tämä sovitaan ohjaajan kanssa. Mahdollisia aiheita voi katsoa täältä.

Kurssi pidetään osittain verkkokurssina, kaikki viikoittaiset palautukset tapahtuvat verkon kautta. Ainoat pakolliset tapaamiset ovat aloitusluento sekä loppudemot. Lisätietoa palautuksista täällä.

Ohjelma toteutetaan ohjaajan hyväksymällä kielellä, melkein poikkeuksetta Javalla.

Kurssin ensisijainen tavoite on oppia toteuttamaan itse tietorakenteita, ja tästä syystä tarvittavat algoritmit ja tietorakenteet tulee toteuttaa itse. Nyrkkisääntönä vain perustietotyyppejä, taulukoita ja merkkijonoja saa käyttää, muu on tehtävä itse, erityisesti Tietorakenteet-kurssilla opetellut rakenteet. Muita apuvälineitä, kuten tiedostonkäsittelyluokkia, saa tietenkin käyttää. Valmiita tietorakenteita (esim. Javassa: ArrayList, HashMap...) tai algoritmeja (esim. Collections.sort) ei saa käyttää lopullisessa työssä ja myös niiden importit kannattaa poistaa. Jos olet epävarma jonkin luokan käyttämisestä, kysy ohjaajalta.

Hyväksi koettu tapa tehdä työ vaiheittain on laittaa ensin kuntoon algoritmin ydin käyttäen kielen standardikirjastojen valmista kalustoa (jonot, keot, järjestämisalgoritmit). Kannattaa siis pyrkiä toteuttamaan algoritmin ydin nopeasti ja sen jälkeen korvata käytetty kalusto omilla toteutuksilla. Eli toteuttaa rajapintojen takana olevat rakenteet ja/tai algoritmit itse. Tätä tapaa käytetään osapalautusten pohjana algoritmin/tietorakenteiden kehityksen osalta. Mikäli toteutat työn erilaisella lähestymistavalla, sovi työn edistymisen "Milestone":t jo 1. viikon aikana ohjaajan kanssa.

📈 Arvosteluperusteet

  • Ohjelma: 30 p

    • Toimivuus ja ominaisuudet 10 p
    • Testaus 10 p
    • Dokumentoiva koodi (JavaDoc sekä itsedokumentoiva) 5 p
    • Ohjelmakoodin selkeys 5 p
  • Dokumentaatio 10 p

    • Aiheen määrittely 2p
    • Ongelman toteutus 3p
    • Testaus 3p (myös suorituskykytestaus!)
    • Käyttöohje 2p
  • Arvostelu kurssin aikana 20p

    • Vertaisarvioinnit 2 * 2p = 4p
    • Viikkopalautukset 1p + 5 x 3p = 16 p

(Yhteensä 60 p)

Kurssin hyväksytysti suorittaminen vaatii ohjelmalta itsetoteutettuja tietorakenteita sekä toiminnallisuutta. Kukin työ arvioidaan omana kokonaisuutenaan, alla viitteelliset pisterajat.

  • 5: 50 p
  • 4: 45 p
  • 3: 40 p
  • 2: 35 p
  • 1: 30 p