Appliance-Based Computing
Reference r Appliance Data Services: Making Steps Towards and Appliance Computing World by A. Huang, B. Ling, J. Barton and A. Fox
Introduction r A digital appliance is defined as a single- purpose device. r Examples include the following: m Network-enabled household appliances like NetFridge m Single-purpose computing facility such as a storage server that can be plugged in and used with minimal configuration. m Single-purpose handheld devices such as digital cameras and PDAs
Introduction r Appliances are often thought of as special- purpose devices that are less computer- like than general-purpose PCs but they are not embedded devices. r General purpose PCs may be more useful when connected to the Internet, but they are useful without the Internet. r An ActiveBadge is useless without infrastructure software for location. r An appliance such as Netfridge would fall in between.
Introduction r We can classify appliances by their degree of sharing. m Mobile devices (e.g., PDA)s have little or no sharing. m Environmental devices (e.g., household appliances) is explicitly shared among a few people. m Enterprise devices such as storage are shared among many people.
Introduction r The intention of digital appliances is the following: m Make our life easier m Provide powerful improvement over their non- digital counterparts. m “Infrastructure enabled” Able to leverage computational power, network b/w, content and aggregate user base of services in infrastructure Example: Viewing Web content on handhelds made possible by transformation proxies.
Problems with Digital Appliances r Usability m Often the digital appliance is more difficult to use. m May have too many features. r Lack of an infrastructure r Quote from Dan Carp, CEO of Kodak m “The industry has made picture-taking more difficult and more complicated by cramming onto digital cameras more features, more buttons and more bells and whistles than most people want or need…The one lesson that 100 years of consumer marketing should have taught us: In the picture business, simple tramps megapixels, every time.”
Illustrating the Problem digital cameras PDAs digital photo frames wall-mounted displays Web pages Move this picture from my camera to my Web page Display the notes taken on my PDA on this wall monitor
Illustrating the Problem digital cameras PDAs digital photo frames wall-mounted displays Web pages
Illustrating the Problem r Current process for putting pictures from digital camera on web page: m We take the picture m Transfer it to the PC m Transform it m Upload it to destination m Edit the HTML r Desired: m Take the picture m Specify the destination m Next thing you know it’s at the desired location.
Appliance Computing World r Vision of Appliance Computing World m An appliance computing world is one in which people move data effortlessly among artifacts to accomplish a variety of simple and advanced tasks r Attributes m Some attributes are inherent to the way people interact with appliance computing world. These are discussed next.
Attributes o f Appliance Computing World r People move data using concrete artifacts m People think of devices in terms they understand People don’t care how pictures are stored, but only that camera takes a picture, film stores it, end of story. People don’t care what format the file is in. They want it to be on a webpage. r Devices are simple, single-purpose appliances m Moving functionality from the computer onto a camera complicates things, as opposed to making life easier.
Attributes of Appliance Computing World r People perform a variety of traditional tasks, as well as a new set of advanced tasks with their devices m The new cool digital device needs to perform at least the tasks an old, traditional device was able to perform and then some m Tradeoff between this, and the previous two attributes
Principles That Enable Appliance Computing r Today dealing with digital devices is difficult since extracting information from a digital device usually requires interacting with a PC. r The user has to deal with both file location and file format conversions. For example, a user may have to take TIFF files (from a scanner) and convert it to GIF or JPEG for a web page. r Bring devices to the forefront m User deals only with source/destination, and not with intermediate computation. r A file’s actual location and format should be hidden from everyday users.
Principles That Enable Appliance Computing r Some features can make a device easier to use. m Examples: The voice command on cell phones or the picture previewing on digital cameras. m This can still be a burden. For example, the digital camera user has to learn how to set the modes on the camera to preview a picture. r Keep the number of user-controllable features users must learn to operate a device to a minimum m User should not have to know anything about “preview” camera mode to turn camera on and off. r There is tension between ease of use and placing potentially useful features on the device.
Principles That Enable Appliance Computing r The emphasis is on making the steps required to perform a high-level task simple. r The implication of the previous two principles is that devices are simple. r What if a user wants more complex functionality?
Principles That Enable Appliance Computing r Place the software required to accomplish tasks in the Internet infrastructure. m Logically centralized software (easy upgrades) m Functionality is moved from the PCs and devices to the supporting infrastructure. m This can make upgrades and administration simpler. m It is easier to reason about reliability and availability.
Appliance Data Services r Appliance Data Services refers to a general application framework on top of which appliance computing applications are built. r The framework implements previously mentioned principles
Scenario Used r Jane is traveling through Europe. r During the trip, she uses her digital camera to take pictures and her PDA to jot down descriptions of her pictures. r She periodically goes to an ADS access point at an Internet Café. r Jane logs in by inserting her SmartCard and entering her PIN. r She selects the “photoalbum” application. r She is prompted for her pictures followed by the descriptions, both of which she transfers using the IR ports on her digital camera and PDA.
The Architecture
Architecture: Basic Data Unit r Basic data unit controlling framework operation is a triplet containing the following fields: m User identifier m Command to be executed m Data to be operated on r The triplet is useful for m Application selection (command-tag) m Access Control (userid) m Other service features (command-tag + userid) Billing, security
Architecture: Main Stages r Data Receive Stage m Collects data, and transfers to next stage once userid/command-tag/data received r Application Control Stage m Determines desired application, determines all needed parameters, sends to Services Execution Stage r Services Execution Stage m Invokes required service on a template it receives m Services are very modular and composable
Architecture: Data Receive Stage r Access Point m Receive data from Appliances m Isolates device heterogeneity to a single architectural component. m Possible Implementations: A commodity PC outfitted with the appropriate hardware interfaces or it can be designed as a special-purpose network appliance. m Example: The Access Point Jane uses requires a Smartcard reader, IR receiver and software and a touch-screen monitor to display Jan’es application options.
Architecture: Data Receive Stage r Access Point (continued) m The software on the Access Point is organized as a set of device adapters, each enabling the access point to “speak” a different device communication protocol. m This isolation of device heterogeneity to one component allows the rest of the system independence from device- specific communication protocols. m Key Challenge: Extensibility in supporting devices and protocols; this arises from the lack of standardization among device vendors and the increase in the variety of devices being introduced.
Architecture: Data Receive Stage r Aggregator m Manages session state m Gathers data sent from the Access Point and sends to the data to the next stage once all pieces of (userid, command-tag,data) triple are received. m Simplifies adding support for new devices in a robust, easy-to-deploy way m Scenario: Jane enters janedoe for the user identifier and photoalbum for the command-tag. The aggregator maintains this state so that each picture and text description from Jane creates a triple (janedoe, photoalbum, [picture or description]). This is forwarded to the next stage.
Architecture: App. Control Stage r The user identifier and command tag are used to determine the chosen application. r Command Canonicalizer m Converts command-tag from its original data type to plain text m Facilitates the design of devices with simple user interfaces m Example from scenario Jane takes a picture and speaks the desired command-tag into the camera. When the pictures are transferred into an Access Point, the command-tag has been specified.
Architecture: App. Control Stage r Template Database m This is where templates are stored. m Templates are looked up by command-tag + userid m Templates describe application’s behavior by describing data, and specifying services to be performed. m Minimizes device configuration m Provides a level of indirection between application selection and application specifications which separates the concerns of applications users and applications creators.
Architecture: App. Control Stage r Template Database (continued) m Templates may be developed by the manufacturer and placed within the infrastructure. m Customers can get new applications (or an upgrade) without having to worry about configuring the applications on their devices. m Example: Kodak wants to make a set of ADS applications available to customers who purchase a Kodak camera. If templates are shipped with the application, it makes it more difficult to upgrade or add new applications; Pirating is easier.
Architecture: App. Control Stage r Dataflow Manager m Coordinate data received from the user to make certain that an application has all the data it requires. m Uses application template to place data into proper parameter slots. m Data from different devices at different times may be coordinated. m Example Photos could be input from the camera, and their description from the PDA at a later time. Later these can be combined.
Architecture: Services Execution r Application Dispatcher m Invoke the services specified in the application template on the data it receives. m Example: For Jane’s photoalbum application, these services include a service that scales her pictures by an appropriate amount and FTPs’ the pictures and descriptions to the appropriate site.
Developmental Experience r Set of services and device adaptors to support two applications: Web Photo album and Guest book r Web Photo album m Users create and publish web-based photo albums. r Guest Book m Takes input from a web cam, business card scanner and PDA to create a web-based guest book containing people’s pictures and business card information. r XML application template used to describe the input data and services to invoke.
Conclusion r Does this make good business? r Could potentially be useful as digital devices becomes more widespread. r Just how powerful is this model of computing?