RTP - Departement Computerwetenschappen

advertisement
RTP
Real-Time Programmatuur
Programmatuur voor
real-time controle
Yolande Berbers
Departement Computerwetenschappen
200A 03.20
Yolande@cs.kuleuven.ac.be
Yolande Berbers
Programmatuur voor real-time controle
slide 1
RTP

2 groepen
cursus voor 2 groepen
 gecombineerd vak, samen met
Processoren voor real-time systemen (1.5 su.)
 Processoren en programmatuur voor real-time systemen:
geïntegreerd practicum (3 su.)
 2e Burg. W.E.Ir., Mechanica: Mechatronica en
productontwikkeling (gewoon en 2ji.i.)
 voorkennis: Methodiek van de Informatica,
Programmatuur: Ontwerp en Ontwikkeling
 alleenstaand keuzevak
 3e burg. elektr. ir.,3e burg. w.e.ir., elektrotechniek, keuze
 voorkennis: Methodiek van de Informatica,
Informatie- en programmastructuren

Yolande Berbers
Programmatuur voor real-time controle
slide 2
RTP

2 groepen
verschillen tussen 2 groepen
 gecombineerd vak
er zijn practicasessies en een ander onderdeel
 alternatief examen (reeds uitgelegd door H. Bruyninckx)
 alleenstaand keuzevak
 dit vak voorziet 3 oefenzittingen
 deze moeten nog gepland worden
 voorkeur weken 10, 11, 12
 klassiek examen (zie verder)

Yolande Berbers
Programmatuur voor real-time controle
slide 3
cursusnota’s
RTP

boek:
 Real-Time Systems and Programming Languages
 Alan Burns, Andy Wellings
 third edition, 2001
 Addison-Wesley

slides:
 Deze zijn te vinden op het web, via mijn home-pagina:

http://www.cs.kuleuven.ac.be/~yolande/
 huidige versie van slides (op het net) is ± die van vorig jaar
 bij lesvoorbereidingen pas ik die heel regelmatig aan
Yolande Berbers
Programmatuur voor real-time controle
slide 4
RTP

praktische organisatie
les dinsdag 8.25-10.25 uur en woensdag 10.35-12.35 uur
 8u25 is een erg vroeg uur !

uurrooster
 week 8 (volgende week) ben ik in het buitenland
 les loopt dus door tot week 12

ik geef zelf de oefenzittingen
Yolande Berbers
Programmatuur voor real-time controle
slide 5
RTP

doelstellingen van de cursus
inzicht verwerven in problematiek v. real-time systemen:
 basisvereisten van real-time systemen
 moeilijkheden bij de realisering

studie van mogelijke aanpakken
 aangewende software concepten
bv samenwerkende processen, atomische acties
 specifieke mogelijkheden geboden door programmeertalen
bv exceptions in Ada
 specifieke mogelijkheden geboden op systeemniveau
bv tijdsbehandeling, scheduling

het is niet de bedoeling om van jullie
Ada-, C- of Java-programmeurs te maken !!
Yolande Berbers
Programmatuur voor real-time controle
slide 6
RTP
waar ik belang aan hecht

inzicht hebben

begrijpen van de concepten

begrijpen waarvoor de concepten dienen
(dus de problematiek goed begrijpen)

kunnen toepassen van concepten

oplossingen kunnen vergelijken
Yolande Berbers
Programmatuur voor real-time controle
slide 7
RTP klassiek examen (alleenstaand keuzevak)

deel 1: open boek ex (= boek + kopieën transparanten)
 mondeling met schriftelijke voorbereiding
 de tijd is beperkt: 2 uur
 vraag 1
peilt naar inzicht in de cursus
 overzichtsvraag
 combinatie van 2 of meer delen uit de cursus
 vraag 2
 oefening


deel 2: gesloten boek examen
 peilt naar terminologie-kennis
 6 kleine vragen waarvan 5 moeten beantwoord worden
Yolande Berbers
Programmatuur voor real-time controle
slide 8
RTP goed om te weten voor het examen



‘vergelijk x en y’
niet: bespreek achter elkaar eerst x en dan y,
wel: bespreek x en y zodat ze vergelijkbaar worden
(dus volgens hetzelfde stramien) en vergelijk ze dan
precieze syntax van een programmeertaal is niet van
belang voor het examen, wel de semantiek (=wat is het
effect van bepaalde constructies)
het examen is geen défilé: jeans & t-shirts zijn welkom !
Yolande Berbers
Programmatuur voor real-time controle
slide 9
RTP alternatief examen (geïntegreerd pract.)

vragen bij de gekozen oplossingen
 peilen natuurlijk ook naar inzicht in de cursus
 peilen naar waarom bepaalde keuzes gemaakt werden
 vragen welke alternatieven overwogen werden
 kijken of men begrijpt op welk niveau de verschillende problemen
en oplossingen zich situeren
 peilen onrechtstreeks naar terminologie kennis
Yolande Berbers
Programmatuur voor real-time controle
slide 10
RTP

vereiste voorkennis
basiskennis programmeren (Java )
 Methodiek van de informatica (MI)
 en verder
OF: Programmatuur, ontwerp en ontwikkeling (POO)
 OF: Informatie- en programmastructuren (IPS)

Yolande Berbers
Programmatuur voor real-time controle
slide 11
RTP
overzicht van de cursus

karakteristieken v. real-time en embedded systemen (H1)

kort overzicht van Ada, C, en Java (H3 en H4)
 met extra slides over hun geschiktheid voor real-time/embedded

aspect betrouwbaarheid
 betrouwbaarheid en fouttolerantie (H5)
 behandeling uitzonderingstoestanden in programmeertalen (H6)

aspect parallellisme
 programmeren van ‘parallelle’ modules (H7)
 synchronisatie en communicatie met gedeeld geheugen (H8)
 synchronisatie en communicatie zonder gedeeld geheugen (H9)
Yolande Berbers
Programmatuur voor real-time controle
slide 12
RTP overzicht van de cursus (vervolg)

combinatie betrouwbaarheid en parallellisme
 atomaire acties (H10)
 het beheren van hulpmiddelen (H11)

aspect tijd
 tijdsbehandeling in systemen (H12)
 scheduling (H13)

gedistribueerde systemen (H14)

laag-niveau programmatie (H15)

RTOS: real-time besturingssystemen
Yolande Berbers
Programmatuur voor real-time controle
slide 13
RTP

relatie cursus - boek
ik probeer zoveel mogelijk het boek te volgen
 maar natuurlijk leg ik eigen accenten

het aspect ‘programming languages’ komt in het boek
uitgebreider aan bod dan ik nodig acht voor jullie
 we zullen vooral de voorbeelden van Ada bekijken, ook die van
C en Java, maar niets van occam2

normaal geven de slides goed weer wat er gezien werd
 huidige versie van slides (op het net) is ± die van vorig jaar
 bij lesvoorbereidingen pas ik die heel regelmatig aan
Yolande Berbers
Programmatuur voor real-time controle
slide 14
RTP
Real-Time Programmatuur
hoofdstuk 1: inleiding tot
real-time en embedded systemen
Yolande Berbers
Programmatuur voor real-time controle
slide 15
RTP
overzicht

wat is een real-time systeem ?

wat is een embedded systeem ?

concrete voorbeelden

verschillen types van real-time & embedded systemen

kenmerken van real-time & embedded systemen

economisch belang
Yolande Berbers
Programmatuur voor real-time controle
slide 16
RTP

wat is een real-time systeem?
een computersysteem dat moet
 reageren op externe stimuli
 binnen een eindige en wel bepaalde tijd

de correctheid van het systeem
 niet alleen afhankelijk van het logische resultaat
 ook van het tijdstip waarop dat resultaat gegeven werd


niet op tijd reageren is even erg als foutief antwoorden
in het Nederlands
 ware-tijd-systemen
Yolande Berbers
Programmatuur voor real-time controle
slide 17
RTP
wat is een ingebed systeem?

ingebed systeem == embedded systeem

een product met processor en software
 software is onlosmakelijk verbonden met het product
 software wordt niet apart verkocht
 software biedt vaak belangrijke toegevoegde waarde
 product dat een welbepaalde functie vervult

zeer veel voorbeelden in de huidige consumentenmarkt

vaak is ingebed syst. deel van groter industrieel complex
 computersysteem bewaakt en/of bestuurt externe apparatuur
 voorbeelden uit boek komen meestal uit deze hoek
Yolande Berbers
Programmatuur voor real-time controle
slide 18
RTP

real-time systeem vs ingebed systeem
een ingebed systeem reageert op externe stimuli
 deze reacties moeten vaak in real-time gebeuren

ingebedde systemen en real-time systemen
 veel gelijkaardige karakteristieken

in het boek
 real-time system == embedded system
Yolande Berbers
Programmatuur voor real-time controle
slide 19
voorbeelden van RT & ES
RTP
 hoofdcomponenten van globale infrastructuur

al onze energiebronnen hangen af van embedded systemen
(olie, gas, nucleaire energie)

vliegtuigen vliegen, schepen varen, allemaal gebaseerd op
embedded systemen

voedsel, drank, zuiver water komen hoofdzakelijk van
processen die afhankelijk zijn van embedded systemen
 de farmaceutische industrie gebruikt embedded systemen om
medicijnen te produceren en te creëren
 embedded systemen zijn vitaal in autoproductie, nationale en
internationale defensie, spoorwegen netwerken, medische
uitrusting, telecommunicatie, radio en televisie, ...
Yolande Berbers
Programmatuur voor real-time controle
slide 20
RTP

soorten real-time systemen
harde real-time - systemen: absolute noodzaak om te
reageren binnen een deadline
 bv een vlucht-controle systeem
 wanneer de deadlines erg klein zijn en de mogelijke gevolgen
catastrofaal, zijn dit zeer kritische systemen
(bv het besturen van bomraketten)

zachte real-time - systemen: deadline is belangrijk, maar
het systeem functioneert correct ook als een deadline
‘af en toe’ gemist wordt
 bv het verzamelen van gegevens bij procescontrole
 vaak vermindert de waarde van een reactie wanneer deze te
laat komt (maar heeft geen catastrofale gevolgen)
Yolande Berbers
Programmatuur voor real-time controle
slide 21
RTP

soorten real-time systemen
wat gebeurt er wanneer een deadline gemist wordt
 systeem faalt: hard real-time
 waarde van resultaat vermindert: soft real-time
 resultaat heeft geen waarde meer: firm real-time
Yolande Berbers
Programmatuur voor real-time controle
slide 22
RTP
soorten real-time systemen

een computer systeem kan zowel harde als zachte
real-time subsystemen hebben

missen van een deadline
 vaak: kost-functie geassocieerd met missen van een deadline
 aangeven (in %) hoe vaak een deadline mag gemist worden
Yolande Berbers
Programmatuur voor real-time controle
slide 23
RTP
voorbeelden van RT systemen

real-time systemen voor proces-controle

real-time systemen in een productieomgeving

real-time systemen voor communicatie, bevel en controle

veralgemening: industrieel ingebed computersystemen
Yolande Berbers
Programmatuur voor real-time controle
slide 24
RTP

voorbeelden: proces-controle
real-time systeem voor proces-controle
 eenvoudig voorbeeld: zorgen voor een gelijke stroming in een
pijpleiding, door controle van een klep

de hoek van de klep moet aangepast worden aan de
veranderingen van de inputstroming

dit moet gebeuren binnen een bepaalde tijd, of anders zal de
apparatuur aan het einde van de pijp overbelast worden

Yolande Berbers
dit kan best veel rekenwerk vragen
Programmatuur voor real-time controle
slide 25
example: simple valve control
RTP
interface
input flow
reading
flow
meter
processing
output valve
angle
valve
time
Yolande Berbers
Programmatuur voor real-time controle
slide 26
RTP

voorbeelden: proces-controle
proces-controle: algemene kenmerken
 interactie met uitrusting
 gebruik van sensoren en actuatoren
 gebruik van transducers: genereren een elektrisch signaal
evenredig met een fysische gemeten waarde
 gebruik van analoge - digitaal (en digitaal - analoog)
convertoren
Yolande Berbers
Programmatuur voor real-time controle
slide 27
RTP
general process control
operators console
process control
computer
chemicals
and
materials
valve
temperature
transducer
stirrer
finished
products
a process control system
Yolande Berbers
Programmatuur voor real-time controle
slide 28
RTP voorbeelden: productieomgeving

real-time systeem in een productieomgeving
 gebruik van een variatie van mechanische tuigen (werktuigen,
robots, lopende banden),

werking moet gecoördineerd en gecontroleerd worden

vaak een groot aantal losgekoppelde systemen
 automatisering van allerhande handelingen

verlaagt de productiekost

verhoogt de productiviteit
 integratie van het volledige productieproces,
van ontwerp van een product tot fabricatie
Yolande Berbers
Programmatuur voor real-time controle
slide 29
RTP
general manufacturing
operators console
production control
computer
parts
machine
tools
manipulators
conveyor
belts
finished
products
a production control system
Yolande Berbers
Programmatuur voor real-time controle
slide 30
RTP

voorbeelden: comm., bevel en controle
real-time systemen voor communicatie, bevel en controle
 militaire term, veel toepassingen met zelfde karakteristieken
 voorbeelden: automatische bediening van medische toestellen,
luchtverkeer controle, vliegtuigreservaties, bankoperaties per
terminal
 kenmerken:
 ingewikkelde beslissingsregels
 verzamelen van informatie
 grote hoeveelheden
 vaak geografisch verspreid
 administratieve procedures
Yolande Berbers
Programmatuur voor real-time controle
slide 31
RTP communicatie, bevel en controle
command
post
command and
control computer
terminals
temperature, pressure, power and so on
sensors/actuators
a command and control system
Yolande Berbers
Programmatuur voor real-time controle
slide 32
RTP

voorbeelden: veralgemening
veralgemening: industrieel ingebed computersystemen
 directe interface met fysische wereld
 sensoren die op regelmatige tijdstippen informatie geven
 meestal ook een console

operator krijgt uitgebreide informatie (vaak grafisch)

operator kan manueel ingrijpen

toestandsveranderingen in het systeem worden in een
gegevensbank bijgehouden voor analyse en het nemen van
beslissingen
Yolande Berbers
Programmatuur voor real-time controle
slide 33
RTP
real time
clock
industrial embedded system
algorithms for
digital control
interface
data
logging
remote
monitoring
data retrieval
and display
display
devices
engineering
system
database
operator’s
console
Yolande Berbers
operator
interface
Programmatuur voor real-time controle
slide 34
RTP

vb van ingebedde systemen
wasmachine
 één specifieke taak, beperkte functionaliteit
 weinig flexibel
 goedkoop, massaproductie

postsorteermachine
 één specifieke taak, uitgebreide maar overzienbare functionaliteit
 geen massaproductie

communicatiesysteem in wagen
 zeer complex
 goedkoop
 zware real-time vereisten
 laag vermogen gebruik
 moet zeer flexibel zijn, open voor nieuwe toepassingen
Yolande Berbers
Programmatuur voor real-time controle
slide 35
RTP

vb van ingebedde systemen
ADSL switching center
 in centraal punt 20 tot 50 ADSL lijnen op een ATM netwerk
 zware real-time vereisten
 zeer hoge snelheid nodig
 laag vermogen gebruik

MPEG-4 decoder
 zeer complex
 zeer hoge snelheid nodig
 laag vermogen gebruik (bv in draagbare videospelletjes)
Yolande Berbers
Programmatuur voor real-time controle
slide 36
RTP

kenmerken van een RTS
groot en complex
 niet gewoon proportioneel met het aantal lijnen code
 gerelateerd aan de variëteit die in de code voorkomt
 verandert continu omdat de omgeving continu verandert

situaties veranderen

noden veranderen
 nood aan continu onderhoud
 kan variëren van enkele honderden lijnen assembler of C tot 20
miljoen lijnen Ada-code (geschat voor het ruimtestation ISS)
Yolande Berbers
Programmatuur voor real-time controle
slide 37
RTP

kenmerken van een RTS
manipulatie van reële getallen
 veel RT systemen controleren een industriële activiteit
 bv.: controller gebaseerd op feedback

gecontroleerde entiteit heeft een vector van output variabelen,
die veranderen 
in de tijd

outputs worden vergeleken met het gewenste signaal

verschil wordt gebruikt om de input variabelen bij te sturen
 controle gebaseerd op mathematisch model van proces

Yolande Berbers
complex, vaak gebaseerd op differentiaal vergelijkingen
Programmatuur voor real-time controle
slide 38
RTP

kenmerken van een RTS
e.g.: controller (eventueel analoog), gebaseerd op feedback
 r(t) is gewenst signaal
 u(t) is input vector
 e(t) is foutenvector
 y(t) is output signaal
r(t)
Yolande Berbers

e(t)
controller
(analog)
u(t)
plant
Programmatuur voor real-time controle
y(t)
slide 39
RTP
kenmerken van een RTS
 realistischere figuur met een computer, discrete waarden (met *),
en D/A en A/D convertoren
 discipline: controle theorie
r(t*)
controller
u(t*)
(computer)
y(t*)
digital to
analog
converter
u(t)
sample
and
hold
plant
y(t)
 vereiste: vermogen om reële getallen te manipuleren
Yolande Berbers
Programmatuur voor real-time controle
slide 40
RTP

kenmerken van een RTS
extreem betrouwbaar en veilig
 meer en meer vitale functies in de samenleving worden
toevertrouwd aan computer systemen

slecht functionerende systemen kunnen catastrofaal zijn

vaak zijn mensenlevens gemoeid
– bv kerncentrales

kan ook extreem kostelijk zijn
 voorbeeld van zeer kostelijke faling:
Ariane 5, zie volgende slides
Yolande Berbers
Programmatuur voor real-time controle
slide 41
RTP

voorbeeld: ontploffing Ariane 5
eerste lancering van Ariane 5 op 4 juni 1996: na 37 sec.
 boordcomputer denkt dat raket zwaar uit koers is
 boordcomputer geeft sterk bijstuurcommando
 boordcomputer oordeelt dat dit niet voldoende is, en schakelt
zelfs de hoofdmotor in
 raket kantelt, bovendeel scheurt los, zelfvernietigingsdozen
doen het geheel ontploffen
Yolande Berbers
Programmatuur voor real-time controle
slide 42
RTP

voorbeeld: ontploffing Ariane 5
wat liep er mis
 het Inertial Reference System (SRI) berekent de houding en de
bewegingen van de raket, op basis van bepaalde metingen
 deze metingen worden doorgegeven aan de boordcomputer, die
in functie hiervan stuurbeslissingen neemt
 vóór de lancering berekent een zekere module in het SRI die
houding tov het lanceerplatform
 na lancering heeft die bepaalde module geen betekenis meer
 die module werd gestopt ongeveer 40 sec. na lancering
 voor Ariane 4, om count-down te kunnen “pauzeren”
 behouden in Ariane 5: verander geen goedwerkende software
 in die code staat een conversie van een 64-bit floating point
getal naar een 16-bit integer
Yolande Berbers
Programmatuur voor real-time controle
slide 43
RTP

voorbeeld: ontploffing Ariane 5
wat liep er mis (vervolg)
 Ariane 5 stijgt anders op van Ariane 4: traject is verschillend
 na de lancering gebeurde er een conversiefout: het 64-bit
floating point getal had een onverwachte grote waarde
 de toepassing crashte, een 2de computer werd ingeschakeld
 deze 2de computer bevatte dezelfde software, dus crashte ook
 door de crash werd een diagnose bit-patroon naar de
boordcomputer gestuurd, die dit als gegevens interpreteerde,
en besloot dat er drastisch bijgestuurd moest worden, met alle
gevolgen van dien

gebruikte programmeertaal: Ada
Yolande Berbers
Programmatuur voor real-time controle
slide 44
RTP

voorbeeld: ontploffing Ariane 5
hoe had dit kunnen vermeden worden
 fouten door conversies, evenals andere fouten zoals delingen
door 0, kunnen opgevangen worden in specifieke stukken code
(zie H6)

dit gebeurde niet voor de instructie die crash veroorzaakte
 de fout had via simulaties kunnen gevonden worden

Yolande Berbers
maar in de simulaties draaide die module niet na lancering
Programmatuur voor real-time controle
slide 45
RTP

karakteristieken van een RTS
verschillende software componenten zijn gelijktijdig actief
 de apparaten in de omgeving werken gelijktijdig
 deze gelijktijdigheid wordt het best gerealiseerd door
gelijktijdig uitvoerende software componenten
 meer en meer real-time systemen zijn gedistribueerde systemen
 dit vraagt ondersteuning van programmeertalen en/of systemen
Yolande Berbers
Programmatuur voor real-time controle
slide 46
RTP

karakteristieken van een RTS
omgang met ‘tijd’
 responstijd is van groot belang
 deadlines moeten in alle omstandigheden gehaald worden

worst-case moet gekend zijn

voorspelbaarheid van responstijd is cruciaal

real-time systemen worden altijd over-gedimensioneerd
 taal en systeem moeten toelaten om tijd te specifiëren,
deadlines te specifiëren, om te reageren wanneer een deadline
niet gehaald zal worden
Yolande Berbers
Programmatuur voor real-time controle
slide 47
RTP

karakteristieken van een RTS
interacties met hardware interface
 aangesloten hardware: vaak niet de klassieke randapparaten
 randapparaten moeten kunnen gestuurd worden,
liefst op een abstracte manier

vereiste voor efficiënte implementatie en
uitvoeringsomgeving
 de tijdsvereisten kunnen zo streng zijn dat efficiëntie echt
belangrijk wordt (vb DSP)
Yolande Berbers
Programmatuur voor real-time controle
slide 48
RTP

karakteristieken van een RTS
typische karakteristieken voor consumentenmarkt
 goedkoop

beperkt geheugen

goedkopere processor
 time-to-market is extreem laag
 laag vermogen gebruik indien draagbaar
Yolande Berbers
Programmatuur voor real-time controle
slide 49
RTP

‘
karakteristieken van een RTS: overzicht
groot en complex

manipuleren reële getallen

extreem betrouwbaar en veilig

verschillende software componenten zijn gelijktijdig actief

omgang met ‘tijd’

interacties met hardware interface

vereist efficiënte implementatie en uitvoeringsomgeving
Yolande Berbers
Programmatuur voor real-time controle
slide 50
RTP

economisch belang
ingebedde systemen:
 voor elke PC zijn er ongeveer 50 ingebedde systemen
 PC-markt heeft een plateau bereikt, markt voor ingebedde
systemen kan nog enorm groeien

belang voor Vlaanderen
 groot deel van software dat in Vlaanderen gemaakt wordt is
voor ingebedde systemen
 Vlaanderen is derde ‘super-high-tech region’ in Europa
(na Rheinland-Phals en Hessen) volgens Eurostat studie

belang voor Europa
 VS hebben groot deel van ‘packaged software’ markt
 Europa heeft en kan nog groeien in markt ingebedde systemen
Yolande Berbers
Programmatuur voor real-time controle
slide 51
RTP

economisch belang
belang voor Europa
 VS hebben groot deel van ‘packaged software’ markt
(zie volgende slide)
 top 10 software verkopers in de wereld:

Microsoft

Sybase

Oracle

Adobe systems

Computer Ass. Int.

Informix

Novell

American Management Systems

SAP AG

Sterling Software
 Europa kan nog kan nog groeien in markt ingebedde systemen
Yolande Berbers
Programmatuur voor real-time controle
slide 52
RTP
economisch belang
Packaged Software : Production Share versus Customer Share 1993
Production share
100% = $ 100 bn
Customer share
1%
Rest of World
Pacific Region
Europe
4%
5%
16%
14%
42%
79%
USA
39%
Source : Gartner Group 1994
Yolande Berbers
Programmatuur voor real-time controle
slide 53
Download