Programmeringsteknik för V1 info till handledare
KTH
2D1310 Programmeringsteknik
Särskild information för V
Nada

^ Upp till allmänna kurssidan.

Senaste nytt Lärare Kurslitteratur Förkunskaper Schema
Tentamen V:s datorsalar Detaljschema Studiedisposition Laborationer I-uppgift
Hemuppgifter Betyg Hjälp och handledning Hederskodex Synpunkter på kursen Länkar

Senaste nytt

Kursanalysen för 1998 är nu sammanställd.
Om din kursomgång är slut kan du boka tid för redovisning (normalt i tentaperioder) genom att trycka på knappen. Redovisningarna sker på Nada i Röd respektive Blå sal.
Tryck här för att hämta kursenkäten:


Lärare

Kursledare är Linda Kann. Lämpligaste sättet att komma i kontakt med kursledaren är att skicka datorbrev, näst lämpligast är att lägga en lapp i postfacket på Nada, Osquars Backe 2, 4 tr eller skicka ett vanligt brev till Nada, KTH, 100 44 Stockholm. Vill man träffa kursledaren personligen går det bra på mottagningstiden.

De fyra övningsgrupperna leds av följande personer:

Grupp Övningsledare Datorpostadress
1 Mats Näslund matsn@nada.kth.se
2 Linda Kann linda@nada.kth.se
3 Josefin C. Lindh v95_lie@nada.kth.se
4 Larsson Omberg f94-lom@nada.kth.se

Kurslitteratur

Kurslitteraturen ska läsas på egen hand parallellt med kursen. Föreläsningar, övningar och laborationer täcker endast en del av kursmaterialet.

Programmeringsteknik med Pascal Kursbok: Bälter: Programmeringsteknik med Pascal, upplaga 2, pris ca 225 kr, 292 sidor. Täcker denna kurs och lite till. Läsanvisning inför tentan finns både till första och andra upplagan.

Condensed Pascal (För den som föredrar engelsk litteratur kan Coopers Condensed Pascal användas istället. En trevlig amerikansk bok på 644 sidor, pris ca 295 kr. Saknar lösningar till övningarna.) Läsanvisningar till Condensed Pascal finns också.

Båda böckerna finns att köpa på kårens bokhandel.

Kursbunt innehållandes:

Kursbunt kan köpas på elevexpeditionen. Papper som delas ut under kursens gång finns också att hämta i bokhyllan utanför expeditionen.

Förkunskaper

Kursen förutsätter att man känner till begrepp som operativsystem, filer och redigeringsprogram. Den som inte gör det uppmanas att läsa igenom kapitel 7 (kap 6 i upplaga 1) i kursboken och ägna extra mycket tid åt kursen i början. Vissa föreläsningar anordnas speciellt som stöd för den som behöver det.

Schema

Under kursens första period ges två föreläsningar per vecka, utom sista veckan då blott en föreläsning ges. Efter ordinarie tentamen hålls dessutom tre repetitionsföreläsningar (för att ge den som missade tentan en chans att komma ifatt).

Under de första åtta veckorna av kursen hålls en salsövning per vecka.

Varje vecka finns ett redovisningstillfälle för laborationer. Observera att vid det ordinarie redovisningstillfället prioriteras redovisningar av den laboration som är ordinarie för det tillfället. För elever som missar att redovisa på ordinarie redovisningstillfälle hålls det en extra redovisning veckan därpå. Maximalt tre redovisningar kan göras på måndagar utan förlust av betygspoäng. Extra redovisningar är till för redovisning av alla labbar, men inte I-uppgifter.

I-uppgiften redovisas under kursens andra period.

Period 1

VAD VECKA DAG TID GRUPP SAL
Föreläsning 36 tor 8-10 Alla V4
36 fre 9-11 Alla V1
37-42 tis 12-14 Alla V4
37-41 tor 9-11 Alla V1
Övning 36 tor 12-14 Alla V01,V11,V21,V23
37-42 tis 14-16 Alla D32,V11,V21,V23
Datorlab 36-41 fre 12-14 1-2 V26T,V29T
36-41 fre 14-16 3-4 V26T,V29T
42 ons 9-11 1-2 V26T,V29T
42 ons 12-14 3-4 V26T,V29T

Period 2

VAD VECKA DAG TID GRUPP SAL
Repetitionsföreläsning 44 ons 12-14 (*) V11
44 tor 15-17 (*) V11
44 fre 12-14 (*) V01
Övning 44 mån 15-17 Alla V01,V11,V21,V23
Datorlab 44-50 tis 12-14 1-2 V26T,V29T
44 ons 9-11 3-4 V26T,V29T
45-50 ons 12-14 3-4 V26T,V29T
45-49 fre 12-14 Alla V26T,V27T
(*) Föreläsningarna i period 2 är repetition, och är inte för dom som redan klarat tentan.

Tentamen

Ingen tentaanmälan krävs. Alla är välkomna till tentan. På ordinarietentor sätts placeringslistor upp vid tentasalarna.
Tentan består av sex uppgifter. På varje uppgift finns en a- och en b-del, där a- eller b-delen måste besvaras rätt. (Avsikten är att man ska behärska alla moment för att bli godkänd; det räcker inte med att kunna hälften väl.) På tentan ges bara betyget Godkänd/Underkänd.

Hjälpmedel är en Pascalbok.

Tentaresultatet anslås på institutionens anslagstavla på plan 3 (rakt under elevexpeditionen). Klagomål på rättning av tentan lämnas in skriftligen till den kursansvarige inom tre veckor från det att tentaresultatet anslagits.
Observera att du inte får ta med dig tentan från expeditionen om du vill klaga på rättningen. Ordinarie tentamen ges lördag 24 oktober kl 14-17 i sal F11-15,22-25,31-34
Omtenta lördag 16 januari kl 14-17 i F51-55.


V:s datorsalar

Det finns fem datorsalar på V.
V12T och V13T ligger bakom fiket (Teknikringen 72).
V26T, V27T och V29T ligger en trappa upp i högra V-huset (Teknikringen 76).
NADA har inget ansvar för programvara i dessa salar.
Vid problem med datorerna - skicka brev till fel@ce.kth.se eller kontakta Mimers Bar, Osquars backe 20, tel 790 9300, mimer@midgard.kth.se

Preliminärt detaljschema

För föreläsningarna anges vilka kapitel i kurslitteraturen som gås igenom, för övningarna förslag på övningsuppgifter. Schemat är preliminärt och kan vid behov stuvas om.

vecka 36

  • F1 Grunderna i programmering (PT1: Kap 0, 1.1-1.3, 1.5; PT2: Kap 1, 2.1; BP: 1, 2)
  • Ö1 PT1: Uppg 1.1, 1.5, 1.6, 1.10; PT2: Uppg 1.5, 1.7, 2.4, 1.11
  • FX2 Hur fungerar ett program?
  • Dat1 Introduktion till programmeringsmiljön

vecka 37

  • Hemtal 1 lämnas in senast måndag klockan 18.00.
  • F3 Procedurer och funktioner, val (PT1: Kap 1.4 (ej avsnittet om parameterfunktioner/procedurer), 2.1; PT2: Kap 2.1-2.3(ej avsnittet om parameterfunktioner/procedurer), 3.1)
  • Ö2 PT1: Uppg 1.12, 1.13, 1.19, 2.1; PT2: Uppg 2.6, 2.7, 2.12, 3.1
  • F4 Styrstrukturer, parameteröverföring (PT1:Kap 1.4, 2.2, 2.3; PT2: Kap 2.3, 3.2, 3.3; BP: 3.8)
  • Dat2 Introduktion till Pascal

vecka 38

  • Hemtal 2 lämnas in senast måndag klockan 18.00.
  • F5 Sammansatta datatyper, rekursion (PT1: Kap 3 (utom 3.1.8 och 3.2.3), 2.2.4; PT2: Kap 4, 3.2.4; BP: 4.2)
  • Ö3 PT1: Uppg 1.16, 2.4 (med vektor), 3.1, 3.2; PT2 Uppg 2.13, 3.4 (med vektor), 4.1, 4.3, 4.5
  • FX6 Indexerade variabler, Dynamiska strukturer
  • Dat3 Stålmannen (Slingor, funktioner och procedurer)

vecka 39

  • Hemtal 3 lämnas in senast måndag klockan 18.00.
  • F7 Dynamiska strukturer (PT1: Kap 4.1, 7.1.2; PT2 Kap 5.1, 8.1.2)
  • Ö4 PT1: Uppg 4.18, proc till lab 5; PT2: Uppg 5.18, proc till lab 5
  • F8 Filer (PT1: Kap 5 dock ej 5.3.2; PT2: Kap 6 dock ej 6.3.2; BP: 3.4, 3.6)
  • Dat4 Bokstavsräkning (vektorer)

vecka 40

  • F9 Stora program, Grafiska användargränssnitt (PT1: Kap 7 dock ej 7.4; PT2: Kap 8 dock ej 8.4)
  • Ö5 PT1: 5.11 (med filer); 6.10 (med filer).
  • F10 Komplexitet, Sökning och sortering (PT1: Kap 8.1, 8.2.1, 8.3.1, 8.3.2, 3.1.6; PT2: Kap 9.1, 9.2.1, 9.3.1, 9.3.2, 4.1.5)
  • Dat5 Molekyler (länkade listor)

vecka 41

  • Hemtal 4 lämnas in senast måndag klockan 18.00.
  • F11 Felhantering, Specskrivning, Talsystem, Datordelar (PT1: Kap 7.2.6, 7.3; PT2: Kap 8.2.6, 8.3; BP: 5)
  • Ö6 Datastrukturövningar, sökning och sortering.
  • F12 Andra programspråk, Matlab (PT1: Kap 7.4; PT2: Kap 8.4)
  • Dat6 Kryptering

vecka 42

  • F13 Förberedelser inför tentan
  • Ö7 Extentaräkning
  • Dat7 Uppsamling

vecka 43

  • Tentamen lördag 24 oktober kl 14-17 i F11-15,F22-25, F31-34

vecka 44

  • Ö8 Specskrivningshjälp
  • Lab8 I-uppgiftshjälp
  • FR1
  • FR2
  • FR3

vecka 45

  • I-uppgiftshjälp Inlämning spec senast onsdag 4 november 18.00

vecka 46

  • I-uppgiftshjälp

vecka 47

  • I-uppgiftshjälp, Prototypredovisning senast fredag 20 november

vecka 48

  • Redovisning av I-uppgifter

vecka 49

  • Redovisning av I-uppgifter
F = Föreläsning
Ö = Salsövning
Dat = Datorövning
FX = Extraföreläsning till stöd för nybörjare
FR = Repetitionsföreläsning för den som missade tentan
PT1 = Programmeringsteknik med Pascal, upplaga 1
PT2 = Programmeringsteknik med Pascal, upplaga 2
BP = En introduktion till Borland Pascal

Studiedisposition

Detta är en högskola och du förväntas själv ta ansvar för dina studier, men eftersom många är ovana att planera sina studietimmar följer här ett förslag till disposition av tiden:
Kursen är på 4 poäng vilket motsvarar 4*40 = 160 timmar. 42 timmar används till föreläsningar och övningar samt 3 timmar till tentamen. Återstår 115 timmar för självstudier och redovisningar fördelade på:

Laborationer

Labbkursens första del, LAB1, består av sex laborationer som görs i grupper om två personer. Det är tillåtet att jobba ensam, men vid redovisningstillfällen har tvåpersonersgrupper företräde.

I den första laborationen ingår en introduktion till det operativsystem och det redigeringsprogram som används i kursen. Efter första laborationen förväntas du klara dig själv i datorsalarna.

Endast gruppmedlemmar som är närvarande vid redovisningar kan godkännas. Enstaka labbar får inte sparas till annan kursomgång. Fullgörs inte alla sex labbarna i LAB1 fram till nästa kursstart måste du göra en helt ny labbkurs (detta beroende på att datorer och system byts ut och uppgraderas årligen och detta medför att labbar inte längre går att utföra).


I-uppgift

Labbkursens andra del, LAB3, är en större, individuell programmeringsuppgift. Regler för I-uppgiften finns i laborationshäftet. I-uppgiften redovisas under kursens sista veckor.
Redovisningen sker i tre steg:
Specifikation
Innan programmet skrivs ska en datorskriven specifikation (mall finns på kursbiblioteket) lämnas in till din övningsledare som kommenterar den, och ger den betyget godkänd/underkänd. Blir du underkänd måste en ny specifikation lämnas in. Syftet med specifikationen är att du ska tänka igenom problemet innan du försöker lösa det.
Prototyp
Två veckor efter det att specen lämnats in ska du redovisa en prototyp, dvs en körbar version av ditt program där endast vissa procedurer och funktioner (du föreslår själv vilka i specen) finns med och fungerar. Syftet med prototypen är att du ska komma igång med programmeringen.
Granskning
Innan det färdiga programmet kan godkännas ska det testas av en elev. Eleven får du välja själv, men för din egen skull bör det vara någon ovän, eller kritisk person. Vid testen ska testeleven kritiskt granska ditt program, testköra det och föra ett besiktningsprotokoll. Denna granskning är ett obligatoriskt moment. Varje kursdeltagare måste granska en uppgift. Syftet med granskningen är att du genom att kritiskt granska en annans program ska få en ökad förståelse för hur man ska (och inte ska) programmera.
Tips! Välj granskare först när du är klar att redovisa, och välj då någon som också är klar med sitt program, så att ni kan granska varandra. Om allt annat fallerar kan du vända dig till kursledaren för att utföra en särskild granskning.
Slutredovisning.
Du tilldelas en tid för slutredovisning. Specifikationen, besiktningsprotokollet och granskaren ska medföras till slutredovisningen.

I-uppgifterna är av olika svårighetsgrad. Högre svårighetsgrad ger fler betygspoäng (se Betyg nedan), men tar givetvis också längre tid att göra. Betygspoängen finns angiven på I-uppgiften. Efter kursens slut kan I-uppgifter endast redovisas i omtentaperioder. Eftersom datorsystemen byts eller uppgraderas årligen så bör du vara medveten om att tiden du har på dig att redovisa din I-uppgift är begränsad. Samtidigt som bonuspoängen försvinner så kan lydelsen till din I-uppgift behöva bytas ut. Du måste då ta kontakt med kursledaren. Vi reserverar oss för att byten av datorsystem kan medföra att vissa eller samtliga I-uppgifter inte går att utföra i framtiden. Du kan alltså bara vara säker på att det går att redovisa din I-uppgift fram till nästa kursstart.


Hemuppgifter

Under kursens gång har du möjlighet att göra ett antal hemuppgifter. Meningen med dessa är att uppmuntra till att läsa i förväg i kurslitteraturen. Den som lämnar in hemuppgifterna i tid kommer att få bonuspoäng. 50 % av hemuppgifterna ger 1p och 75 % ger 2p. Alternativt kan dessa poäng intjänas genom att klara tentamen vid det ordinarie tillfället. Hemuppgifterna ska lämnas in i förväg och den som har lämnat in ska vara beredd på att redovisa sitt lösningsförslag vid tavlan på kommande övning. Observera att talet inte behöver vara korrekt löst för att ge poäng, det räcker med ett ärligt försök.

Betyg

För att bli godkänd på kursen måste man klara av de tre momenten LAB1 (inledande labbar som tar ca 3-12 timmar var att göra), TEN2 (tentamen) och LAB3 (I-uppgiften) samt ha samlat ihop tillräckligt många betygspoäng. Slutbetyget i kursen ges av betygspoängsumman DIV 10. Betygspoäng ges för följande moment:
I-uppgiftens betygspoäng (17­52 poäng)
Bonuspoäng för att ha redovisat lab 1­6 i tid (max 6 poäng)
Bonuspoäng för att ha lämnat in specifikationen i tid (2 poäng)
Bonuspoäng för att ha redovisat prototypen i tid (2 poäng)
Bonuspoäng för att ha redovisat I-uppgiften i tid (4 poäng)
Bonuspoäng för att ha klarat tentan vid ordinarie tillfälle (2 poäng), alternativt kan dessa två poäng förtjänas genom att lämna in hemuppgifterna.
Betygsgränserna är följande under 1998­1999:
30­39 poäng ger betyg 3
40­49 poäng ger betyg 4
50 poäng eller mer ger betyg 5

Betyget ges alltså av I-uppgiftens poäng och de bonuspoäng som är giltiga när du redovisar I-uppgiften. Observera att samtliga bonuspoäng försvinner ett år efter kursstart, exakt datum anges på kvittensbladet för labbarna. Lydelser och betygsgränser hänger samman. Det är alltid innevarande års version som gäller, fram till nästa kursstart.

Hjälp och handledning

Hjälp finns att få (i prioritetsordning):
  1. Kurslitteraturen.
  2. Via datorn.
  3. Labgruppskamraten.
  4. Via datorbrev till övningsledaren.
  5. Av allmän handledare i Nadas datorsalar vardagar i läsveckor kl. 11­13, 17­20.
  6. Under redovisningstillfällena.

Hederskodex

Grundregeln är att det jobb du gör i kursen på labbar och tenta ska du göra själv, förutom att labbarna kan göras i tvåmannagrupper. Vid redovisning av labbar ska båda i gruppen kunna redogöra i detalj även för vad labbkompisen skrivit.

Ibland, speciellt när man skriver program, kan det vara nödvändigt att fråga någon annan (en kamrat eller en handledare) om hjälp med att hitta fel. Detta är tillåtet förutsatt att du uppfyller följande villkor.

Varje annan form av samarbete och utnyttjande av andras lösningar betraktas som ett brott mot hederskodexen och kan t ex resultera i att du förlorar alla bonuspoäng, får göra en ny uppgift och så kan ärendet lämnas till KTHs jurist som avgör eventuell avstängning.
För denna kurs gäller speciellt att det alltid är tillåtet att diskutera lösningar med andra, men inte att skriva av eller kopiera andras lösningar. För I-uppgiften gäller att alla delar ska lösas individuellt. Observera att alla lösningar till I-uppgifter lagras och att nya lösningar jämförs med de gamla för att motverka kopiering.

Synpunkter på kursen

Vi är tacksamma för synpunkter på kursen, både under kursens gång och efteråt. En datorstödd kursutvärdering kommer att göras. Synpunkter kan lämnas till kursledaren, övningsledarna eller examinator Kerstin Frenckner kfrenck@nada.kth.se

Intressanta länkar

^ Upp till allmänna kurssidan.


Sidansvarig: <linda@nada.kth.se>
Senast ändrad 6 maj 1999
Tekniskt stöd: <webmaster@nada.kth.se>