An Architecture For Ubiquitous Applications: Ubiquitous Computing and Communication Journal

Download as pdf or txt
Download as pdf or txt
You are on page 1of 8

AN ARCHITECTURE FOR UBIQUITOUS APPLICATIONS

Sofia Zaidenberg, Patrick Reignier, James L. Crowley


Laboratoire LIG
681 rue de la Passerelle - Domaine Universitaire - BP 72
38402 St Martin d'Hères
{Zaidenberg, Reignier, Crowley}@inrialpes.fr
http://www-prima.imag.fr

ABSTRACT
This paper proposes a framework intended to help developers to create
ubiquitous applications. We argue that context is a key concept in ubiquitous
computing and that, by nature, a ubiquitous application is distributed and needs to
be easily deployable. Thus we propose an easy way to build applications made of
numerous modules spread in the environment and interconnected. This network of
modules forms a permanently running system. The control (installation, update,
etc.) of such a module is obtained by a simple, possibly remote, command and
without requiring to stop the whole system. We ourselves used this architecture to
create a ubiquitous application, which we present here as an illustration.

Keywords: middleware, ubiquitous computing, distributed application,


deployment.

1 INTRODUCTION To come to the point, in order to achieve its


vision, ubiquitous computing must (i) Integrate
New technologies bring a multiplicity of new numerous, heterogeneous and spread out platforms
possibilities for users to work with computers. Not that can dynamically appear and disappear. (ii)
only are spaces more and more equipped with Perceive the user context to enable implicit
stationary computers or notebooks, but more and interaction.
more users carry mobile devices with them (smart This is the background when developing
phones, PDAs, etc.). Ubiquitous computing takes ubiquitous applications. What we propose is an
advantage of this observation. Its aim is to create implementation of this background, of the software
smart environments where devices are dynamically infrastructure underlying a ubiquitous system. Our
linked in order to provide new services to users and architecture comprises the communication and
new human-machine interaction possibilities. The interconnection of modules, service discovery, a
most profound technologies are those that platform for easy deployment, dynamic re-
disappear. They weave themselves into the fabric of composition without restart. This architecture is
everyday life until they are indistinguishable from it easy to install on every device of the environment,
[16]. A ubiquitous environment is typically it works on Linux, Windows and MacOSX.
equipped with sensors. Users are detected using Modules are easy to develop thanks to a wizard
vision or the mobile devices they carry. Such an (section 3.2.3) for Java. Modules can also be
environment should also provide numerous human- written in C++ and can communicate with the
machine interfaces. Moreover, all the devices in the others. Thanks to this architecture, developers can
environment can be mobile, appearing and focus on the algorithms which make the
disappearing freely as users come and go. As a intelligence of the system and address fundamental
consequence, a ubiquitous system is necessarily problems. The cost of adding a module and
distributed. We are in an environment where deploying it for testing on several machines is
computers and devices are numerous and spread out, minimal. One can install, uninstall, start, stop or
by definition of ubiquitous, and need to cooperate update a module without suspending the whole
in order to achieve a common goal. Furthermore, system.
the environment should not put constraints on the Furthermore, we propose a centralized
kind of platforms it integrates. In fact, legacy knowledge base. This database records the history
devices are already present and should be used. of modules’ lifecycles, of actions and events in the
Additionally, the system integrates users’ mobile environment. It also contains static information
devices, and thus can not put any constraints on about the infrastructure and the users. This database
them. helps the development by allowing to replay a

Ubiquitous Computing and Communication Journal 1


scenario, to examine an experience, etc. based on our architecture.

2 RELATED WORK 3 AN ARCHITECTURE FOR UBIQUITOUS


APPLICATIONS
Context has been recognized as being a key
concept for ubiquitous applications [3], [7]. Dey [3] 3.1 Needs
defines context to be “any information that can be As we described above (section 1), a ubiquitous
used to characterize the situation of an entity, environment needs to integrate heterogeneous
where an entity can be a person, place, or physical platforms: computers running with different
or computational object”. A number of frameworks operating systems and mobile devices such as smart
have been proposed to facilitate context-awareness phones or PDAs. Therefore, a ubiquitous
in ubiquitous environments. Some are centralized computing architecture is distributed. This implies
context servers, such as Schilit’s mobile application the need for a communication protocol between the
customization system [13], the Contextual modules that are spread in the environment.
Information Service (CIS) [10], the Trivial Context Furthermore, it implies the need for a dynamic
System (TCoS) [5] and the Secure Context Service service discovery mechanism. In fact when a
(SCS) [1], [8]. These systems operate as module needs to use another module, e.g. a speech
middleware collecting unprocessed data from synthesizer, it needs to find it in the environment
sensors, treating it and providing interpreted, high first. Moreover, often the need would be to find a
level context information to applications. In this speech synthesizer in the location of the user. Thus
manner it is easier to ensure data integrity, we first need to dynamically find a host connected
aggregation and enrichment. On the other hand it is to speakers located in that room; and then find the
harder to make such a system evolve in size and needed module on that host. It would be even better
complexity. Most of this work is rather early in if we could dynamically install and/or start this
ubiquitous computing. Distributed systems have module if it is not already available. More generally,
been proposed, as for example the Context Toolkit it is convenient to be able to control the deployment
[3] or the architecture proposed by Spreitzer and and the lifecycles of modules. This example shows
Theimer [14], where context information is that we also need a knowledge base on the
broadcasted. The Context Toolkit offers distributed infrastructure and the registered users. This
context components and aggregators that make the component knows that there are speakers in the
distributed character of the environment transparent given room and it knows the hostname of the
to the programmer. device connected to them. With the perspective of
More recent work proposes frameworks for providing services to users, this knowledge should
ubiquitous applications, helping developers to use include user preferences such as the preferred
context: Rey [2] introduces the notion of a modality for interaction (e.g. audio rather than
contextor, a computational abstraction for modeling video). This knowledge could be spread: each
and computing contextual information. A contextor machine knows its hardware and capabilities. But
models a relation between variables of the we made the choice of a centralized database with a
Observed System Context. An application is “map” of the environment in terms of hardware. In
obtained by composing contextors. This work is an fact, queries of this knowledge base are very
extension to the Context Toolkit as it adds the frequent and it is more convenient to group the
notion of metadata and control to the system. information, rather than search on several hosts.
Our work also proposes a structure for In addition, for more flexibility and a better
developing ubiquitous applications. But our scalability, modules can be written in different
architecture is more general. In fact, we propose no programming languages. Such a distributed
more than an easy way to create a number of architecture is hard to maintain. In fact, installing
interconnected, distributed modules whose software on several heterogeneous machines and
lifecycles can be remotely controlled. The devise of keeping it up-to-date is laborious. The update
one module and the deployment of the global should be easy and quick, without requiring the
system are simple. Our architecture stays in the stop of the whole system, or even the stop of the
realm of ubiquitous computing as it is oriented for machine being updated.
interactive applications: it has a small latency and a We propose such an architecture, responding to
small network cost. these needs with the combination of two recent
In the following sections we describe our technologies: OMiSCID [4] for communication and
architecture. We state the needs that appear when service discovery and OSGi (www.osgi.org) for
building ubiquitous applications and that we deployment. Additionally, we designed a database
respond to. We then explain how we respond to serving as the central knowledge component. The
those needs and what the underlying technologies following sections detail these aspects.
that we use are. Finally we illustrate our work by an
example of a ubiquitous application developed

Ubiquitous Computing and Communication Journal 2


3.2 Architecture to use each module like a black box, knowing only
the message format (see section 3.2.1.1 below).
In this section we describe in detail which Moreover, this facilitates the ubiquitous
technologies our architecture is based on and how deployment of the system. In fact, modules can run
one uses it to create ubiquitous applications. on different hosts, including mobile devices:
3.2.1 Communication between modules: OMiSCID and its modules can be implanted on a
OMiSCID PDA connected to the network via WiFi.
As shown above (section 3.1), we need a Additionally, OMiSCID is multi-language and
communication protocol between modules. For multi-platform as it is implemented in C++ for
more flexibility and scalability, each module is an Windows, Linux and MacOSX, and in Java. In this
independent piece of software and can be devised matter, applications run on one host, but are
by different developers. Such a protocol has been ubiquitous because of their easy and transparent
specified and implemented by [4]: OMiSCID is the access to any other mobile or stationary device of
resulting middleware, composed of two layers: (i) the environment, “equipped” with a module
network communication: BIP [9] with a minimal providing access to it.
network cost: only a 38 bytes heading per message.
(ii) The service layer using DNS-SD (www.dns- 3.2.1.1Communication format
sd.org), also called Bonjour (c.f. Apple), as a
distributed directory. Each module is implemented For modules to understand each other, we need
as an OMiSCID “service”. At startup it declares a convention for the format of exchanged messages.
itself to the domain and can be contacted by any We made the choice of the XML format for
service in this domain, whether they are physically messages. Each connector is associated to an XSD
running on the same host or not. This contact is schema (which can be retrieved from the database)
made through “connectors” defined by each module. and incoming or outgoing messages are valid XML
Three types of connectors exist: input, output and strings for the corresponding schema. To facilitate
inoutput. Modules communicate in several ways. the processing of this XML, we use Castor
An output connector can broadcast messages. For (www.castor.org) for a mapping between XML and
instance a person tracker sending an event each Java objects. In this manner, developers work only
time a person enters or leaves the area. To receive with objects. They do not need to know exactly the
messages (and react to them using listeners), a syntax of messages, but only the semantic.
module connects its input connector to an output
connector. To send a message and receive an 3.2.2 Deployment of modules: OSGi
answer, a module connects its inoutput with another
module’s inoutput. Figure 1 shows the connectors At this point we have a distributed architecture
of a personal assistant (called “PersonalAgent”), of inter-connected modules. Such architecture can
which is described section 3.3 below. “-” represents quickly become hard to control and maintain. For
inoutput, “+” – input and “#” – output connectors. instance, a person tracker runs on several machines
An OMiSCID service also defines variables, with to monitor several rooms. We need an easy way to
read or read-write access, representing its state. install and update the tracker on all these machines
when a new version is developed.
Furthermore, we are in an environment with
numerous stationary machines and where devices
appear dynamically. We can not consider installing
every module manually on every machine. We need
an opportunistic strategy: we install a module on a
machine only when needed. For instance we install
a speech synthesizer on a machine in a room when
we need to send a message to a user in that room.
The dynamic deployment of modules is based on a
central server containing all available modules.
OSGi provides these functionalities. We use
Oscar as an implementation of OSGi. An Oscar
platform runs on each device of the ubiquitous
Figure 1: The personal assistant and his environment. At least two bundles are required: one
connectors. Each connector is used for incorporating jOMiSCID, a Java implementation of
communication with a particular OMiSCID OMiSCID 1 and one incorporating Castor for
service. (Not all the connections are shown.) modules to decode messages they send and receive

This architecture allows us to connect modules,


1 jOMiSCID is not a JNI layer of the C++
developed possibly by different programmers, and
version, but a complete rewriting in pure Java.

Ubiquitous Computing and Communication Journal 3


(section 3.2.1.1). All the modules are at the same 3.2.3 For easy development: a wizard
time OSGi bundles and OMiSCID services. A
common bundle repository on a central machine To facilitate the programmer’s work, we have
regroups all the modules. It is accessed via http. developed an Eclipse plug-in [11]: a wizard for
Every Oscar platform installs its bundles from this creating new projects of type OMiSCID service and
repository and thus is linked to it. Newly developed OSGi bundle. An empty project generated with this
modules are added to the repository and the Oscar wizard contains the correct arborescence of
platforms just install the corresponding bundle. packages and files, the main classes with the
When a module is updated in the repository, the OMiSCID code to create and register the service,
Oscar platforms just update their bundle. This is the XML file for the developer to specify the
convenient because once this architecture is set up, connectors, the lifecycle code for OSGi, the
new modules are easy to install. One doesn’t need manifest file and the build files to build and publish
to compile them on the new machine or to worry the new bundle on the repository. To add a new
about dependencies. To update a module, one also empty module, one (i) uses the wizard, (ii) builds
has to just enter the “update” command in Oscar. and publishes the new project by running the
It is also convenient to be able to remotely generated build.publish.xml file (iii) installs it
control other modules (start a needed module, in Oscar (a single install command) and (iv) starts it
update, stop or even install one). We add this in Oscar (a single start command). At this point the
functionality to OSGi via a bundle called new OMiSCID service is visible in the domain.
“remoteShell”. It is an OMiSCID service able send A user interface has been created to visualize
commands to the Oscar platform that it runs on. the services running in a domain. It is shown Figure
Thus a distant module can call upon the local 3. Figure 2 shows the graphical interface of Oscar.
“remoteShell” (through OMiSCID connectors) and
send OSGi commands to it. This bundle should be
installed by default on every Oscar platform as well.

Figure 2: The graphical interface of Oscar, showing the bundles. The active bundles are visible as
services on Figure 3.

Figure 3: Visualization of the OMiSCID services running in a domain.

Ubiquitous Computing and Communication Journal 4


the user of the reminder. It tries to find the user in
3.3 Example: a personal ubiquitous assistant the building and to send him a message. The
assistant takes into account the user’s context
We use the architecture described above (whether he is alone or not) and preferences (his
(section 3.2) for a personal ubiquitous assistant. preferred modality for receiving a message). In the
Our environment is equipped with a number of following sections, we explain in detail how this
devices used to retrieve information about the user example works.
and his context. Mobile devices brought by users
contribute to that knowledge. We use that 3.3.1.1The context model
knowledge to propose relevant services to the user.
The assistant is the central module of the system. A context is represented by a network of
The assistant can do task migration: doing a task situations [6]. A situation refers to a particular state
instead of the user. It can also provide additional of the environment and is defined by a
services, such as forwarding a reminder to the user configuration of entities, roles and relations. An
while he is away from his computer. Thus our entity is a physical object or a person, associated
assistant is personal in the sense that it is user- with a set of properties. It can play a role if it passes
centered. It is ubiquitous because it uses a role acceptance test on its properties. A relation is
information provided by all available devices in the a semantic predicate function on several entities.
environment to observe the user and estimate his The roles and relations are chosen for their
current situation or activity. It calls upon these relevance to the task. A situation represents a
devices to provide services as well. Thereby, the particular assignment of entities to roles completed
services provided are context-aware. At last, our by a set of relations between entities. Changes in
assistant is a learning assistant and these services the relations between entities or the binding of
are user-adapted. In fact, most of current work on entities to roles indicate a change in the situation. A
pervasive computing [15], [12] fires pre-defined federation of observational processes detects
services in the correct situation. We start with a pre- situation changes.
defined set of actions and adapt it progressively to In order to provide services we define rules
each particular user. The default behavior allows associating actions to situations. An action is
the system to be ready-to-use and the learning is a triggered when a situation is activated. This
life-long process, integrated into the normal corresponds to a service being provided to the user.
functioning of the assistant. Figure 2 shows an example of a context model.
The assistant observes the user and gathers clues This context model tells the assistant what to do in
on his context and his activity. For that he needs a given situation and what the current situation is
perceptive modules – sensors. For providing given the observations of the user and the
services to the user, it needs proactive modules – environment. The context model incorporates the
effectors. Some modules run on any host and some intelligence of the assistant.
are linked to, or used to access, specific hardware.
They run on the machine connected to it. For
instance, a person tracker needs at least one camera.
The person tracker module is installed on the
machine connected to the camera(s). Likewise, each
machine equipped with speakers would have a
speech synthesizing module. To sum up, our
ubiquitous system is composed of several modules
and the personal assistant. Sensor modules fire
events received by the assistant, or the assistant
explicitly interrogates a sensor. With this input the
assistant estimates the user’s situation (section
3.3.1.1). The learned behavior indicates to the
assistant how to act in a certain situation. It contacts Figure 4: Extract of the context model
effectors to execute the appropriate action (e.g.
provide the chosen service). This context model is implemented in Jess as a
Petri network.
3.3.1 Mechanism of the assistant

We mentioned in section 3.3 above an example 3.3.1.2 The ubiquitous database


of a service provided by the assistant: the user’s
agenda fires a reminder while he is away. The All modules share a database divided into four
system detects this event and reacts by informing parts: user, service, history and infrastructure
(Figure 5). Each part is implemented as an SQL

Ubiquitous Computing and Communication Journal 5


schema.

Figure 5: Simplified scheme of the database

of the assistant. For easy communication with the


The part history stores the modules’ lifecycles database, we use Hibernate (www.hibernate.org).
(the dynamic start and stop of bundles in the OSGi We enclose it into a bundle used by other modules
platform), all occurred events and actions taken by to query the database.
the system. This part is useful for explaining to the
user (if required) why an action was or was not 3.3.1.3 The global mechanism
taken. We believe that these explanations bring a
better trust of the user for the system. The part Figure 6 resumes the logic of our system and
infrastructure contains known, static information shows the connections between components. The
about the environment: rooms of the building and personal assistant is the central part of the system.
their equipment (in- and output devices and the Its role is to connect all the resources and
hardware units controlling them). This knowledge knowledge in order to reach the goal of providing
allows to determine the most appropriate device for services to the user. It is linked to the environment
a service. The part user describes registered users by the modules mentioned above (section 3.2). The
(associating users with their Bluetooth devices and latter run in the OSGi platform as bundles and
storing user logins for identification). As a future communicate with each other (and with the
evolution, this data will be brought in by the user’s assistant) through OMiSCID (as they also are
PDA as a profile. When the user enters the OMiSCID services).
environment, his profile is loaded into the system. Perception gives the assistant information about
This discharges the PDA of any heavy treatment the user, for instance his location and his activity.
necessary to exploit this personal data (learning These clues are directly interpreted as the role (in
algorithms, HMMs, etc.). The computation is taken the sense defined above, section 3.3.1.1) the user is
over by an available device and the PDA, whose playing. It sends it as an input to the context model
resources are very limited, stays available for its by asserting Jess facts. These possibly trigger
primary purpose. When the user leaves the situation changes. The activation of a situation
environment, the new profile is migrated back on triggers rules defining services that are to be
the PDA and the user has the updated data with him provided to the user. Concretely, Jess rules call
(to be used in another ubiquitous environment). The methods of the assistant who knows how to provide
part service is a free ground for plug-in services. that service and which OMiSCID services (effector
For instance, if available, Bluetooth USB adapters modules) to contact.
can detect users’ presence thanks to their Bluetooth The ubiquitous database is used all along in this
cell phones and PDAs. This information may be process. It is mainly queried by the assistant, but
used to determine the identity of a video tracker’s also by other modules.
target.
The database is the knowledge and the memory

Ubiquitous Computing and Communication Journal 6


Figure 6: The global mechanism of the system
architecture providing simple and convenient
Let us reconsider the example scenario means to create ubiquitous software modules. The
mentioned section 3.3.1 above in order to explain in interconnection and communication of these
depth how it works. The user’s agenda modules forms the ubiquitous application. As we
(KOrganizer) triggers a reminder. A module provide technical solutions to easily deploy and
(“KAlarmDaemon”) listening to reminders detects interconnect modules, developers can focus on
this event. It sends a message on his output algorithms that will constitute the core intelligence
connector. The assistant receives this event. The of their systems. We use OMiSCID for service
alarm is considered as an entity playing the role discovery and communications. OSGi provides us a
“AlarmNow” hence the assistant asserts the framework for deployment of modules without
corresponding Jess fact. If the current situation is stopping the whole system. The combination of
“UserPresent”, nothing else happens. Otherwise, if OMiSCID and OSGi allows us to add the remote
the situation is “UserAbsent”, a rule indicates that control of modules’ lifecycles.
the reminder should be forwarded to the user.
Actually, there are three rules differentiating the 5 REFERENCES
cases where the user location is unknown and
where the user is in a known office but alone or not [1] C. Bisdikian, J. Christensen, J. Davis, M. R. Ebling,
alone. Thus one of these rules is fired and calls a G. Hunt, W. Jerome, H. Lei, S. Maes and D. Sow:
method of the assistant. The context model Enabling location-based applications. In WMC '01:
Proceedings of the 1st international workshop on
(implemented as Jess rules) knows what to do and
Mobile commerce, p. 38-42. ACM Press (2001).
the assistant knows how to do it. If the user is not to [2] J. Coutaz, G. Rey: Foundations for a Theory of
2
be found, the reminder is forwarded by email . The Contextors. In CADUI, p. 13-34 (2002).
assistant contacts the email module “MailService” [3] A. K. Dey and G. D. Abowd: The Context Toolkit:
(the user’s email address is known from the Aiding the Development of Context-Aware
database) which sends an email using JavaMail. If Applications. In The Workshop on Software
the user location is known, the assistant tries to Engineering for Wearable and Pervasive
contact the user by his preferred modality (written Computing, Limerick, Ireland (2000).
message, synthesized voice, etc.), according to the [4] R. Emonet, D. Vaufreydaz, P. Reignier and J.
Letessier: O3MiSCID: an Object Oriented
user’s context (alone or not). For each modality in
Opensource Middleware for Service Connection,
preference order, the assistant queries the database Introspection and Discovery. In 1st IEEE
for the machine it can be provided on, in the room International Workshop on Services Integration in
the user is in. Then it searches on that host for the Pervasive Environments (2006).
needed module and, if required, starts or even [5] F. Hohl, L. Mehrmann and A. Hamdan: Trends in
installs the corresponding OSGi bundle remotely. Network and Pervasive Computing. ARCS 2002:
One can notice that the host used to forward the International Conference on Architecture of
reminder could be a mobile device, for instance the Computing System. Proceedings, volume Volume
user’s PDA, as long as it is in a WiFi covered area. 2299/2002 of Lecture Notes in Computer Science,
chapter A Context System for a Mobile Service
Platform, page 21. Springer Berlin / Heidelberg
4 CONCLUSION (2004).
[6] J. L. Crowley, J. Coutaz, G. Rey and P. Reigner:
We presented in this paper an architecture for Perceptual components for context awareness. In
ubiquitous applications. Our aim is to provide International conference on ubiquitous computing,
developers an easy way to build such systems. p. 117-134 (2002).
Looking at the requirements of ubiquitous [7] J. E. Bardram: Pervasive Computing, volume
computing, we created an adapted software 3468/2005 of Lecture Notes in Computer Science,
chapter The Java Context Awareness Framework
(JCAF) - A Service Infrastructure and Programming
2 A text message on the user’s mobile phone
Framework for Context-Aware Applications, p. 98-
would be more adequate. 115 (2005).

Ubiquitous Computing and Communication Journal 7


[8] H. Lei, D. M. Sow, J. Davis, G. Banavar and M. R.
Ebling: The design and applications of a context
service. SIGMOBILE Mob. Comput. Commun. Rev.,
6(4):45-55 (2002).
[9] J. Letessier and D. Vaufreydaz: Draft spec: BIP/1.0 -
A Basic Interconnection Protocol for Event Flow
Services. www-
prima.imag.fr/prima/pub/Publications/2005/LV05,
(2005).
[10] J. Pascoe: Adding Generic Contextual Capabilities to
Wearable Computers. iswc, (1998).
[11] P. Reignier: Eclipse Plug-in creating an OMiSCID
project. www-prima.imag.fr/reignier/update-site.
[12] V. Ricquebourg, D. Menga, D. Durand, B. Marhic,
L. Delahoche and C. Log: The Smart Home
Concept: our immediate future. In Proceedings of
the First International Conference on E-Learning in
Industrial Electronics, Hammamet – Tunisia (2006).
[13] B. N. Schilit, M. N. Theimer and B. B. Welch:
Customizing Mobile Application. In USENIX
Symposium on Mobile and Location-independent
Computing, p, 129-138 (1993).
[14] M. Spreitzer and M. Theimer: Providing location
information in a ubiquitous computing environment
(panel session). In SOSP '93: Proceedings of the
fourteenth ACM symposium on Operating systems
principles, p. 270-283, New York, NY, USA. ACM
Press (1993).
[15] M. Vallée, F. Ramparany and L. Vercouter:
Dynamic Service Composition in Ambient
Intelligence Environments: a Multi-Agent Approach.
In Proceeding of the First European Young
Researcher Workshop on Service-Oriented
Computing, Leicester, UK (2005).
[16] M. Weiser: The computer for the 21st century.
Scientific American, p. 66-75 (1991).

Ubiquitous Computing and Communication Journal 8

You might also like