Embodiments of the invention relate to the field of data security, and more particularly, to enabling trust based data scanning and capture.
There are many elements that contribute to, or detract from, trust in the digital world. As people store more personal documents and data on the Internet, trust becomes more important.
Trust in data and systems is multifaceted. It is not just security that is important. Authentication, traceability, accessibility, and privacy all play an important part. Furthermore, the human characteristics of credibility, consistency, competence, confidence, and character play as important a role online as they do in human interaction and trust.
There are many known data trust algorithms. Symmetric key encryption algorithms, such as the Advanced Encryption System (AES) approved by the National Institute of Standards and Technology (NIST), use the same key to both encrypt and decrypt data. Asymmetric key encryption, such as the Pretty Good Privacy (PGP) owned by Symantec™, uses a different key for encryption and decryption.
The quality of security and authentication provided by these encryption algorithms is more a function of key management and system design than the quality of the encryption algorithms themselves. For example, the basis of Public/Private key encryption is that asymmetric encryption keys are distributed in such a way that one is held strictly confidential (private) and the other is given to a receiving party and is possibly freely available (public).
Another common algorithm is a hash function, e.g. MD-5, SHA1, SHA256, etc. Hash functions have the property that when processing any block of data, regardless of the size of that data, a unique (or statistically unique) fixed-length number is returned. The same block of data will return the same number; however, a block of data with even one bit of different data will return a very different hash value. This is the hash signature of the data. Note that the block of data is not determinable given just the returned hash value—the hash function creates a one way index value.
These tools are the basis of many network security functions such as assuring transfer data integrity (TCP/IP), password protection, digital signatures, and secure network protocols (e.g., HTTPS, SSL).
Trust and security, like a chain, are only as strong as the weakest link. While a network secures individual data packet transfers, the source and destination computing systems are another matter. Many data collection systems such as document scanners, magnetic card readers, barcode readers, signature pads, are directly connected to a computer, or other device, and do not incorporate any security technology. Instead, the reliance is on the connected computer for security. Given the number of security attacks on computing systems such as the Windows™ operating system from Microsoft Corporation, such reliance does not ensure data security.
Thus, there is no direct security offered by the data collection systems. No authentication derives from these devices, the use of these devices as components in a multi-factor authentication system are lost, and data tracking, the chain of custody (provenance), and proof of data integrity do not start with these devices.
The embodiments discussed herein combine data security, source authentication, and data tracking systems at a source of data capture, such as at an image scanner, barcode reader, radio frequency identification (RFID) scanner, magnetic card reader, etc. By performing encryption at the source of the data capture, the provenance and trust in the data is improved.
Furthermore, the embodiments discussed herein simultaneously enable data security, by ensuring that transferred data can only be seen by the intended recipient, source authentication, by ensuring transferred data is only sent by a specific device, data integrity, by ensuring transferred data is correct and complete, and data tracking, by providing a record as to where transferred data has been.
In one embodiment, encryption and hashing functions are performed on a data capture device, rather than on a computing or network device to which the data capture device is connected. In one embodiment, complementary decryption and hashing functions are performed at various known intermediate computing devices or network nodes, as well as at a destination device, such as a web-based service provider.
In one embodiment, for security, encryption is performed at a data capture device using a destination device's, such as a web-based service provider's, public encryption key. This public key is available to the capture device and may also be available to other devices. The private key is used for decryption and is available only to the destination device. Therefore, only the destination device can decode the encrypted data. The capture device can be certain of security, that is, only the destination device will have access to the data.
In one embodiment, for authentication, encryption is performed at a data capture device using the data capture device's private encryption key. This private key is available only to the capture device. The public key is used for decryption and is available to the destination device and may also be available to other devices. Therefore, the data can only originate at the data capture device. The destination device can be certain of authentication.
In one embodiment, for data integrity and tracking, hashes are performed on data captured by a capture device before and/or after each encryption. In one embodiment, these hashes are stored on the data capture device, and are transmitted along with the data to enable verification that data is unaltered and complete. In one embodiment, these hashes are incorporated in a log of activity that may include other entries. These entries and logs themselves are hashed and those values placed in the log. This entangles the log in such a way that it is self-validating.
These building blocks are used in the embodiments discussed herein in various ways to achieve different effects. For example, in some embodiments, the security enabling encryption is performed before the authentication enabling encryption, which enables devices and proxy nodes in the network with access to the authentication public key to perform authentication without access to the securely encrypted data. In other embodiments, the authentication enabling encryption is performed before the security enabling encryption to prevent exactly this intermediate authentication allowing only the destination device (or a device with access to both the security and authentication decryption keys) to authenticate the source of the data.
In some embodiments, the data is encrypted using a symmetric key produced or available at the data capture device. Furthermore, in some embodiments, the security and authentication enabling public/private encryptions are performed on the symmetric key itself, rather than the entire data stream. This achieves the same levels of security and authentication while incurring less CPU, time, and memory costs when performing the more complex asymmetric algorithms multiple times on the entirety of the data.
In some embodiments, the hash function creates unique index values of the unencrypted data (and possibly versions of the data as it is multiply encrypted) that are transmitted along with captured data. In some embodiments, these unique index values are sent in an unencrypted form to allow nodes of the network to record the passing of the data and check for data integrity. Other embodiments incorporate these unique index values in the encrypted data so that only allowed nodes in the network, which have access to corresponding decryption keys, can decrypt the hash value(s) and record the passing of data.
In some embodiments, the data capture device stores the unique index values in a log on the data capture device. With appropriate queries, including secure and authenticated requests, the log responds with the relevant index data in a provable and verifiable form. Thus, the data capture device becomes the provable provenance of the data.
The present invention will be understood more fully from the detailed description given below and from the accompanying drawings of various embodiments of the invention, which, however, should not be taken to limit the invention to the specific embodiments, but are for explanation and understanding only.
In the following description, numerous details are set forth. It will be apparent, however, to one of ordinary skill in the art having the benefit of this disclosure, that the present invention may be practiced without these specific details. In some instances, well-known structures and devices are shown in block diagram form, rather than in detail, in order to avoid obscuring the present invention.
Some portions of the detailed description that follow are presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. An algorithm is here, and generally, conceived to be a self-consistent sequence of steps leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like.
It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussion, it is appreciated that throughout the description, discussions utilizing terms such as “capturing”, “encrypting”, “decrypting”, “transmitting”, “receiving”, “processing”, “adding”, “hashing”, “indexing”, “verifying data integrity”, “recording”, “logging”, “requesting”, or the like, refer to the actions and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (e.g., electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.
The present invention also relates to an apparatus for performing the operations herein. This apparatus may be specially constructed for the required purposes, or it may comprise a general purpose computer selectively activated or reconfigured by a computer program stored in the computer. Such a computer program may be stored in a computer readable storage medium, such as, but not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, and magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, or any type of media suitable for storing electronic instructions. The computer program may be delivered over a network for execution on the computer's main operating system, or on a virtual machine operating system, or inside a browser-like program or browser-plugin.
The algorithms and displays presented herein are not inherently related to any particular computer or other apparatus. Various general purpose systems may be used with programs in accordance with the teachings herein, or it may prove convenient to construct a more specialized apparatus to perform the required method steps. The required structure for a variety of these systems will appear from the description below. In addition, the present invention is not described with reference to any particular programming language. It will be appreciated that a variety of programming languages and other tools may be used to implement the teachings of the invention as described herein.
In one embodiment, the network 102 could be one or more specific web services that the encrypted data is routed to. In one embodiment, this web service can authenticate the data and its destination. In one embodiment, the web service can decrypt the data and send it using secondary security methods (e.g. a repetition of the techniques discussed herein, or more traditional HTTPS or SSL protocols) to the service provider 101.
In one embodiment, data capture device 110 is a device for collecting data, such as an image scanner, barcode reader, radio frequency identification (RFID) scanner, magnetic card reader, physical sensor (temperature, humidity, light, etc.), location sensor, security state sensor, video sensor, etc.
In one embodiment, data capture device 110 is coupled with intermediate computing device/network node 130 via a wired or wireless connection, while intermediate computing device/network node 130 is coupled with service provider 101 via network and/or web services 102. In one embodiment, network 102 communicates using standard protocols for the exchange of information. In one embodiment, service provider 101 and intermediate computing device/network node 130 is coupled with network 102 via a wireless connection, such as a cellular telephone connection, wireless fidelity (WiFi, e.g. IEEE 802.11a-n) connection, etc. The service provider 101 and intermediate computing device/network node 130 runs on one Local Area Network (LAN) and is incorporated into the same physical or logical system, or different physical or logical systems. Alternatively, the service provider 101 and intermediate computing device/network node 130 resides on different LANs, wide area networks, cellular telephone networks, etc. that is coupled together via the Internet but separated by firewalls, routers, and/or other network devices. It should be noted that various other network configurations can be used including, for example, hosted configurations, distributed configurations, centralized configurations, etc. For example, in one embodiment, data capture device 110 is coupled directly 140 with the network 102 via a wired or wireless connection and with service provider 101.
In one embodiment, data capture device 110 has a device private encryption key used to authenticate the data capture device 110 as the device from which the data was captured. The data capture device 110 encrypts captured data with the device private encryption key and transfers the encrypted data to a receiving device, such as service provider 101 via the network 102. That receiving device decrypts the data with the capture device's public encryption key. If successful, i.e. if the data is not corrupted, the receiving device can be certain that the data capture device 110, and only the data capture device 110, could have transmitted the data. To enable the receiving device to determine which public key to use to authenticate the data, an identifier of the data capture device 110 (such as a GUID, or Mac Address, or Serial Number) is sent in the clear along with the encrypted data.
In one embodiment web services in the network 102 can authenticate the data's source as the device 110. In one embodiment, this authentication is recorded in the web service's log (not shown). In one embodiment, data capture device 110 also performs encryption on data to be transferred to service provider 101, with the service provider's public encryption key service for security purposes. In one embodiment, by encrypting the captured data with the public encryption key of the service provider's 101, only the service provider (i.e., owner of the complementary private encryption key) is able to decrypt the transferred data.
In one embodiment, data capture device 110 includes additional data before or after encryption, such as the service provider's universal resource locator (URL), an instruction set detailing the processing and disposition of the data, hash values computed from original and/or encrypted data, etc. This data accompanies data transmitted to service provider 101 to enable processing, tracking, etc. of the transmitted captured data. In one embodiment, data capture device 110 generates symmetric encryption keys to encrypt captured data.
Using these services and data, the data capture device 110 sends captured data (e.g., image data, magnetic card data, RFID data, etc.), which forms the basis of a query, data transfer, or data upload, to a service provider 101. In one embodiment, service provider 101 decrypts the encrypted data and performs one or more processes, such as storing captured data, logging captured data, performing one or more actions with the capture data, etc. In one embodiment, service provider 101 transforms, deposits, or act as a proxy for the data transmitted by image capture device. In one embodiment, service provider 101 accesses additional remote services or acts as a service proxy for data capture device 110.
In one embodiment, data captured, encrypted, and transmitted by data capture device 110 is transmitted to service provider 101 via one or more computing devices, such as intermediate computing device/network node 130. In one embodiment, the intermediate computing device/network node 130 is a tablet, personal computer, mobile phone, etc. In one embodiment, intermediate computing device/network node 130 acts as an intermediate computing network node, between data capture device 110 and service provider 101, through which data may pass.
In one embodiment, service provider 101 also transmits encrypted data to data capture device 110. In one embodiment, the transmission of data from service provider 101 to data capture device forms the basis of a download or query response. The encryption, transfer, and decryption of data from the service provider 101 to the data capture device 110 functions in a similar fashion, as discussed in the figures below, except that the transfer of data occurs in the opposite direction.
Again, an intermediate computing device/network node 130, such as a tablet, personal computer, mobile phone, etc., acts as intermediate computing network node to pass through the query or download from service provider 101 to data capture device 110. In one embodiment, data capture device 110 includes a device private encryption key for security, a services public decryption key for authentication, and performs hashing and logging functions, as discussed herein.
In one embodiment, data capture device 210 includes a data capture engine 212, such as an image scanner, RFID scanner, barcode reader, magnetic card reader, etc. In one embodiment, the captured data may be stored in data storage 216, such as a memory, a database, etc. In order to enable trust in the transfer for the captured data beyond the confines of data capture device 210, data security engine 214 performs one or more encryption processes on the captured data. For example, data security engine creates symmetric encryption keys, access symmetric encryption keys stored in storage 216, access and encrypt data with the data capture device's 210 private encryption key, access and encrypt data with service provider's 201 public encryption key, etc. The different encryptions, and order of encryptions, performed by data security engine 214 are discussed below in
In one embodiment, data security engine 214 optionally attaches data to the captured data before or after encryption, such as hash values, device identifiers, service provider identifiers, instructions to be used to process the captured data, etc. In one embodiment, the additional data is used by service provider 201 to track captured data, ensure data integrity, or process the captured data.
In one embodiment, data capture device 210 transmits the encrypted form of the captured data to service provider 201 via communications interface 218. As discussed above, the transmission may occur via one or more intermediate computing device or network nodes (not shown), such as tablet computers, personal computer, server computer systems, routers, etc.
In one embodiment, service provider 201 receives the encrypted form of the captured data at communications interface 252. In one embodiment, communications interface 252 stores the received data in data storage 256, or passes the received data to service security engine 254. In one embodiment, service security engine 254 performs one or more decryption processes, complementary to those performed by data security engine 214 at data capture device 210, to decrypt the transferred data. In one embodiment, service security engine 254 further extracts any additional data, such as hash values, instructions, device identifiers, etc. from the decrypted data. In one embodiment, service security engine 254 utilizes the hash values to authenticate the integrity of data, use identifiers to log data transfers, transactions, etc., or use instructions to process the received data.
In one embodiment, service security engine 254 stores the decrypted data and extracted data in data storage 256. In one embodiment, service security engine 254 further provides the decrypted data, and any instructions, to service processor 258. In one embodiment, service processor 258 processes the received data, such as processing a financial transaction, logging data, performing a query based on the received data, etc. In one embodiment, service processor 258 may further act as a proxy to another computing device to processes the received data.
In one embodiment, service provider 201 may transfer encrypted data to data capture device 210 in a manner similar to that discussed herein.
These embodiments employ a symmetric key, or key pair, to encrypt and decrypt the data and public/private key pairs to encrypt and decrypt the symmetric key itself and any associated data and metadata.
Referring to
Processing logic creates or accesses a symmetric cryptography key (processing block 304). In one embodiment, the symmetric key is a symmetric key, or key pair, stored by processing logic, which was previously generated by a data capture device, a service provider, or another device. In another embodiment, processing logic utilizes a key generator to create the symmetric cryptography key, or key pair. Processing logic then encrypts the captured data with the symmetric key (processing block 306).
In one embodiment, processing logic then encrypts the symmetric key with a private encryption key of the data capture device (processing block 308), and appends or prepends a service provider's ID or URL to the encrypted key (processing block 310). Thereafter, processing logic optionally appends or prepends additional data, such as a hash index to the encrypted key (processing block 312). In one embodiment, the hash index may be subsequently used to verify integrity of transferred data, or log the passing of the transferred data.
In one embodiment, processing logic encrypts the key data with a service provider's public encryption key (processing block 314). Next, processing logic appends or prepends the capture device's ID (e.g., a serial number, a GUID, a MAC address, etc.) to the key (processing block 316) and appends or prepends a data set to the key data (processing block 318). Finally, processing logic transmits the data and header to the service provider (processing block 320).
Referring to
Referring to
In one embodiment, processing logic encrypts the symmetric key with a service provider's public encryption key (processing block 408). Processing logic also appends or prepends a service provider's ID or URL to the encrypted key (processing block 410). Thereafter, processing logic optionally appends or prepends additional data (e.g., a hash index value) to the key (processing block 412).
In one embodiment, processing logic encrypts the key data, along with the additional data, with a private encryption key of the data capture device (processing block 414). Processing logic then appends or prepends a device ID (e.g., serial number, GUID, MAC) to the key (processing block 416) and appends or prepends a data set to the key data (processing block 418). Finally, processing logic transmits the data and header to the web service (processing block 420).
Referring to
Referring to
In one embodiment, processing logic then appends or prepends a service provider's ID or URL to the key (processing block 512). Finally, processing logic transmits the data and header to the service provider (processing block 514).
Referring to
Referring to
In one embodiment, processing logic optionally appends or prepends the service provider's ID or URL to the encrypted data (processing block 606). In one embodiment, processing logic further optionally appends or prepends additional data (e.g., a hash index) (processing block 608) to the encrypted data.
Processing logic then encrypts the entire data set with a private encryption key of the data capture device (processing block 610) and appends or prepends the data capture device's ID (e.g., the data capture device's serial number, GUID, MAC, etc.) to the encrypted data set (processing block 612). Processing logic appends or prepends the service provider's ID or URL to the encrypted data set (processing block 614), and transmits the data to the service provider (processing block 616).
Referring to
In other embodiments, a symmetric key is used to encrypt and decrypt the data for authentication only. The symmetric key is then encrypted with the authentication public/private key pair. Security is provided by encrypting the entire data file with the security public encryption key either before or after authentication.
In other embodiments, a symmetric key is used to encrypt and decrypt the data for security only. The symmetric key is then encrypted with the security public/private key pair. Authentication is provided by encrypting the entire data file with the authentication private encryption key either before or after authentication.
The figures and discussion above enable several forms of trust for the transfer and processing of data. In the embodiments discussed above, the several forms of trust are enabled through the use of a series of encryptions performed on data and/or different encryption keys. The trust afforded by the techniques discussed herein enable one or more of security (i.e., only a destination device can decode encrypted data), authentication (i.e., only a specific data capture device could possibly have transmitted data to a destination device), and integrity and tracking (i.e., hash values computed from data enable verification and tracking of the data).
Below are embodiments of application and deployment scenarios that benefit from the encryption and trust enablement techniques discussed herein.
In one exemplary embodiment, the techniques discussed herein are beneficial to financial transactions, which demand a high level of security. In this exemplary embodiment, a magnetic card reader/writer and image scanner act as the data capture device, and the service provider acts as the only and final security destination and authenticator. Although the examples below discusses a financial application, the same embodiment can be used for health care transactions of both financial and medical data.
In the embodiments discussed herein, a data capture device, such as the data capture device 110 discussed above, may scan check images, which are transferred and processed by a bank service provider server. As another embodiment, a data capture device may scan fingerprint images, which are transmitted, logged, and stored at a repository of such images. As yet another embodiment, a data capture device may scan the magnetic strip on a credit, debit, or cash card, and transmit the card information to a merchant and/or bank for processing. The embodiments discussed herein are suitable for the capture, and transfer, of numerous forms of digital data.
In one embodiment, remote deposit capture may be carried out with a data capture device, such as an image scanner and/or a magnetic card reader. The data capture device may be coupled with a computer, tablet, or smart phone for interacting with a website to perform the remote deposit capture. When the encryption techniques, as discussed above, are deployed in the image scanner and/or magnetic card reader, a user, transaction, data capture, etc. may be securely and reliably transferred and authenticated. Furthermore, the authentication enables trust for subsequent financial transactions (e.g., withdrawal or deposit of funds on a cash card, depositing a check, charging a credit card, scanning a barcode, reading an RFID chip, etc.).
In one embodiment, the read/write device 730 performs authentication and altering funds amounts on credit cards, bank accounts, etc. In some embodiments, the authentication and altering of funds may occur in a single transaction, or multiple transactions. In one embodiment, the altering of funds may include either adding funds or subtracting funds. For example, a cash card, such as a pre-paid card branded with Visa™, MasterCard™, etc., may have money added to it by an end-user with the system of
In one embodiment, smart device 710 access website 740 via network 702. In one embodiment, the website 740 is a service provider that provides various financial services (e.g., banking, merchant, shopping, retail, etc.). Service provider website 740, however, could provide other services, such as data storage, search, security, etc. In one embodiment, the website 740 may prompt a user to swipe a card at magnetic card read/write device 730. Furthermore, card read/write device 730 may visually indicate, such as by activating a green light, when card read/write device 730 is ready to scan a card. The magnetic card read/write device 730 reads the ID and/or values from the card, in response to the card being swiped by a user, and communicates the ID and/or values to the website 740 via the smart device 710.
In one embodiment, the website 740 may request authentication, such as entry of a PIN number, login information, biometric identification scans, etc. entered by a user at image scanner 720 or another peripheral device (not shown).
In one embodiment, the card ID and/or values, as well as the authentication data, may be transferred to website 740 by the magnetic card reader 730 using one of the processes discussed above in
In one embodiment, the URL and/or login information for a user, website 740, bank server 750-i, etc. is contained on a card that the read/write device 730 reads. In some embodiments, the scanning of the card at read/write device 730 initiates the interaction with website 740. Furthermore, although value is commonly considered monetary, the value being added or subtracted to a card, account, ticket, etc. may be some type of point or other non-monetary system, such as a customer loyalty clubs (e.g., American Airlines Frequent Flyer Miles™).
As discussed above, in alternate embodiments, the magnetic card reader can be replaced by other types of identification readers, e.g. RFID, barcode, biometric, document scanner, etc., or the smart device can be replaced with a reader that is directly connected (wired or wireless) to the network application. Furthermore, as illustrated in
Enabling a magnetic card, such as a credit card, cash card, or ATM card to be scanned, and then transactions processed, provides a user experience that is as essentially the same as a commercial automated teller machine interaction. However, utilizing the encryption and data transfer techniques discussed above, enables secure data handling, visual feedback, and a simple interface that may mimic an ATM. Furthermore, by leveraging existing computer device hardware (e.g., a smartphone coupled with a magnetic card reader, a scanner coupled with a personal computer, etc.), there is minimal hardware or software setup and equipment expense.
In one embodiment, the data capture device 820 is an image scanner coupled with smart device 810. In one embodiment, user interface 870 allows the Agent to select how the document will be handled (i.e. the instruction set). The data is captured, processed and sent via the Network 802 using the secure transfer techniques discussed above in
The data processing system illustrated in
The system may further be coupled to a display device 970, such as a cathode ray tube (CRT) or a liquid crystal display (LCD) coupled to bus 915 through bus 965 for displaying information to a computer user. An alphanumeric input device 975, including alphanumeric and other keys, may also be coupled to bus 915 through bus 965 for communicating information and command selections to processor 910. An additional user input device is cursor control device 980, such as a mouse, a trackball, stylus, or cursor direction keys coupled to bus 915 through bus 965 for communicating direction information and command selections to processor 910, and for controlling cursor movement on display device 970.
Another device, which may optionally be coupled to computer system 900, is a communication device 990 for accessing other nodes of a distributed system via a network. The communication device 990 may include any of a number of commercially available networking peripheral devices such as those used for coupling to an Ethernet, token ring, Internet, or wide area network. The communication device 990 may further be a null-modem connection, or any other mechanism that provides connectivity between the computer system 900 and the outside world. Note that any or all of the components of this system illustrated in
It will be appreciated by those of ordinary skill in the art that any configuration of the system may be used for various purposes according to the particular implementation. The control logic or software implementing the present invention can be stored in main memory 950, mass storage device 925, or other storage medium locally or remotely accessible to processor 910.
It will be apparent to those of ordinary skill in the art that the system, method, and process described herein can be implemented as software stored in main memory 950 or read only memory 920 and executed by processor 910. This control logic or software may also be resident on an article of manufacture comprising a computer readable medium having computer readable program code embodied therein and being readable by the mass storage device 925 and for causing the processor 910 to operate in accordance with the methods and teachings herein.
The present invention may also be embodied in a handheld or portable device containing a subset of the computer hardware components described above. For example, the handheld device may be configured to contain only the bus 915, the processor 910, and memory 950 and/or 925. The handheld device may also be configured to include a set of buttons or input signaling components with which a user may select from a set of available options. The handheld device may also be configured to include an output apparatus such as a liquid crystal display (LCD) or display element matrix for displaying information to a user of the handheld device. Conventional methods may be used to implement such a handheld device. The implementation of the present invention for such a device would be apparent to one of ordinary skill in the art given the disclosure of the present invention as provided herein.
The present invention may also be embodied in a special purpose appliance including a subset of the computer hardware components described above. For example, the appliance may include a processor 910, a data storage device 925, a bus 915, and memory 950, and only rudimentary communications mechanisms, such as a small touch-screen that permits the user to communicate in a basic manner with the device. In general, the more special-purpose the device is, the fewer of the elements need be present for the device to function.
It is to be understood that the above description is intended to be illustrative, and not restrictive. Many other embodiments will be apparent to those of skill in the art upon reading and understanding the above description. The scope of the invention should, therefore, be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled.
The foregoing description, for purpose of explanation, has been described with reference to specific embodiments. However, the illustrative discussions above are not intended to be exhaustive or to limit the invention to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications, to thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as may be suited to the particular use contemplated.
This application claims the benefit of U.S. Provisional Patent Application No. 61/641,735, filed May 2, 2012, and U.S. Provisional Patent Application No. 61/560,193 filed Nov. 15, 2011, and incorporates both applications in their entirety by reference.
Number | Date | Country | |
---|---|---|---|
61641735 | May 2012 | US | |
61560193 | Nov 2011 | US |