Dopo aver visto tutte le possibilità messe a disposizione dai dispositivi moderni, è giunto il momento di concentrarci esclusivamente su aspetti spaziali, possiamo quindi inizialmente separare le caratteristiche attraverso due tipologie di coordinate:
• coordinate d’assetto: avendo il dispositivo un volume, esse riguardano il suo orientamento e la disposizione dell’oggetto in riferimento a una posizione “di riposo” prestabilita (es. dispositivo a forma di parallelepipedo appoggiato con la base maggiore su un piano orizzontale con la faccia dello schermo rivolta verso l’alto);
• coordinate posizionali: con le dovute approssimazioni un dispositivo può es- sere rappresentato come un oggetto puntiforme senza un volume, in tale si- tuazione ci si riferisce alla sua posizione nello spazio come a quella di un punto identificabile con il suo baricentro. In questa casistica rientrano anche le informazioni riguardanti gli spostamenti e quindi direzione, verso, velocità e accelerazione.
Quando si parla di spazio bisogna innanzi tutto effettuare una distinzione fra spazio fisico e spazio virtuale, a maggior ragione nel nostro caso in cui la localizzazione può avvenire attraverso meccanismi differenti.
La posizione fisica si riferisce appunto al luogo in cui è situato il dispositivo che sta eseguendo un programma o sui cui è montato hardware specifico per la localiz- zazione, stiamo parlando quindi di uno spazio in cui c’è la possibilità di muoversi in modo continuo. Essa può essere esplicitata in modi diversi:
• assoluta: latitudine, longitudine, altitudine;
• geografica: associazione con entità cartografiche (es. via Sacchi 3, Cesena, FC, Italia);
• organizzativa: si fa riferimento a una suddivisione dello spazio effettuata in base a esigenze strutturali e di coordinazione (es. stanza 5 del DISI).
Queste tre tipologie di identificazione della posizione definiscono un livello di det- taglio molto differente fra loro e devono quindi essere scelte in base alla necessità di precisione ma anche allo scopo della localizzazione: se ad esempio il sistema è
CAPITOLO 2. ARCHITETTURA DI PROGRAMMAZIONE
AGGREGATA 48
concentrato sul movimento di un utente all’interno di uno stesso dipartimento, a po- co serviranno le corrdinate geografiche o l’indirizzo del dipartimento mentre avremo la necessità di sapere in quale stanza o corridoio si trova il dispositivo in questione. Mentre le prime due tipologie fanno uso di sistemi di riferimento definiti universal- mente, nel terzo caso saranno i costruttori del sistema a dover delineare e nominare le zone di interesse secondo le caratteristiche dell’ambiente rendendo quindi necessaria una fase di configurazione iniziale in cui verranno definite le regioni significative.
La posizione virtuale si riferisce invece a concetti definiti dal sistema che ab- biamo sviluppato, per ovvie ragioni in un sistema che utilizza la rete possiamo fare riferimento al nodo della rete a cui il dispositivo è connesso e in cui vengono eseguite le astrazioni delle operazioni. In questo caso lo spazio è discreto in quanto si passerà ad esempio da un nodo ad un’altro senza soluzioni di continuità; con questa struttura si rende possibile anche distinguere fra un posizionamento di tipo assoluto (indirizzo IP) e uno di tipo relativo (domini e sottodomini identificabili tramite DNS). In que- sto caso i ragionamenti devono essere quindi effettuati sul valore degli indirizzi IP dei dispositivi: la situazione in regime di connessione Wi-Fi alla stessa rete non pre- vede grossi intoppi per quel che riguarda le considerazioni fra dispositivi diversi in quanto la struttura della rete determina un assegnamento di indirizzi nella rete locale che ci consente di collocare un dispositivo nella suddetta rete. Stesso discorso non può essere effettuato in regime di connessione dati in quanto non c’è un meccanismo identificabile che ci permetta di estrapolare informazioni dall’indirizzo IP assegnato a ciascun dispositivo, tale comportamento è inoltre fortemente dipendente dai singo- li operatori: non ci resta quindi che considerare l’id della cella a cui si è connessi valutando eventuali cambiamenti o variazioni della potenza del segnale.
Andiamo ora ad analizzare tutto quello che concerne il moto che può compiere un dispositivo autonomamente (per esempio un robot) oppure tramite l’intervento dell’utente. Il moto in sè non è altro che un cambiamento di posizione di un corpo in funzione del tempo, stiamo quindi parlando di uno spostamento che deve essere ovviamente caratterizzato:
• qualitativamente: tramite un punto di partenza, una direzione e un verso, oltre che un punto di arrivo (se esso è già terminato o se comunque ne è program- mata la fine);
CAPITOLO 2. ARCHITETTURA DI PROGRAMMAZIONE
AGGREGATA 49
• quantitativamente: da dei valori che ne identificano la velocità e l’accelerazio- ne (nel caso in cui non si tratti di un moto uniforme).
Le feature presenti negli OS mobili visti all’interno del capitolo 1 ci danno inoltre lo spunto per caratterizzare il moto secondo dei pattern riconducibili alle abitudini umane:
• camminata (movimento contraddistinto da velocità ridotta e pressochè costan- te, indicativamente poco sopra il m/s ovvero circa 4 km/h);
• corsa (movimento denotato da velocità media e pressochè costante, indicativa- mente sotto i 3 m/s ovvero 10 km/h);
• guida (movimento contraddistinto da velocità fortemente discontinue, che si aggirano in media attorno ai 18 m/s ovvero 65 km/h, intervallate da possibili momenti di sosta).
La descrizione è stata fin qui effettuata in linea puramente generale tenendo in con- siderazione soprattutto i criteri derivanti dall’analisi fisica di questo concetto, se esa- miniamo invece l’aspetto riguardante lo spazio virtuale uno spostamento rilevabile può essere caratterizzato da:
• passaggio da un nodo ad un altro all’interno della stessa rete (Wi-Fi);
• passaggio da una cella ad un altra all’interno della rete dati;
• passaggio da 3g a Wi-Fi o viceversa (dovuto all’entrata/uscita dalla zona di copertura del router).
A livello implementativo, Android consente di rilevare tutti questi cambiamenti e di programmare quindi azioni in risposta agli eventi in questione: attualmente però c’è un solo limite ed è costituito dal fatto che il cambiamento di cella è rilevabi- le solamente a schermo acceso, si ritiene quindi indispensabile mantenere attivo il dispositivo altrimenti esso si accorgerà del passaggio solo al momento del risveglio.