Programdesign (Sun SPOT)
Denne artikel indeholder informationer omkring den konkrete udformning af Sun SPOT programmet. Designet ligger tæt op ad kravspecifikationen
Generelt
Vi vil som altid i forbindelse med grafisk brugerflade programmering benytte os af model-view-control design mønstret.
Model
Modellen er den del af systemet, som skal håndtere alle data, hvilket inkluderer positionsbestemmelse samt protokol. Disse punkter bliver behandlet selvstændigt nedenfor.
Modellen kommunikerer med den grafiske brugerflade igennem interfaces. Brugerfladen må ikke i sig selv indeholde vigtige oplysninger såsom variabler, sensor lister osv. Disse gemmes og vedligeholdes i modellen.
Protokol
Protokollen opdeles som i kravspecifikationen i to dele. En for basisstationen og en for de frie sensorer. I forbindelse med simulering af sensorer gælder nogle specifikke forholdsregler, da der i dette tilfælde skal oprettes en virtuel forbindelse og ikke en fysisk forbindelse mellem basisstationen og sensorerne.
Basisstation
Basisstationenen skal kunne holde styr på mange ting på en gang. Det er derfor nødvendigt at benytte trådet programmering.
Opgaver (Ukomplet liste):
- Håndtering af indkomne datapakker.
- Ping. Hver frie sensor skal konstant gøre opmærksom på sin tilstedeværelse.
- Data. Temperatur, accelerometer, lys, radiostyrke. Dataene håndteres konkret et andet sted.
- Vedligeholdelseskommandoer, herunder:
- Hver frie sensor vil forsøge at oprette forbindelse til basisstationen. Der er således et konstant behov for, at sensorer kan kontakte basisstationen.
- Hvis en sensor pludselig mister forbindelse til en anden sensor, skal dette rapporteres.
- Status meddelelser som f.eks. antal naboer, deres adresser osv.
- Håndtering af data.
- Som beskrevet i kravspecifikationen skal det være muligt til hver en tid at se en sensors målinger. Vi ved endnu ikke, om disse målinger skal gemmes eller blot være den seneste måling.