Scriptingtalen (2018–2019)

Peter Dawyndt · Universiteit Gent

Welkom op de Dodona-cursus van het opleidingsonderdeel Scriptingtalen. Deze cursus bevat een groot aantal programmeeroefeningen in Python en JavaScript die voorzien zijn van automatische feedback.

Onderstaand overzicht bevat een lijst van opdrachten die je wekelijks moet afwerken. Dit omvat onder meer de hoofdstukken uit het handboek die als voorbereiding op de hoorcolleges moeten gelezen worden, extra opdrachten als voorbereiding op het oplossen van de programmeeroefeningen, en een lijst van opgelegde oefeningen die wekelijks moeten ingediend worden voor vrijdagavond 22:00. Merk op dat de ISBN-oefeningen deel uitmaken van de opgelegde oefeningen, en dus ook moeten ingediend worden voor de wekelijkse deadlines op vrijdag. Voorbeeldoplossingen van de ISBN-oefeningen vind je op Minerva. Hou zelf het overzicht in de gaten om te zien voor welke opgelegde oefeningen je reeds een (correcte) oplossing hebt ingediend.

De punten voor het opleidingsonderdeel Scriptingtalen worden voor 35% (7/20) berekend op basis van niet-periodegebonden evaluatie (dagelijks werk) en voor 65% (13/20) op basis van periodegebonden evaluatie (examen). Er zijn in totaal drie niet-periodegebonden evaluatiemomenten die samen de score van de niet-periodegebonden evaluatie bepalen.

Voor de eerste niet-periodegebonden evaluatie (Python) krijgen de studenten een reeks van 44 Python oefeningen opgelegd. Op basis van de behandelde programmeertechnieken worden deze oefeningen onderverdeeld in 10 reeksen. De eerste oefening van elke reeks is telkens een variant op het werken met ISBN-nummers. Een voorbeeldoplossing van deze oefening is gegeven op Minerva, en in een bijhorende instructievideo wordt uitgelegd hoe we tot deze voorbeeldoplossing gekomen zijn. Met deze ISBN-oefening zetten we uiteen hoe de nieuw aangebrachte programmeertechniek van de oefeningenreeks in de praktijk kan gebracht worden. Met deze voorbereiding kunnen de studenten zelf aan de slag om de programmeertechniek in de praktijk te brengen via het oplossen van de andere opgelegde oefeningen uit de reeks. Studenten moeten hun oplossingen voor de opgelegde oefeningen van elke reeks (inclusief de ISBN-oefening) indienen via het online leerplatform Dodona tegen vooraf vastgelegde deadlines (telkens op vrijdag om 22:00 in de week van het werkcollege gewijd aan de oefeningenreeks). Studenten kunnen gebruik maken van het overzicht op Dodona om op te volgen voor welke oefeningen ze reeds een correcte oplossing hebben ingediend. Dodona geeft immers een handig overzicht van de opgelegde oefeningen uit de opeenvolgende reeksen, de bijhorende deadlines en de tijd waarop voor het eerste een correcte oplossing voor de oefening werd ingediend.

De eerste niet-periodegebonden evaluatie (Python) wordt afgesloten met een evaluatiemoment tijdens het eerste werkcollege dat volgt op de deadline voor het indienen van de oplossingen van de laatste oefeningenreeks. Bij deze evaluaties krijgen de studenten twee uur de tijd om twee nieuwe Python programmeeroefeningen op te lossen. Hierbij kunnen ze gebruik maken van het online leerplatform Dodona om de correctheid van hun oplossingen na te gaan. De ingediende oplossingen van deze evaluatie-oefeningen worden echter met de hand nagekeken door de lesgever en zijn begeleiders, en beoordeeld op correctheid, gebruikte programmeerstijl, keuzes gemaakt bij het gebruik van de verschillende programmeertechnieken en de kwaliteit van de oplossingsmethode. De moeilijkheidsgraad van deze evaluatie-oefeningen is van hetzelfde niveau als deze van de opgaven die tijdens de periodegebonden evaluatie (het examen) worden voorgelegd. Bovendien volgt dit evaluatiemoment dezelfde procedure die gebruikt wordt tijdens de periodegebonden evaluatie, zodat studenten op basis van hun ervaring eventueel hun werkmethode kunnen bijsturen in voorbereiding naar het examen.

Voor de tweede niet-periodegebonden evaluatie (JavaScript) krijgen de studenten een reeks van JavaScript oefeningen opgelegd. Met deze oefeningen kunnen de studenten zelf aan de slag om hun kennis en vaardigheden van JavaScript in de praktijk te brengen. Studenten moeten hun oplossingen voor de opgelegde oefeningen van elke reeks indienen via het online leerplatform Dodona tegen vooraf vastgelegde deadlines (telkens op vrijdag om 22:00 in de week van het werkcollege gewijd aan de oefeningenreeks). Studenten kunnen gebruik maken van de online leeromgeving Dodona om de correctheid van hun oplossingen na te gaan en onmiddellijk geautomatiseerde feedback te krijgen op hun ingediende oplossingen.

De tweede niet-periodegebonden evaluatie (JavaScript) wordt afgesloten met een evaluatiemoment tijdens het eerste werkcollege dat volgt op de deadline voor het indienen van de oplossingen van de laatste oefeningenreeks. Bij deze evaluaties krijgen de studenten twee uur de tijd om twee nieuwe JavaScript programmeeroefeningen op te lossen. Hierbij kunnen ze gebruik maken van het online leerplatform Dodona om de correctheid van hun oplossingen te testen. De ingediende oplossingen van deze evaluatie-oefeningen worden echter met de hand nagekeken door de lesgever en zijn begeleiders, en beoordeeld op correctheid, gebruikte programmeerstijl, keuzes gemaakt bij het gebruik van de verschillende programmeertechnieken en de kwaliteit van de oplossingsmethode. De moeilijkheidsgraad van deze evaluatie-oefeningen is van hetzelfde niveau als deze van de opgaven die tijdens de periodegebonden evaluatie (het examen) worden voorgelegd. Bovendien volgt dit evaluatiemoment dezelfde procedure die gebruikt wordt tijdens de periodegebonden evaluatie, zodat studenten op basis van hun ervaring eventueel hun werkmethode kunnen bijsturen in voorbereiding naar het examen.

De derde niet-periodegebonden evaluatie omvat een opdracht waarbij de studenten een client-server toepassing moeten implementeren die gebruik maakt van Python aan de serverzijde (CGI) en JavaScript aan de clientzijde (browser). De oplossing voor deze opdracht moet ingediend worden tegen een vooraf vastgelegde deadline, en wordt beoordeeld op basis van correctheid, keuzes die genomen werden bij het ontwerp en de implementatie, en gebruiksvriendelijkheid van de oplossing.

De score van de niet-periodegebonden evaluaties wordt bepaald volgens de formule s * c / a. Hierbij staat s voor de score die de studenten behaald hebben op basis van hun ingediende evaluatie-oefeningen (uitgedrukt op 20), c staat voor het aantal opgelegde oefeningen die correct werden ingediend tegen de wekelijkse deadlines, en a staat voor het aantal opgelegde oefeningen. Een student die bijvoorbeeld 16/20 behaald heeft voor zijn evaluatie-oefeningen en alle 44 opgelegde oefeningen correct heeft ingediend voorafgaand aan de wekelijkse deadlines, krijgt voor die evaluatiereeks een score van 16 * 44/44 = 16 op 20. Als die student echter nog steeds 16/20 had behaald voor zijn evaluatie-oefeningen, maar slechts 30/44 opgelegde oefeningen correct had ingediend voorafgaand aan de wekelijkse deadlines, dan houdt die student slechts een score van 16 * 30/44 = 10.9 op 20 over.

Studenten krijgen zo snel mogelijk na een evaluatie per email hun score toegestuurd. Tijdens het daaropvolgende werkcollege krijgen de studenten ook de oplossingen die ze ingediend hebben tijdens de evaluatie terug, voorzien van feedback die aangeeft waar er verbeterpunten zijn die ze kunnen meenemen bij het verder oplossen van oefeningen of naar het examen.

De niet-periodegebonden evaluaties kunnen niet hernomen worden tijdens de tweede examenperiode. Voor de tweede examenperiode wordt enerzijds een score berekend rekening houdend met de punten behaald voor de niet-periodegebonden evaluatie (dus punten dagelijks werk gequoteerd op 7 samen met het examen gequoteerd op 13, zoals dat ook geldt voor de eerste examenperiode) en wordt anderzijds ook een score berekend zonder rekening te houden met de punten behaald voor de nietperiodegebonden evaluatie (examenresultaat rechtstreeks gequoteerd op 20). De eindscore voor de tweede examenperiode is het maximum van de voorgaande twee berekeningen.

Tijdens de periodegebonden evaluatie (examen) krijgen de studenten 4 uur om vier programmeeroefeningen op te lossen: twee Python-oefeningen en twee JavaScript oefeningen. Voor de Python oefeningen kunnen de studenten opnieuw gebruik maken van de Pythia omgeving om hun oplossingen in te dienen en feedback te krijgen op de correctheid en de programmeerstijl ervan. Voor de JavaScript oefeningen kunnen de studenten opnieuw gebruik maken van de Dodona omgeving om hun oplossingen in te dienen en feedback te krijgen op de correctheid ervan. Voor het bepalen van de examenscore worden de ingediende oplossingen evenwel opnieuw met de hand nagekeken en beoordeeld.

Je kan momenteel niet registreren voor deze cursus.

Registreren

Oefeningenreeksen

week 01: expressies, statements en controlestructuren
19 februari 2019 22:00

Titel Voortgang groep
ISBN
Som van twee getallen
De gestopte klok
ISBN
Kaartmakkers
Darts
ISBN
Loonbrief
Lifters
Volkstelling op Mars

week 02: strings en functies
26 februari 2019 22:00

Titel Voortgang groep
ISBN
Woordevoluties
HIV 11/25
Cowsay
ISBN
Woordsommen
Palindroom in Scrabble
Ierse Turken

week 03: lijsten en tuples
05 maart 2019 22:00

Titel Voortgang groep Status
ISBN
Diffy
Heremietkreeften
Ritsen
Polka Dot
Dronken mier
Pozo Azul

week 04: modules, verzamelingen en dictionaries
12 maart 2019 22:00

Titel Voortgang groep Status
ISBN
Onvoorspelbare verjaardagen
Aangebrande pannenkoeken
Dawkins' wezel
ISBN
Busroddels
LetterWise
Zonnestelsel

week 05: tekstbestanden
19 maart 2019 22:00

Titel Voortgang groep Status
ISBN
In memoriam
Jaarboek
Plutokiller
Sestina
De Parsons code

week 06: objectgericht programmeren
26 maart 2019 22:00

Titel Voortgang groep Status
ISBN
Geheimschreiber
Anthropocentrisme
Driehoekige klok
Geohash-36
Point Nemo

week 07: evaluatie partim Python
26 maart 2019 17:30

Titel Voortgang groep Status
Geen drie-op-een-rij
Cryptex

week 07: inleiding tot JavaScript

Het luik JavaScript wordt opnieuw zo georganiseerd dat je elke week een aantal aspecten van de programmeertaal en haar binding met externe omgevingen (in het bijzonder de browser) bestudeert onder de vorm van zelfstudie (blended learning). Deze aspecten worden in de hoorcolleges geïllustreerd door het uitwerken van voorbeelden, waarbij ook de kans geboden wordt om vragen te stellen over het gedeelte dat via zelfstudie moest verwerkt worden (flipped classroom). Tijdens de werkcolleges moet je zelfstandig een aantal opgelegde opdrachten uitvoeren tegen vooropgestelde deadlines, waarbij vragen kunnen gesteld worden aan de aanwezig begeleiders of via het forum op Minerva.

week 08: JavaScript
23 april 2019 22:00

Titel Voortgang groep Status
Lineup
Akkoorden
Naomees
Bitcoins
Pozo Azul

week 09: JavaScript
30 april 2019 22:00

Titel Voortgang groep Status
Blockchain
Blindelings
Metrokaart der exacte wetenschap
Kolomtranspositie
Qlocktwo

Extra oefeningen op het gebruik van JavaScript, die je kan gebruiken om je voor te bereiden om de evaluatie en het examen.

Titel Voortgang groep Status
Echo
Mad Libs
Zonnestelsel
Wepe sprepekepen p
Voorspelbare dobbelstenen
Vier-vierkant
Turbolift
Triplerotatie
Speleologie
Racetrack Playa
Quixo
Quipu
Playfair
Molecuulformule
Marsrovers
Magische machine
∞ lus
Leren rekenen
Kwatro
Immuunsysteem
Het vijfde element
Heremietkreeften
Geheimschrift van Dumas
Five up
Een schuldige sleutel
Consensussequentie
Complementaire reeksen
Combinatieslot
Chromosomale crossover
Bifidcodering
Zweedse voorouders

week 12: evaluatie partim JavaScript

Titel Voortgang groep Status
Chaocipher
Game of dots
Titel Voortgang groep Status
Plus minus
Soapserie
Kaarten omkeren
Flow Free
Titel Voortgang groep Status
Japanse getallen
Bergbeklimmers
Knockout
Samensmelten