The present invention relates to data storage and exchange and more specifically to a system and method for storing and exchanging data between a wireless computing device and a host computer such as a server.
There are many types of data processing devices including computer terminals, wireless personal digital assistants (“PDAs”) and network servers. Data objects such as calendar entries, e-mail messages and data objects are frequently shared between two or more data processing devices. When a copy of a particular data object is stored on both a computer terminal and a server that serves the computer terminal, for example, the stored data object can be independently modified (i.e. edited, added, deleted, moved, . . . etc) on both the computer terminal and the server. Commonly, after the data object is modified on the computer terminal, the data object is then transmitted back to the server to be stored in place of the original data object, so that the copy of the data object remains up-to-date on both the computer terminal and the server.
One technique for ensuring that the data object on the server is synchronized with the data object on the computer terminal is for the server to assign a unique data object ID to each original data object when the server initially stores the data object. Subsequently, when the computer terminal retrieves the data object, the retrieved data object includes the unique data object ID. If the data object is modified at the computer terminal and transmitted back to the server, as described above, the data object is identified by the server with the same unique data object ID.
Another data sharing technique reduces network data traffic by sending only the actual edits (i.e., the difference between the original data object and the edited data object) rather than the complete, edited data object between the computer terminal and the server. For example, the computer terminal retrieves and edits a data object from the server which is identified with a particular data object ID. The data object is then edited at the computer terminal (e.g., by deleting the third line and changing the third word in the second line from “less” to “more”). The actual edits (i.e. delete the third line and replace the third word in the second line from “less” to “more”) and the data object ID of the document data object are then sent to the server. The server then executes the modifications to the data object with the same data object ID stored on the server.
The actual network bandwidth of the computer network is often limited to the lowest bandwidth of the any one portion of the network connecting the computer terminal and the server. For example, if the server is linked to the computer terminal via a 14.4 kbps wireless connection, then the maximum through put to the computer terminal is 14.4 kbps even though some portions of the network may have a wider bandwidth (e.g., a 1.4 Mbit T1 line, 10 Mbit Ethernet, . . . etc).
In addition, certain wireless networks suffer frequent interruptions due to radio frequency interference and lack of network coverage. A wireless network connection may be interrupted, for example, if the wireless data processing device passes through a tunnel or some other obstruction or into an area without wireless network coverage. Because the wireless network may be interrupted and may often have a relatively low bandwidth, it is important to minimize the data traffic across the wireless network.
In a block 125, the data object is edited in the user terminal. In block 130, a copy of the edits are sent to the server along with the data object ID. The server uses the ID to properly identify and edit the data object and then updates the correct data object according to the edits, in block 140.
A system and method for managing objects in a wireless user terminal are described. When an object is created or added to a user terminal, the user terminal assigns a temporary ID to the object. The wireless user terminal can also be coupled to a server by a network. The object or a copy of the object and the object's temporary ID can also be transferred to the server. The server can then assign a permanent ID to the object. The permanent ID of the object can also be transferred to the wireless user terminal.
The present invention is illustrated by way of example and not limitation in the figures of the accompanying drawings in which like references indicate similar elements.
A system and method for managing data objects in a wireless device is described below. In one embodiment, when a data object is created in a wireless device, the wireless device identifies the data object with a temporary ID code. The data object and corresponding temporary ID are uploaded to the server. The server then assigns a permanent ID to the data object. The temporary ID is also recorded with the corresponding permanent ID. In one embodiment, at the next available opportunity, the permanent ID and the temporary ID are transmitted from the server to the user terminal.
In one embodiment, the temporary ID number is a unique number such as a time stamp or a negative time stamp. For example the time stamp could be the number of seconds since 12:01:00 am, Jan. 1, 2001.
One of the problems that can occur is that the permanent ID for the data object is not received by the user terminal in a timely fashion. The permanent ID may not be received in a timely fashion for many reasons such as network outages or network interruptions or other reasons that the user terminal cannot connect to the server.
The wireless device/user terminal may be a wireless personal digital assistant (“PDA”) or similar computing device. The PDA can be used to generate and store various types of data objects including, but not limited to address book entries, e-mail messages, calendar entries, files of various file types (e.g., Word documents), and memos. When the PDA establishes a connection to a host computer such as a server, the various data objects are uploaded to the host computer. The PDA may be used for extended periods before connecting to the host computer and therefore the data objects created in or added to the PDA may also be edited. For example, a new memo (memo1) may be created in the PDA. When memo1 is completed, a copy of memo1 is placed in a “drop box” in the PDA or otherwise designated for sending to the host computer when the PDA establishes a connection to the host computer. In one embodiment, the drop box is a temporary memory location such as a memory buffer. At a later time, but before the PDA is connected to the host computer, memo1 may be further edited on the PDA. The memo1 edits are also placed in the drop box or otherwise designated for sending to the host computer. When the PDA and the host computer are next connected, the copy of the memo1 and the copy of the memo1 edits are transferred from the PDA to the host computer. However, the host computer may not be able to identify the correct data object to be edited because memo1 has not yet been assigned a permanent ID and the edits sent by the PDA therefore are not identified by a permanent data object ID.
In one embodiment, the PDA (or other user terminal) assigns a temporary ID when memo1 is designated for download to the host computer. In addition, the subsequent edits to memo1 are also assigned the temporary ID. When the PDA and the host computer are next connected, the copy of memo1, the memo1 temporary ID, the memo1 edits and the associated temporary ID are transferred from the PDA to the host computer. The host computer assigns a permanent ID to memo1 and records the corresponding temporary ID with the permanent ID. The host identifies the correct data object to be edited by determining that the memo1 edits include a temporary ID which corresponds to a permanent ID identifying the memo1 data object. The host computer can also transfer the corresponding permanent and temporary IDs to the PDA so that the PDA can re-identify memo1 with the correct, permanent ID in the PDA. The PDA may then use the permanent ID for future data object modifications.
In block 272, the server assigns a permanent ID to the added data object and also records the corresponding temporary ID to the data object. The server then sends the permanent ID and the corresponding temporary ID of the data object to the user terminal, in Block 274. The server determines the correct data object to which to apply the edits in block 276. In one embodiment, the server determines the correct data object by comparing the IDs. The server then edits the correct data object according to the edits, in block 278.
The temporary ID in one embodiment is a timestamp or some other unique number. One way to ensure that the temporary ID is a unique number is to use a timestamp, such as the number of seconds since 12:01:00 am, Jan. 1, 2001. In one embodiment, the temporary ID is a negative number and the permanent ID is a positive number, so that the server can readily differentiate a permanent ID from a temporary ID. In another embodiment, the permanent ID and the temporary are ID are provided with different formats. For example, the temporary ID may be numeric and the permanent may be alphabetic or alphanumeric.
I/O devices 316-1 through 316-N may include, for example, a keyboard, a pointing device, a display device and/or other conventional I/O devices. Mass storage device 310 may include any suitable device for storing large volumes of data, such as a magnetic disk or tape, magneto-optical storage device, or any of various types of Digital Versatile Disk or Compact Disk based storage.
Network interface 312 provides data communication between the computer system and other computer systems such as via the network 420 illustrated in
Elements of the present invention may be included within a client-server based architecture such as illustrated in
In addition, various networking protocols may be used to support communication across the network 420 including, for example, the Asynchronous Transfer Mode (“ATM”), Ethernet, and Token Ring (at the data-link level); as well as Transmission Control Protocol/Internet Protocol (“TCP/IP”), Internetwork Packet Exchange (“IPX”), AppleTalk and DECnet (at the network/transport level). It should be noted, however, that the principles of the invention are not limited to any particular communication channel or protocol.
The server 410 in one embodiment includes a user database for storing various types of user configuration and account data. Users may register and login to the server 410 from a client 440 by specifying a user ID and/or password. According to one embodiment, a user connects to the servers 410, 430 via a browser application such as Netscape Navigator™ or Microsoft Internet Explorer™ which communicates via the Hypertext Transfer Protocol (hereinafter “HTTP”).
In one embodiment, users may configure the server 410 to retrieve and manage specific types of information. For example, a user may configure the server 410 to retrieve up-to-date stock quotes for a specified set of stocks (e.g., reflecting the user's portfolio), to collect the weather forecast for the user's hometown, and/or to retrieve recent articles relating to a particular sports franchise. The server will then retrieve the specified information from other servers (e.g., server 430) on behalf of the user.
In addition to information retrieval and management, in one embodiment the server 410 also provides application services such as email, online scheduling (e.g., appointments, to-do lists, etc), instant messaging, contact management, word processing and a variety of other online services. Users may access these services by logging in to the server 410 with a valid user ID and password. In one embodiment, the server 410 generates a unique, personalized Web page for each user containing links to all, or a subset of, the information and/or services subscribed to by the user.
The microcontroller 505 of one embodiment is comprised of a central processing unit (“CPU”), a read only memory (“ROM”), and a scratchpad RAM. The ROM is further comprised of an interpreter module and a toolbox module.
The toolbox module of the ROM contains a set of toolbox routines for processing data, text and graphics on the wireless user terminal 500. These routines include drawing text and graphics on the wireless user terminal's display 575, decompressing data transmitted from the server 410, reproducing audio on the wireless user terminal 500, and performing various input/output and communication functions (e.g., transmitting/receiving data over the client link 460). A variety of additional wireless user terminal functions may be included within the toolbox while still complying with the underlying principles of the invention.
In one embodiment, microprograms and portal data are transmitted from the server 410 to the external memory 565 of the wireless user terminal via a communication interface under control of the microcontroller 505. Various communication interfaces may be employed without departing from the underlying principles of the invention including, for example, a Universal Serial Bus (“USB”) interface or a serial communication (“serial”) interface. The microprograms in one embodiment are comprised of compact, interpreted instructions known as “bytecodes,” which are converted into native code by the interpreter module before being executed by the microcontroller 505. One of the benefits of this configuration is that when the microcontroller portion of the wireless user terminal 500 is upgraded (e.g., to a faster and/or less expensive model), only the interpreter module and toolbox of the ROM needs to be rewritten to interpret the currently existing bytecodes for the new microcontroller 505. In addition, this configuration allows wireless user terminals 500 with different CPUs to coexist and execute the same microprograms. Moreover, programming frequently-used routines in the ROM toolbox module reduces the size of microprograms stored in the external memory 565, thereby conserving memory and bandwidth over the client link 460. In one embodiment, new interpreter modules and/or toolbox routines may be developed to execute the same microprograms on cellular phones, personal information managers (“PIMs”), or any other device with a CPU and memory.
One embodiment of the ROM may be comprised of interpreted code as well as native code written specifically for the microcontroller CPU. More particularly, some toolbox routines may be written as interpreted code (as indicated by the arrow between the toolbox and the interpreter module) to conserve memory and bandwidth for the same reasons described above with respect to microprograms. Moreover, in one embodiment, data and microprograms stored in external memory 565 may be configured to override older versions of data/microprograms stored in the ROM (e.g., in the ROM toolbox).
The wireless user terminal 500 may communicate with the server 410 (discussed above) using various RF communication techniques. In one embodiment, the RF communication is established through the communication device 580. In one embodiment, the communication device 580 includes a cellular telephone module that includes at least the radio portion of a cellular telephone that the microcontroller 505 may access for establishing a wireless link to the server 410. The communication device 580 can also include any other similar RF receiver/transmitter combination that will allow the microcontroller 505 to establish a link to the server 410 or other network server such as network server 430. For example, in one particular embodiment, the wireless user terminal 500 transmits and receives data to/from a cellular network via the cellular digital packet data (“CDPD”) standard. As it is known in the art, the CDPD standard is a digital wireless standard that is deployed as an enhancement to the existing analog cellular network. It provides a packet overlay onto the AMPS network and moves data at 19.2 Kbps over continuously-changing unused intervals in standard voice channels. Accordingly, this embodiment of the wireless user terminal is capable of exploiting normally unused bandwidth on a nation-wide, analog cellular network. Embodiments of the wireless user terminal may also be configured to transmit/receive data using a variety of other communication standards including 2-way paging standards and third generation (“3G”) wireless standards (e.g., UTMS, CDMA 2000, NTT DoCoMo, . . . etc).
As indicated in
Embodiments of the invention may include various steps as set forth above. The steps may be embodied in machine-executable instructions. The instructions can be used to cause a general-purpose or special-purpose processor to perform certain steps. Alternatively, these steps may be performed by specific hardware components that contain hardwired logic for performing the steps, or by any combination of programmed computer components and custom hardware components.
Elements of the present invention may also be provided as a machine-readable medium for storing the machine-executable instructions. The machine-readable medium may include, but is not limited to, floppy diskettes, optical disks, CD-ROMS, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, magnetic or optical cards, propagation media or other type of media/machine-readable medium suitable for storing electronic instructions. For example, the present invention may be downloaded as a computer program which may be transferred from a remote computer (e.g., a server) to a requesting computer (e.g., a client) by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., a modem or network connection).
Throughout the foregoing description, for the purposes of explanation, numerous specific details were set forth in order to provide a thorough understanding of the invention. It will be apparent, however, to one skilled in the art that the invention may be practiced without some of these specific details. For example, while the system described above employs a single server 410, alternative embodiments of the invention may include numerous different servers (e.g., database servers, web servers, etc), and/or mirrored servers distributed across a network. Accordingly, the scope and spirit of the invention should be judged in terms of the claims that follow.
It will be further appreciated that the instructions represented by the blocks in
Number | Name | Date | Kind |
---|---|---|---|
5126786 | Tanaka | Jun 1992 | A |
5159592 | Perkins | Oct 1992 | A |
5436960 | Campana, Jr. et al. | Jul 1995 | A |
5517387 | Smith | May 1996 | A |
5559800 | Mousseau et al. | Sep 1996 | A |
5594910 | Filepp et al. | Jan 1997 | A |
5625670 | Campana, Jr. et al. | Apr 1997 | A |
5631946 | Campana, Jr. et al. | May 1997 | A |
5727202 | Kucala | Mar 1998 | A |
5778176 | Geihs et al. | Jul 1998 | A |
5790974 | Tognazzini | Aug 1998 | A |
5802312 | Lazaridis et al. | Sep 1998 | A |
5819172 | Campana, Jr. et al. | Oct 1998 | A |
5915095 | Miskowiec | Jun 1999 | A |
5961590 | Mendez et al. | Oct 1999 | A |
5964830 | Durrett | Oct 1999 | A |
6023708 | Mendez et al. | Feb 2000 | A |
6035104 | Zahariev | Mar 2000 | A |
6035339 | Agraharam et al. | Mar 2000 | A |
6067451 | Campana, Jr. et al. | May 2000 | A |
6076109 | Kikinis | Jun 2000 | A |
6134539 | Alexander et al. | Oct 2000 | A |
6151643 | Cheng et al. | Nov 2000 | A |
6151677 | Walter et al. | Nov 2000 | A |
6157935 | Tran et al. | Dec 2000 | A |
6166734 | Nahi et al. | Dec 2000 | A |
6167441 | Himmel | Dec 2000 | A |
6188752 | Lesley | Feb 2001 | B1 |
6199099 | Gershman et al. | Mar 2001 | B1 |
6233318 | Picard et al. | May 2001 | B1 |
6289212 | Stein et al. | Sep 2001 | B1 |
6308201 | Pivowar et al. | Oct 2001 | B1 |
6317592 | Campana, Jr. et al. | Nov 2001 | B1 |
6324691 | Gazdik | Nov 2001 | B1 |
6330618 | Hawkins | Dec 2001 | B1 |
6370687 | Shimura | Apr 2002 | B1 |
6396482 | Griffin et al. | May 2002 | B1 |
6418310 | Dent | Jul 2002 | B1 |
6449622 | LaRue et al. | Sep 2002 | B1 |
6587462 | Mahalingaiah | Jul 2003 | B2 |
6622175 | Piller | Sep 2003 | B1 |
6728685 | Ahluwalia | Apr 2004 | B1 |
6785534 | Ung | Aug 2004 | B2 |
6847632 | Lee et al. | Jan 2005 | B1 |
6980963 | Hanzek | Dec 2005 | B1 |
7076736 | Hugh | Jul 2006 | B2 |
7136635 | Bharatia et al. | Nov 2006 | B1 |
20010056508 | Arneson et al. | Dec 2001 | A1 |
20020032768 | Voskuil | Mar 2002 | A1 |
20020083035 | Pearl et al. | Jun 2002 | A1 |
20020103935 | Fishman et al. | Aug 2002 | A1 |
20020132609 | Lewis et al. | Sep 2002 | A1 |
20020194279 | Chern | Dec 2002 | A1 |
20030032417 | Minear et al. | Feb 2003 | A1 |
20030055902 | Amir et al. | Mar 2003 | A1 |
20030081591 | Cheung et al. | May 2003 | A1 |
20030088693 | Cheung et al. | May 2003 | A1 |
20030167230 | McCarthy | Sep 2003 | A1 |
20030181242 | Lee | Sep 2003 | A1 |
20030182380 | Yabe et al. | Sep 2003 | A1 |
20040077347 | Lauber et al. | Apr 2004 | A1 |
20040082323 | Smith | Apr 2004 | A1 |
20040090950 | Lauber et al. | May 2004 | A1 |
20040199663 | Horvitz et al. | Oct 2004 | A1 |
20050144251 | Slate | Jun 2005 | A1 |
Number | Date | Country |
---|---|---|
WO 9836344 | Aug 1998 | WO |
WO 9906929 | Feb 1999 | WO |
WO 0030003 | May 2000 | WO |