This application claims the benefit of and priority to commonly owned U.S. Provisional Patent Application No. 60/793,114, filed Apr. 18, 2006; U.S. Provisional Patent Application No. 60/794,039, filed Apr. 20, 2006; U.S. Provisional Patent Application No. 60/795,436, filed Apr. 26, 2006; U.S. Provisional Patent Application No. 60/795,445, filed Apr. 26, 2006; and U.S. Provisional Patent Application No. 60/795,512, filed Apr. 26, 2006; the disclosure of each of which is hereby incorporated by reference herein.
This application is related to concurrently filed and commonly owned U.S. patent application Ser. No. 11/736,480 entitled “WAVEFORM ENCODING FOR WIRELESS APPLICATIONS,” the disclosure of which is hereby incorporated by reference herein.
1. Field
This application relates generally to wireless communication, and to offloaded processing for wireless applications.
2. Background
Various types of devices including, for example, cell phones, computers, and associated peripherals may utilize wireless communication technology to communicate with one another and with other devices. To facilitate such wireless communication, these devices perform various operations associated with the transmission and reception of data via one or more wireless communication links (e.g., a wireless network).
In a typical scenario a first device (e.g., a headset) may communicate via a wireless communication link (e.g., Bluetooth) with a second device (e.g., a cell phone) to send data to and receive data from a remotely-located device (e.g., a communication device connected to the Internet). Here, the first device may include a transducer (e.g., a microphone) or some other mechanism that generates data to be sent to the remote device. In addition, the first device performs various processing operations to facilitate transmitting the generated data to the second device via the wireless communication link. For example, the first device may convert analog generated data to digital data, attempt to improve one or more characteristics of the data, compress the data, and encode the data for transmission to the second device via the wireless communication link.
The second device may then perform various operations to facilitate transmission of the data to the remote device. For example, the second device may decode the data from the format used for the wireless communication link and then re-encode the data into an appropriate communication format for transmission over a network (e.g., a cellular network) to the intended destination.
Complementary operations may be performed for data traveling in the opposite direction. For example, upon receipt of data destined for the first device, the second device may perform various operations such as decoding data received via the network, decompressing the data as necessary, and re-encoding the data for transmission via the communication link to the first device. The first device may then perform operations such as decoding the received data and processing the decoded data, as necessary. The first device may then convert this digital data to analog data and provide the analog data to another transducer (e.g., a speaker).
From the above it may be appreciated that different devices in the communication system may have different processing requirements and, hence, different processing capabilities. In some cases, however, the processing capabilities conventionally associated with a given device may hinder or otherwise negatively affect other desirable features of the device. For example, in some applications it is desirable for a mobile device to be as small as possible and to consume as little power as possible. In practice, however, meeting these design goals may be difficult due to the processing requirements of the device.
A summary of sample aspects of the disclosure follows. It should be understood that any reference to aspects herein may refer to one or more aspects of the disclosure.
The disclosure relates in some aspects to offloading processing for a wireless communication device. For example, processing conventionally performed by a first device may, instead, be performed by a second device on behalf of the first device.
Offloaded processing may be employed to improve or otherwise alter one or more attributes of a given device or system. In some aspects offloaded processing may be employed in the event the processing may be more effectively performed by another device. For example, one class of device may have more processing capabilities, more available power, or a larger footprint than another class of device. Consequently, a class of device from which processing has been offloaded may be advantageously adapted to consume less power, have a smaller footprint, and have a less complex design.
The disclosure relates in some aspects to offloading processing that would normally be performed on one device to another device, where the devices are connected wirelessly. Here, the offloaded processing may prove beneficial (e.g., according to some metric) for the overall system, even though an additional burden may be placed on one of the devices. In some aspects offloaded processing may be utilized if the cost associated with performing the processing is higher that the cost associated with performing any transmission associated with the offloading. For example, power savings may be realized at a device even if additional power is required to send data (e.g., the data is in an uncompressed form, so more data is sent) as long as more power is saved by not having to perform the processing (e.g., data compression).
In some aspects offloaded processing may be employed to enable a first device to process data for transmission and then wirelessly send the data to another device for processing. For example, the first device may preprocess an analog data (e.g., raw analog sensed data such as an analog waveform) for transmission (e.g., in an analog or digital form) to the second device, while the second device processes the received data to improve a least one characteristic represented by the analog data. In this way, the second device may perform one or more processing operations on behalf of the first device. For example, the second device may process the received data to improve at least one characteristic such as sound or imagery, or at least one characteristic such as an indication of heart rate, temperature, pressure, velocity, or acceleration. Here, processing such as equalization, echo cancellation, active noise reduction, filter and decimate operations, side-tone generation, filter tap generation, biological processing, ambient condition processing, and voice command and recognition operations may be performed at the second device rather than at the first device.
In some implementations the first device may waveform encode the analog output of a transducer and send the resulting data via a wireless link to the second device. The second device may then process the received data on behalf of the first device. Here, the waveform encoded data may comprise digital data that represents the entire waveform (e.g., the waveform encoded data is of a form that could be converted back to an analog form to essentially reconstruct the waveform). In some implementations the waveform encoded data comprises pulse code modulated data or sigma delta modulated data. In some implementations the waveform encoded data may be preprocessed (e.g., encoded, packetized, and so on) for reliable transmission across the wireless link.
In some aspects offloaded processing may be employed whereby a first device processes data on behalf of a second device and then sends the processed data to the second device. For example, the first device may process received data and waveform encode the processed data for transmission back to the second device. The second device may then process the received waveform encoded data to provide a desired output based on the data. Here, the second device may pass the received waveform encoded data directly to an output transducer.
In some aspects offloaded processing may be implemented in a static manner or in a dynamic manner. As an example of static offloaded processing, a first device may be adapted (e.g., implemented) to not provide certain processing capabilities, while a second device may be adapted to provide those processing capabilities. In addition, provisions may be made to enable the second device to perform the corresponding processing on behalf of the first device.
As an example of dynamic offloaded processing, both a first device and a second device may be adapted to provide certain processing capabilities. In addition, the devices may be adapted to be configurable so that a dynamic selection may be made as to which of the devices is to perform a given processing operation. For example, one of the devices may send a message to the other device to indicate which of the devices is to perform a given operation or operations.
These and other features, aspects and advantages of the disclosure will be more fully understood when considered with respect to the following detailed description, appended claims and accompanying drawings, wherein:
In accordance with common practice the various features illustrated in the drawings may not be drawn to scale. Accordingly, the dimensions of the various features may be arbitrarily expanded or reduced for clarity. In addition, some of the drawings may be simplified for clarity. Thus, the drawings may not depict all of the components of a given apparatus (e.g., device) or method. Finally, like reference numerals may be used to denote like features throughout the specification and figures.
Various aspects of the disclosure are described below. It should be apparent that the teachings herein may be embodied in a wide variety of forms and that any specific structure, function, or both being disclosed herein is merely representative. Based on the teachings herein one skilled in the art should appreciate that an aspect disclosed herein may be implemented independently of any other aspects and that two or more of these aspects may be combined in various ways. For example, an apparatus may be implemented or a method may be practiced using any number of the aspects set forth herein. In addition, such an apparatus may be implemented or such a method may be practiced using other structure, functionality, or structure and functionality in addition to or other than one or more of the aspects set forth herein. For example, in some aspects a method of processing data comprises receiving data, wherein the received data comprise analog data obtained and preprocessed by another device for wireless transmission, and processing the received data to extract at least one characteristic represented by the analog data. In addition, in some aspects a method of processing data also comprises transmitting the processed data to the other device.
In some aspects the devices 102 and 104 are adapted such that the device 104 may perform processing on behalf of the wireless 102. For example, rather than performing a given processing operation at the device 102, the processing may be offloaded to the device 104. To this end, the devices 102 and 104 include one or more processor components 108 and 110, respectively, to perform operations to facilitate this offloaded processing. In addition, the devices 102 and 104 include transceivers 112 and 114, respectively, for sending data between the devices 102 and 104.
Offloaded processing may be employed in a variety of scenarios where multiple devices having different capabilities communicate with one another to support certain functionality. For example, a wireless body area network may include one or more wireless medical sensors that are distributed on a user's body. Each of these sensors may send sensed data to a central node such as a cell phone or a personal data assistant (“PDA”). Another example involves a wireless headset (e.g., an earpiece) that communicates with a cell phone, a music player, or some other device. Yet another example is a tire pressure monitor that is located in a wheel of a car where the monitor sends pressure readings back to a dashboard-mounted device via a wireless link. In these scenarios one of the devices (e.g., the sensors and headset) is generally of lower complexity and generally consumes less power than the other device (e.g., the cell phone or the dashboard-mounted device).
Typically, low complexity and low-power devices such as these generate raw data that need to be processed before being used. Examples of such processing include echo cancellation at the headset to reduce the effects of surrounding noise, equalization, data compression of a heartbeat waveform, and audio compression. In some cases, the processed data are sent to another device for ultimate use. For example, audio data generated by a headset may be compressed before it is transmitted to a remote device for playback. In other cases the processed data are ultimately used at the low complexity, low-power device. For example, active noise reduction generates modified audio data that are played back at the headset. Conventionally, the processing discussed above is performed on the low complexity, low-power device.
By offloading processing from a low power, low complexity device to a higher power, higher complexity device as taught herein, one or more advantages may be obtained in the overall system. For example, moving processing from a low power, low complexity device to a higher power, higher complexity device allows the low power, low complexity device to be of even lower power and lower complexity. Consequently, such a device, which may be sold in much greater numbers than the other device, may cost less to manufacture, may be smaller (e.g., through the use smaller batteries and less circuitry) and hence more user friendly, and may require less frequent recharges or battery replacements. In addition, economies of scale may exist when multiple devices are deployed in a network. For example, in a scenario where an audio player multicasts an audio stream to several headsets, performing the active noise cancellation on the audio player reduces the complexity and the power draw of multiple headsets while only increasing the complexity and power consumption of a single device (i.e., the audio player).
In the example of
In some aspects the device 102 includes a preprocessor 118 that may preprocess the data (e.g., the raw analog data) for transmission to the device 104. For example, the preprocessor 118 may perform waveform processing on the data. Such waveform processing may include, for example, pulse code modulation encoding or sigma delta modulation encoding. Thus, the device 102 may transmit waveform data to the device 104, as opposed to waveform data that has been further processed (e.g., compressed, as may be transmitted in a conventional system).
The preprocessor 118 also may perform operations such as, error coding, scrambling, etc, to facilitate transmitting the data. A transmitter 120 is then used to transmit the preprocessed data to a receiver 122 of the device 104.
After the device 104 receives the waveform data from the device 102, the processor 110 of the device 104 may process the waveform data on behalf of the device 102. For example, the processor 110 may process the data to improve one or more characteristics represented by the data (e.g., as discussed above).
In some aspects improving the at least one characteristic represented by the data (e.g., the raw analog waveform data) may comprise extracting (e.g., by an extractor component 124) at least one characteristic represented by the data (e.g., the raw analog data) generated by the device 102. For example, extraction may involve extracting a voice signal from the received data (representative of the raw sensed data), extracting a biological parameter (e.g., a heart beat waveform), extracting an ambient parameter (e.g., a pressure waveform), or some other similar operation. Advantageously this process may be performed in a manner that improves a characteristic represented by the data. For example, extraction may involve filtering, denoising, noise cancellation, or some other suitable technique.
In some aspects extraction may involve extracting an indication relating to the received data (representative of the raw sensed data). For example, extraction may comprise extracting an indication of a biological parameter (e.g., a heart rate value), extracting an indication of an ambient parameter (e.g., a pressure value), or some other similar indication. Again, such a process may be performed in a manner that improves a characteristic represented by the data. For example, indications of a heart rate (e.g., as derived from multiple sensors that detect a heart beat waveform) may be averaged to provide an improved ultimate heart rate value. Similar operations may be performed for other indications of a biological or ambient parameter. Improving a characteristic also may comprise improving machine readability or human readability of values represented by the analog data. For example, extracting or computing an indication of heart rate (or some other parameter) may improve the characteristic of machine readability or human readability of the analog data. Here, an indication of a heart rate (or some other parameter) may be obtained (e.g., extracted or computed) by converting pulses from a sensor to a numeric heart rate value (or some other type of value).
In conjunction with the extraction (or following the extraction) a waveform processor 136 may perform the desired waveform processing on the extracted waveform data. For example, as will be discussed in more detail below, such waveform processing may involve improving at least one characteristic of the data by performing operations such as equalization, echo cancellation, active noise cancellation, filter tap computation, side-time processing, biological-related (e.g., medical-related) processing, voice-command and recognition, and processing of ambient conditions.
The processing may thereby improve at least one attribute of a characteristic. Such an attribute may relate to, for example, frequency response, signal-to-noise ratio, or accuracy. In some aspects the extraction process may involve, for example, substantially reconstructing data representative of the waveform data (e.g., the raw data) generated by the device 102.
In some aspects, the result of the extraction process may provide data that have less degradation of the least one characteristic, as compared to the data generated by the device 102 (e.g., the analog raw data). For example, there may be less noise in the extracted data relative to the characteristic represented by the data (e.g., an audio waveform) than in the raw analog data. Similarly, the magnitude of any interference-related component in the extracted data may be less than the magnitude of such a component in the raw analog data. It should be appreciated that the processing performed here (e.g., relating to a characteristic represented by the data) may be distinguishable from processing that simply operates on the data (e.g., compressing or decompressing the data).
A characteristic represented by the data may relate to various types of data (e.g., multimedia data, biological data, and ambient data) and various aspects of that data. For example, a characteristic represented by data may comprise audio, music, voice, speech, video, a heart beat, blood pressure, body temperature, oxygen concentration levels, glucose levels, pressure, temperature, velocity, acceleration, or some other event or condition.
In addition, as mentioned above a characteristic represented by the data may comprise an indication relating to one or more of the above events and conditions. For example, an audio-related characteristic may comprise a noise level of the audio, an audio-related characteristic may comprise a pleasantness of the audio to the human ear, a heart beat-related characteristic may comprise a computed heart rate, a pressure-related characteristic may comprise a computed blood pressure value, a temperature-related characteristic may comprise a computed temperature value, an oxygen concentration-related characteristic may comprise a computed value of oxygen concentration, a glucose level-related characteristic may comprise a computed glucose level value, a temperature-related characteristic may comprise a computed temperature value, a velocity-related characteristic may comprise a computed velocity value, and an acceleration-related characteristic may comprise a computed acceleration value.
Also as discussed above, in some aspects the offloaded processing may improve at least one of the characteristics represented by the data. For example, improving an audio-related characteristic may comprise reducing noise in audio or improving pleasantness of the audio to the human ear (e.g., adding side-tones). Improving a biological related-characteristic may comprise improving a calculation (e.g., improving the accuracy of the calculation) for determining a heart rate, blood pressure, etc. Improving an ambient-related characteristic may comprise improving a calculation (e.g., improving the accuracy of the calculation) for determining pressure, velocity, etc.
In some aspects the processor 110 may process the data to facilitate transmission to the device 102 and, in some cases, to further reduce the processing required by the device 102. For example, a waveform encoder 126 may provide processed data in a waveform encoded form such as pulse code modulated data or sigma delta modulated data. This data may then be transmitted to the device 102 without any further processing (e.g., compression) other than standard transmission-related processing. Thus, the device 104 also may transmit waveform data to the device 102, as opposed to processed data representative of the waveform. As will be discussed below, in this case less processing may be performed at the device 102 since the device 102 will receive data in a form that may be readily provided to an output device.
After the data is processed, the device 104 sends the data to the appropriate destination. For example, a local area network or wide area network communication component 128 of the device 104 may send the processed data to another device via an appropriate communication link (e.g., to a wide area network such as a cellular network or to the Internet, not shown in
As discussed above, the device 104 may send the processed data back to the device 102. This may be the case, for example, in the event the device 102 is the ultimate user of the data or in the event the device 102 is better suited to forward the processed data to the ultimate destination. Here, the processor 110 may encode the data, as necessary, depending upon the transmission scheme used over the link 106 and then provide the encoded data to a transmitter 130.
A receiver 132 of the device 102 may then provide the received data to the processor 108 for communication-related processing. For example, the processor 108 may decode the received data, as necessary, depending upon the transmission scheme used over the link 106.
The processor 108 may further process the received data to provide the data in a form suitable for output via one or more output devices 132. Advantageously, in the event the wireless device 104 provided the data in a waveform encoded format, relatively minimal processing may be required here. For example, a waveform processor 134 may process received pulse code modulated data or sigma delta modulated data to generate analog data or may process pulse code modulated data to generate sigma delta modulated data that is provided to the output device 132. Moreover, in some implementations sigma delta modulated data may be provided directly to the output device 132.
To further illustrate how offloaded processing may be implemented, an example of offloaded processing will be briefly discussed in the context of an implementation where the device 104 comprises a wireless device such as a cell phone or an entertainment device (e.g., an audio player) and the device 102 comprises a headset for the wireless device. In this use case, various types of processing may be offloaded from the headset 102 to the device 104. For example, in some implementations it may be desirable to provide echo cancellation or active noise cancellation for the headset 102. Here, the input device 116 may comprise a microphone that senses ambient sound. The headset 102 may thus transmit the raw sensed ambient sound data (e.g., a waveform) to the device 104 as discussed above.
The device 104 processes the raw sensed data in conjunction with other input data to provide, for example, the desired equalization, equalizer tap weight computation, echo cancellation or active noise cancellation. In the case of an audio player, the other input data may comprise data (e.g., the audio waveforms) to be played out by the headset 102. This input data may be generated by the device 104 or may be received from another device via the communication component 128.
The device 104 transmits the processed data (e.g., equalized data, tap weights, echo cancelled data, noise cancelled data) back to the headset 102 or to some other destination. In the former scenario, the headset 102 may then provide the received processed data to a speaker 132. Here, it should be appreciated that the operations discussed above may be performed fast enough to provide effective echo cancellation, active noise cancellation, or some other type of processing.
With the above overview in mind, additional details of a system incorporating offloaded processing and associated operations will be discussed in more detail in conjunction with
Referring now to
In some aspects sensed data generated by the transducer 206 is in the form of analog data. Such analog data may represent, for example, a continuous waveform (e.g., audio data), a non-continuous waveform (e.g., a heartbeat), or information that is more discrete in nature (e.g., pressure, velocity, etc.).
As represented by block 306, the device 202 preprocesses the sensed data for transmission. As discussed above, in some implementations the preprocessing may involve waveform encoding the sensed data (e.g., the raw analog data output by the transducer 206). Here, a waveform encoder 210 may perform operations such as sigma delta modulation encoding, pulse code modulation encoding, or some others suitable form of waveform encoding. By converting the analog data to digital form, the raw waveform data may be readily transmitted over a communication link that utilizes digital transmission.
Here, it should be appreciated that the data may be sent over the communication link at a relatively high data rate. For example, rather than sending compressed data to the device 204, the data may be sent in a full pulse code modulated form or in an oversampled form (e.g., sigma delta modulated data). Thus, in contrast with conventional techniques that compress the data before sending it over a communication link (e.g., using sub-band coding in conjunction with Bluetooth, MP3, or stereo encoding) and decompress received data, less processing may be involved with the disclosed approach. For example, for transmission, a conventional technique may convert sigma delta modulated data to pulse code modulated data and may compress pulse code modulated data before transmitting the data. Conversely, the receive side may involve decompressing data to provide pulse code modulated data or converting pulse code modulated data to signal delta modulated data.
Although the disclosed approach may require more wireless bandwidth than approaches that use compression, a favorable tradeoff may be achieved particularly in applications that use a relatively high bandwidth communication channel, that are able to transmit data more efficiently, or both. This may be the case, for example, in applications that employ ultra-wideband communication (e.g., impulse-based ultra-wideband).
The use of sigma delta modulation also may facilitate more reliable transmission of data over the wireless link. For example, given that every bit in a sigma delta modulated signal is, in effect, a least significant bit, a loss of a given bit during transmission may not have a significant effect on the recovered data. In contrast, in schemes that send full pulse code modulated data (e.g., 16 bit PCM) over a link, a loss of any of the more significant bits may have a significant negative impact on the recovered data.
The device 202 also may preprocess the sensed data to facilitate reliable transmission over the communication link. For example, a transmission preprocessing component 211 may provide channel coding, error coding, scrambling, interleaving, formatting, or other similar signal processing.
As represented by blocks 308 and 310, a transmitter 212 transmits the preprocessed data via a wireless communication link to a receiver 214 of the device 204. The device 204 may then perform processing complementary to some of the preprocessing performed at block 306 to recover the waveform encoded data generated at block 306. For example, one or more processors 216 of the device 204 may perform channel decoding, error decoding, descrambling, deinterleaving, deformatting, or other similar operations.
As represented by block 312, the processor 216 of the device 204 may then process the received data on behalf of the device 202. To this end, the processor 216 may extract at least one characteristic represented by the sensed analog data. As discussed above, this may involve substantially reconstructing the original analog data from the received data (e.g., generating data representative of the original waveform, plus quantization noise). For example, the processor 216 may derive sigma delta modulated data, pulse code modulated data, or analog data that will then be further processed on behalf of the device 202.
The processing of block 312 may take various forms depend upon the requirements of a particular application. In some implementations (e.g., where the waveform data comprise audio data) an equalizer 218 may equalize the received data (e.g., to improve the frequency response of the audio waveform). Thus, in this case, the equalization components and the power consumption associated with the equalization processing may be offloaded from the device 202 to the device 204. It should be appreciated that the processing may be offloaded in various ways. As discussed below, in some implementations only a portion of the processing may be offloaded. For example, the device 202 may perform the equalization filtering while computation of tap weights may be offloaded to the device 204.
In implementations where the waveform encoding of block 210 was sigma delta encoding, a filter and decimator 220 may process the sigma delta modulation data to, for example, complete the analog-to-digital conversion process. That is, the filter and decimator 220 may generate pulse code modulation data from the sigma delta modulation data. This configuration may thus reduce the number of components and the power consumption of the device 202 by performing these operations on the device 204.
In some implementations a side-tone processing component 240 may add side-tone information to information destined for the device 202. In this case, the device 202 may send audio (e.g., voice) from a microphone to the device 204. The component 240 may then add this information (e.g., reduced by 10 dB) to audio (e.g., voice traffic) being sent to the device 202 for playback on a speaker.
In some implementations a biological processing component 242 may perform biological-related processing for the device 202. For example, the component 242 may receive sensor data (e.g., heart beat information) from the device 202 (e.g., a medical device) and process the data and, in some cases provide feedback to the device 202 or to some other device based on the sensor data. In some implementations the component 242 may detect EKG anomalies and exceptions and then cause one or both of the device 202 and 204 (or some other device) to change a mode of operation.
In some implementations a voice command and recognition component 244 may perform voice recognition-related processing for the device 202. For example, the device may send sensor data (e.g., from a microphone) to the device 204. The component 244 may then perform voice and command recognition processing on the sensor data and send the results (e.g., an index value representative of the command) back to the device 202.
As will be discussed in more detail below, the processor 216 may include other components for performing offloaded operations. These operations may relate to, for example, echo cancellation, active noise cancellation, processing of biological-related data, and processing of ambient-related data.
As represented by block 314, the device 204 may perform other processing depending upon the requirements of a given implementation. For example, in some implementations the processed data from block 312 may be transmitted to some other device. Accordingly, the processed data may be formatted as necessary (e.g., by a communication processor 222) for transmission via an appropriate communication link (not shown in
Referring now to
As represented by block 404, the processor 204 may process the received data. For example, the communication processor 222 may perform various decoding operations to recover data transmitted via a wide area network or in some other manner. In addition, as will be discussed in more detail below, the wireless device 204 may decompress the received or generated data in the event the data was previously compressed.
As represented by block 406, the processor 216 may then process the data on behalf of the device 202. Again, the processor 216 may improve at least one attribute associated with at least one characteristic represented by the data. For example, in a similar manner as discussed above, the equalizer 218 may equalize data destined for the device 202. Also, as will be discussed in more detail in conjunction with
As discussed above in conjunction with
As represented by blocks 408 and 410, a transmitter 224 of the device 204 transmits the processed data via a wireless link to a receiver 226 of the device 202. In a similar manner as discussed above, the devices 204 and 202 may perform various operations (e.g., relating to channel coding/decoding, etc.) to facilitate transmitting and receiving the data via the wireless link.
The device 202 may optionally waveform decode the received data. For example, in the event the processor 216 generated waveform encoded data, a waveform decoder 228 may perform waveform decoding operations to convert the waveform data into analog data or sigma delta modulated data.
As represented by block 412, in some implementations processing of the received waveform encoded data (e.g., sigma delta modulated data) may simply involve the receiver 226 directly passing the waveform data to an output transducer 232 (e.g., to a buffer for the transducer 232). In this case, the device 202 may not perform any non-transmission related processing of the received data. Such an implementation will be discussed in more detail below in conjunction with
In any event, as represented by block 414, data in the appropriate format are provided to the transducer 232 that outputs the data in the appropriate manner. For example, a speaker may be used to output some form of audio data.
Offloaded processing may be implemented in a variety of ways and used to support various functionality. In some implementations one or both of the devices 202 and 204 may optionally provide additional processing. In some implementations only a portion of the processing that would otherwise be performed by the device 202 may be offloaded to the device 203. In some implementations a decision as with whether to offload processing may be made in a dynamic manner.
As discussed above, in some implementations all non-transmission related processing of the sensed data may be offloaded to the wireless device 204. However, in some implementations some processing may still be performed by the device 202. Accordingly, as shown in
Also as discussed above, in some implementations all non-transmission related processing of the sensed data being sent to the device 202 may be offloaded to the wireless device 204. However, in some implementations some processing may still be performed by the peripheral device. Accordingly, as shown in
In some implementations the device 202B may perform some processing and offload other processing onto device 204B. For example, the device 202B (e.g. a headset) may have processing capabilities (e.g., provided by processor 230) relating to one or more of MP3 decompression, echo cancellation, and side-tone generation. As represented by line 246, the processor 230 may receive information for some of this processing (e.g., the side-tone generation) from the input transducer 206. In addition, the device 204B (e.g., a cell phone) may include processing capabilities to provide one or more of these operations. For example, one or more processors 216B may include an MP3 decompressor 248, a side-tone processor 250, or an echo canceller 234. Hence, depending on the requirements of a given application, the devices 202B and 204B may be configured so that the device 204B receives sensor data from the device 202B to perform one or more of the operations to be offloaded from the device 202B.
In some implementations processing may be offloaded in a dynamic manner. For example, the device 202B may detect that the device 204B has the capability to perform the same types of operations that the device 202B may perform (e.g., MP3 decompression, etc.). Consequently, the device 202B may shut down its circuits or disable its functionality and use the processing of the device 204B as long as the device 202B is communicating with the device 204B. Thus, when operating on its own, the device 202B may provide its own processing (e.g., streaming MP3 music from a FLASH dongle without MP3 decompression capability). In addition, if the charge on the battery of the device 204B drops below a critical point, the device 204B may stop providing offloaded processing (e.g., decompressing MP3 data), and may instead send unprocessed data (e.g., compressed MP3 data) to the device 202B, whereby the device 202B will perform the processing. In another use case, the device 202B (e.g., a heart rate monitor sensor) may initially send processed sensor data (e.g., a measured heart rate) to a second device that does not have offloading-related processing capabilities (e.g., the device may be a watch that simply displays the information). Then, at some other time, the device 202B may send the unprocessed sensor data (e.g., a heart beat waveform) to another device 204B (e.g., a cell phone) that does have the appropriate processing capabilities (e.g., heart rate detection).
The wireless device 204 of
In a similar manner as above, the device 502 may include a communication processor 506 that may, for example, receive data via a local area network, a wide area network, or some other communication link. The communication processor 506 may process (e.g., decode) the received data, as necessary, to extract data that are destined for the device 504.
The resulting data are provided to a data processor 508 that may process the data on behalf of the device 504. The data processor 508 may comprise a data decompressor 510 that decompresses the data in the event the data were previously compressed. In addition, the data processor 508 may comprise a processor 512 that may provide signal processing functionality such as, for example, decoding. In some aspects the signal processing also may attempt to improve at least one characteristic represented by the data as taught herein.
In some aspects the processor 512 may provide waveform processing functionality to generate waveform encoded data. For example, in a similar manner as discussed above, the processor 512 may generate pulse code modulated data, sigma delta modulated data, or some other form of waveform encoded data.
A transmitter 514 may then transmit the processed data via an appropriate communication link 516 to the device 504. As discussed above, the data may be transmitted in a substantially unprocessed form. For example, the transmitter 514 may transmit waveform encoded data that have not been compressed.
At the device 504, a receiver 518 processes the data received via the link 516 (e.g., in a similar manner as discussed above). In an implementation where the device 502 provides waveform encoded data, the receiver 518 may output the raw waveform encoded data. A waveform processor 520 may then process the received waveform encoded data, as necessary, and provide that data to an appropriate transducer 522 (e.g., a speaker).
In some aspects waveform processing may be advantageously employed to reduce the amount of processing required and the power consumed by the device 504. For example, the waveform processor 520 and the transducer 522 may comprise a general amplifier, a class-D amplifier, or a direct drive class-D amplifier. Alternatively, in some implementations signal delta data may be passed unprocessed to a general class-D amplifier. One implementation of a direct drive class-D amplifier circuit will be discussed in more detail conjunction with
Referring again to
In the example of
In some aspects the widths of the control pulses Q1 and Q2 are based on pulses of the time periods W0, W2, and W4. For example, the width of a control signal may be based on the difference between the number of high-level pulses and low-level pulses within a given time period. Thus, in the example of
The above implementation advantageously provides a class-D type output that utilizes tri-state control signals. For example, in the event the durations of successive levels of the waveform data are equal (e.g., representative of silence in an audio signal), both control signals will be off. Thus, the control signals may have a state that turns one switch on, another state that turns the other switch on, and yet another state that does not turn either of the switches on. Through the use of such a tri-state technique, the power consumption of the circuit 600 may be substantially proportional to the volume and activity level of, for example, an audio signal represented by the waveform data 602.
It should be appreciated that the control signals Q1 and Q2 may be generated based on other timing relationships. For example, in some implementations the control signals Q1 and Q2 may be generated based on the sets of pulses associated with time periods W1, W3, W5, and so on. In addition, in some applications the control signals Q1 and Q2 may be generated based on the even time windows (W0, W2, W4, etc.) and the odd time windows (W1, W3, W5, etc.), thereby doubling the number of pulses output on Q1 and Q2. Here, collisions between active Q1 and Q2 pulses may be more frequent; consequently, provisions may be made to ensure that the switches are not turned on simultaneously.
A direct drive class-D amplifier circuit or some other similar circuit that provides functionality similar to that discussed above may be implemented in a variety of ways. For example, in some implementations the controller 604 may comprise a pulse counter 614 that counts the number of pulses associated with each level of the waveform data 602. The resulting count may then be sent to a control pulse generator 616 that generates the control signals 606A and 606B as discussed above. In some implementations an up/down counter may be used to determine the difference in the number of ones and zeros in successive levels of the waveform data 602. In this case, the resulting count value may be passed to another counter that down counts to output a pulse of an appropriate width to thereby generate the control signals 606A and 606B. In some aspects the output stage (e.g., including the switches 608A and 608B and the transducer 610) may instead comprise an H-bridge including two switch pairs where each switch pair is coupled to a unique one of the two input terminals of the transducer 610.
As discussed above, in some implementations the waveform data may comprise multi-bit pulse code modulated data. In this case, the controller 604 may comprise a sigma delta modulation encoder that converts pulse code modulated data into sigma delta modulated data (e.g., the waveform data S of
The teachings herein may be employed with other types of pulse width modulation schemes. For example, the circuit 600 may be adapted to process waveform data that take more of an analog form (e.g., data that are not quantized in time). Hence, the controller 604 may be adapted to generate the control signals 606A and 606B based on the pulse width of the waveform data 602 rather than pulse counts (e.g., “1s” and “0s”).
The waveform data may represent any of various types of information. For example, the waveform data may represent audio signals, various forms of sensed signals, RF signals, or some other suitable information (e.g., as discussed above).
Referring now to
Here, the data sent to the device 204 may be used to generate data that will be sent back to the device 202. For example, in implementations that incorporate echo cancellation the data from a microphone (e.g., a headset microphone) may comprise the raw data that is sent to the device 204 for use in echo cancellation operations. Similarly, in implementations that incorporate active noise cancellation the data from another microphone (e.g., a microphone it senses ambient sound) may be sent to the device 204 to be used in active noise cancellation operations.
Blocks 810, 812, 814, and 816 of
In either case, the device 204 may process the data it receives on behalf of the device 202. In addition, the device 204 may perform other processing, as necessary, as discussed herein.
In some implementations an echo canceller 234 of the processor 216 may perform echo cancellation operations on behalf of the device 202. To this end, the echo canceller 234 may process data received from the device 202 as well as data being transmitted to the device 202 to reduce any echo components that may be present in the data.
In some implementations an active noise canceller 236 of the processor 216 may perform active noise cancellation operations on behalf of the device 202. To this end, the active noise canceller may process data to be output by a transducer (e.g., a headset speaker) of the device 202 as well as data generated by an input transducer 206 (e.g., an ambient microphone) of the device 202. In this way, the active noise canceller 236 may add a signal component to the data being sent to the device 202 that will cancel out ambient noise that may otherwise be heard by the user of the device 202.
It should be appreciated that the above are but a few examples of operations the device 204 may perform on behalf of the device 202, and that other operations may be employed in accordance with the teachings herein. After the device 204 completes the processing of the data, the device 204 may send the processed data back to the wireless device 202 via the wireless link (block 816). As discussed above, in some implementations the device 204 may send the waveform encoded data to the device 202 to enable the device 202 to efficiently output the desired data.
Blocks 818 and 822 again represent operations that may be performed by a device such as the wireless device 202. In some implementations the operations of blocks 818 and 822 may be similar to the operations of blocks 410, 412, and 414 discussed above. Thus, the device 202 may process the received data as necessary, and output the data via the output device 232.
As mentioned above, offloaded processing may be implemented in a static manner or in a dynamic manner. Here, a decision as to whether to implement or invoke offloaded processing may be based on one or more of a variety of factors. For example, processing may be offloaded to a “more capable” device that has more processing resources. Such processing resources may include a larger capacity battery, more processing capability (e.g., a faster processor), more efficient processing, and so on. In addition, processing may be offloaded (e.g., at design time) based on criteria such as a desire to keep the cost of a device as low as possible, to reduce the complexity of a device, or to reduce the size of a device (e.g., by reducing the size of the battery and the integrated circuit die). In some aspects processing may be offloaded based on defined classes of devices. For example, the classes may be associated with different processing resources, different price targets, different complexity, and difference sizes. Here, different types of processing may be offloaded to different classes of devices.
In some aspects devices may be dynamically configured, as necessary, to provide offloaded processing. Here, the dynamic offloaded processing may be invoked by operation of one or both the devices involved in the offloaded operation or by some other device. In addition, dynamic offloaded processing may be evoked based on one or more criteria including, for example, a defined class of a given device, the capabilities of a given device, the processing load of a given device, the power consumption or power reserves of a given device, or some other suitable criterion. In some aspects these criteria may be temporally based. For example, a decision as to whether and how to invoke offloaded processing may be based on prior conditions, current conditions, or future (e.g., anticipated) conditions.
As represented by block 906, once the peripheral device learns the capabilities of the wireless device, the peripheral device may send a message to the wireless device requesting that the wireless device perform one or more operations at some point in the future. In the event the wireless device agrees to do the requested processing, the wireless device may acknowledge the request from the peripheral device (block 908). Here, a message from one or both the devices may identify which particular operations are to be offloaded and how those operations may be invoked (e.g., the form of a subsequent request).
As represented by block 910, at some later point in time the peripheral device transmits data to the wireless device. As represented by block 912, the wireless device then processes the data on behalf of the peripheral device. This processing may take the form of, for example, the offloaded processing discussed above or as otherwise taught herein.
As represented by block 914, the wireless device then transmits the processed data to the appropriate recipient. As discussed above, the wireless device may transmit the processed data back to the peripheral device (block 916) or to some other device (block 918).
The teachings herein may be employed to offload processing for wide variety of operations. For example,
A peripheral device 1002 includes one or more sensors 1004 for sensing one or more conditions such as ambient conditions (e.g., temperature) or biological conditions (e.g., heart rate, temperature, blood pressure, etc.). The sensor(s) 1004 may take various forms including a chemical transducer, and electrical transducer, a mechanical transducer, a magnetic transducer, a nuclear transducer, or an optical transducer. For example, a chemical transducer may be used to acquire glucose level information from a person. An electrical transducer may be used to detect a person's heartbeat. A mechanical transducer may be used to acquire temperature, pressure, velocity, or acceleration information. An optical transducer may be used to acquire oximetry information. A nuclear transducer may be used to measure radiation types and levels. In addition, the peripheral device 1002 may be carried at an appropriate location on a person's body or located at an appropriate location (e.g., within a vehicle) to sense one or more of these conditions.
The acquired sensor data may be passed as analog or digital waveforms for processing to another wireless device. Thus, as discussed above, the device 1002 may include a waveform encoder 1006 for processing the sensed data for transmission and a transmitter 1008 for transmitting the data to another wireless device 1010.
The wireless device 1010 includes a receiver 1012, a processor 1014, and a communication processor 1016 in a similar manner as discussed above. Here, the processor 1014 may comprise one or more components for processing the sensed data on behalf of the device 1002. For example, a heart rate component 1018 may process sensed EKG data to generate an indication of the current rate of a person's heartbeat. A heart rate classifier 1020 may process the heartbeat rate information to classify the heart rate. A temperature component 1022 may process sensed temperature data (e.g., representative of ambient temperature or body temperature) to generate an indication of a measured temperature. A pressure component 1024 may process sensed pressure data (e.g., representative of a person's blood pressure, ambient pressure, tire pressure, etc.) to generate an indication of pressure. A velocity component 1026 may process sensed velocity data to generate an indication of velocity (e.g., of a person or some other moving object). An acceleration component 1028 may process sensed acceleration data to generate an indication of acceleration (e.g., of a person or some other moving object). A blood analysis component 1030 may process sensed chemical data or oximetry data to generate an indication of a person's glucose level or oxygen concentration level, respectively. The corresponding indication generated by the processor 1014 may then be sent to an appropriate device such as, for example, an output device (e.g., a display device) of the device 1010 or to another device via the communication processor 1016.
In some aspects one or more wireless sensing devices may be deployed for sensing, for example, ambient or biological conditions whereby the sensing devices communicate with one or more other wireless devices via a body area network, a personal area network, or in some other manner. For example, referring to the system 1100 of
As represented by block 1202 in
In some implementations the sensing device 1102 may simply pass the sensed data to another device for processing. As discussed herein, the sensed data may be passed as an analog waveform or as a digital waveform. Accordingly, as represented by block 1206 in some aspects the sensing device 1102 may comprise a waveform encoder 1110 (e.g., a sigma delta encoder) for processing the sensed data for transmission.
As represented by block 1208, the sensing device 1102 includes a transmitter 1112 for transmitting the data to another wireless device via a wireless communication link. As mentioned above, in some implementations the sensing device 1102 may transmit the sensed data to the wireless device 1104 in a direct manner or, as depicted in
The use of one or more intermediary devices may be advantageously employed to increase the reliability of data transmission in the system 1100. For example, data transmission in the system 1100 may be subject to interruptions in wireless connectivity between devices. In addition, different amounts of battery power may be available in various devices of the system 1100 at a given point in time. Accordingly, the system 1100 may employ the intermediary devices 1106 as relay points, for temporarily storing the sensor data for relay to another device (e.g., a wireless device) at a later time, or for offloading one or more processing operations.
Referring again to
As discussed herein, once the wireless device 1104 receives the raw or processed sensed data, the wireless device may process the data on behalf of the sensing device 1102 or some other device (e.g., the peripheral device 1106). To this end, the wireless device 1104 also includes a transceiver component 1122 for communicating with the sensing device 1102, the intermediary device 1106, or both. In addition, the wireless device 1104 includes one or more processor components 1124 for processing data and communicating with other devices (e.g., via a wide area network or some other communication link).
In some implementations the sensing device 1102 may comprise a digital signal processor or a microprocessor. Here, the sensing device also may comprise an analog-to-digital converter for converting the sensed data to a digital form.
The teachings herein may be incorporated into a device employing various components for communicating with at least one other device.
Initially, components involved in sending information from the device 1302 to the device 1304 (e.g., a reverse link) will be treated. A transmit (“TX”) data processor 1308 receives traffic data (e.g., data packets) from a data buffer 1310 or some other suitable component. The transmit data processor 1308 processes (e.g., encodes, interleaves, and symbol maps) each data packet based on a selected coding and modulation scheme, and provides data symbols. In general, a data symbol is a modulation symbol for data, and a pilot symbol is a modulation symbol for a pilot (which is known a priori). A modulator 1312 receives the data symbols, pilot symbols, and possibly signaling for the reverse link, and performs modulation (e.g., OFDM or some other suitable modulation) and/or other processing as specified by the system, and provides a stream of output chips. A transmitter (“TMTR”) 1314 processes (e.g., converts to analog, filters, amplifies, and frequency upconverts) the output chip stream and generates a modulated signal, which is then transmitted from an antenna 1316.
The modulated signals transmitted by the device 1302 (along with signals from other devices in communication with the device 1304) are received by an antenna 1318 of the device 1304. A receiver (“RCVR”) 1320 processes (e.g., conditions and digitizes) the received signal from the antenna 1318 and provides received samples. A demodulator (“DEMOD”) 1322 processes (e.g., demodulates and detects) the received samples and provides detected data symbols, which may be a noisy estimate of the data symbols transmitted to the device 1304 by the other device(s). A receive (“RX”) data processor 1324 processes (e.g., symbol demaps, deinterleaves, and decodes) the detected data symbols and provides decoded data associated with each transmitting device (e.g., device 1302).
Components involved in sending information from the device 1304 to the device 1302 (e.g., a forward link) will be now be treated. At the device 1304, traffic data are processed by a transmit (“TX”) data processor 1326 to generate data symbols. A modulator 1328 receives the data symbols, pilot symbols, and signaling for the forward link, performs modulation (e.g., OFDM or some other suitable modulation) and/or other pertinent processing, and provides an output chip stream, which is further conditioned by a transmitter (“TMTR”) 1330 and transmitted from the antenna 1318. In some implementations signaling for the forward link may include power control commands and other information (e.g., relating to a communication channel) generated by a controller 1332 for all devices (e.g. terminals) transmitting on the reverse link to the device 1304.
At the device 1302, the modulated signal transmitted by the device 1304 is received by the antenna 1316, conditioned and digitized by a receiver (“RCVR”) 1334, and processed by a demodulator (“DEMOD”) 1336 to obtain detected data symbols. A receive (“RX”) data processor 1338 processes the detected data symbols and provides decoded data for the device 1302 and the forward link signaling. A controller 1340 receives power control commands and other information to control data transmission and to control transmit power on the reverse link to the device 1304.
The controllers 1340 and 1332 direct various operations of the device 1302 and the device 1304, respectively. For example, a controller may determine an appropriate filter, reporting information about the filter, and decode information using a filter. Data memories 1342 and 1344 may store program codes and data used by the controllers 1340 and 1332, respectively.
A device as taught herein may support or otherwise use various wireless communication links and wireless network topologies. For example, in some aspects the devices 102 and 104 may comprise or form part of a body area network or a personal area network (e.g., an ultra-wideband network). In addition, in some aspects the devices 102 and 104 may comprise or form part of a local area network or a wide area network. The devices 102 and 104 also may support or otherwise use one or more of a variety of wireless communication protocols or standards including, for example, CDMA, TDMA, FDMA, OFDM, OFDMA, WiMAX, Wi-Fi, and other wireless technologies. Accordingly, the devices 102 and 104 may include appropriate components to establish one or more communication links using various wireless technologies. For example, a device may comprise a wireless transceiver (e.g., a radio) with associated transmitter and receiver components that include various components (e.g., signal generators and signal processors) that facilitate communication over a wireless medium. These components may support a variety of wireless physical layer schemes. For example, the physical layer may utilize some form of CDMA, TDMA, OFDM, OFDMA, or other modulation and multiplexing schemes.
In some aspects a device may communicate via a pulsed-based physical layer. For example, the physical layer may utilize ultra-wideband pulses that have a relatively short length (e.g., on the order of a few nanoseconds) and a relatively wide bandwidth. In some aspects an ultra-wideband system may be defined as a system having a fractional bandwidth on the order of approximately 20% or more and/or having a bandwidth on the order of approximately 500 MHz or more.
It should be appreciated that a device as taught herein may be implemented in a variety of forms. For example, the teachings herein may be incorporated into (e.g., implemented within or performed by) a variety of apparatuses (e.g., devices). For example, one or more aspects taught herein may be incorporated into a phone (e.g., a cellular phone), a personal data assistant (“PDA”), an entertainment device (e.g., a music or video device), a headset (e.g., headphones, an earpiece, etc.), a microphone, a medical device (e.g., a biometric sensor, a heart rate monitor, a pedometer, an EKG device, etc.), a user I/O device (e.g., a watch, a remote control, a light switch, a keyboard, a mouse, etc.), a tire pressure monitor, a computer, a point-of-sale device, an entertainment device, a hearing aid, a set-top box, or any other suitable device.
These devices may have different power and data requirements. In some aspects, the teachings herein may be adapted for use in low power applications (e.g., through the use of a pulse-based signaling scheme and low duty cycle modes) and may support a variety of data rates including relatively high data rates (e.g., through the use of high-bandwidth pulses).
In some aspects a device may comprises an access device (e.g., a Wi-Fi access point) for a communication system. For example, a device may provide connectivity to another network (e.g., a wide area network such as the Internet) via a wired or wireless communication link. Accordingly, a device may enable another device (e.g., a Wi-Fi station) to access the other network. In addition, it should be appreciated that one or more of the devices discussed herein may be portable or, in some cases, relatively non-portable.
A device as taught herein may include various components that perform functions based on data transmitted or received via wireless communication. For example, a headset may include a transducer adapted to provide an audible output based on data received via a receiver or a wireless communication link. In addition, a headset may include a transducer (e.g., a microphone) adapted to generate sensed data to be preprocessed for wireless communication. A watch may include a display adapted to provide a visual output based on data received via a receiver or a wireless communication link. A watch also may include a transducer adapted to generate sensed data (e.g., relating to a biological condition) to be preprocessed for wireless communication. A medical device may include a sensor adapted to generate sensed data to be transmitted via a transmitter or a wireless communication link. In addition, a medical device may include a transducer adapted to generate an output (e.g., a warning signal) based on data received via a receiver or a wireless communication link.
The functional components described or taught herein may be implemented using various structures. Referring to
As shown in
The apparatus 1404A also includes one or more modules 1422A, 1424A, 1432, 1434, 1436, 1438, 1440, and 1442 that may perform one or more of the functions described above with regard to various figures. For example, an ASIC for transmitting 1422A may provide various functionality relating to transmitting data to another device as taught herein and may correspond to, for example, component 130 discussed above. An ASIC for receiving 1424A may provide various functionality relating to receiving data from another device as taught herein and may correspond to, for example, component 122 discussed above. An ASIC for waveform encoding 1432 may provide various functionality relating to generating waveform data as taught herein and may correspond to, for example, component 512 discussed above. An ASIC for processing 1434 may perform one or more processing operations as taught herein and may correspond to, for example, component 216 discussed above. An ASIC for equalizing 1436 may perform one or more equalization operations as taught herein and may correspond to, for example, component 218 discussed above. An ASIC for echo canceling 1438 may perform one or more echo cancellation operations as taught herein and may correspond to, for example, component 234 discussed above. An ASIC for active noise canceling 1440 may perform one or more active noise cancellation operations as taught herein and may correspond to, for example, component 236 discussed above. An ASIC for filtering and decimating 1442 may perform one or more filter and decimate operations as taught herein and may correspond to, for example, component to 220 discussed above. An ASIC for side-tone generation 1444 may provide various functionality relating to generating side-tones as taught herein and may correspond to, for example, component 240 discussed above. An ASIC for filter tap generation 1446 may provide various functionality relating to generating filter taps as taught herein and may correspond to, for example, component 238 discussed above. An ASIC for biological processing 1448 may provide various functionality relating to biological (e.g., medical) processing as taught herein and may correspond to, for example, component 242 and/or 1014 discussed above. An ASIC for voice command and recognition 1450 may provide various functionality relating to recognizing voice and commands as taught herein and may correspond to, for example, component 244 discussed above.
As shown in
The apparatus 1404A also includes one or more modules 1422B, 1424B, 1426, 1428, and 1430 that may perform one or more of the functions described above with regard to various figures. For example, an ASIC for transmitting 1422B may provide various functionality relating to transmitting data to another device as taught herein and may correspond to, for example, component 130 discussed above. An ASIC for receiving 1424B may provide various functionality relating to receiving data from another device as taught herein and may correspond to, for example, component 122 discussed above. An ASIC for generating 1426 may perform one or more operations relating to generating waveform data as taught herein and may correspond to, for example, component 508 discussed above. An ASIC for decompressing 1428 may perform one or more operations relating to decompressing data as taught herein and may correspond to, for example, component 510 discussed above. An ASIC for processing received data 1430 may perform one or more processing operations as taught herein and may correspond to, for example, component 512 discussed above.
As noted above, in some aspects these components may be implemented via appropriate processor components. These processor components may in some aspects be implemented, at least in part, using structure as taught herein. In some aspects a processor may be adapted to implement a portion or all of the functionality of one or more of these components. In some aspects one or more of the components represented by dashed boxes are optional.
In some aspects the apparatus 1402 and the apparatus 1404 may comprise one or more integrated circuits that provide the functionality of the components illustrated in
In addition, the components and functions represented by
Those of skill in the art would understand that information and signals (e.g., referred to herein as data) may be represented using any of a variety of different technologies and techniques. For example, analog data, digital data, instructions, commands, information, signals, bits, symbols, and chips that may be referenced throughout the above description may be represented by voltages, currents, electromagnetic waves, magnetic fields or particles, optical fields or particles, or any combination thereof.
Those of skill would further appreciate that any of the various illustrative logical blocks, modules, processors, means, circuits, and algorithm steps described in connection with the aspects disclosed herein may be implemented as electronic hardware (e.g., a digital implementation, an analog implementation, or a combination of the two, which may be designed using source coding or some other technique), various forms of program or design code incorporating instructions (which may be referred to herein, for convenience, as “software” or a “software module”), or combinations of both. To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, modules, circuits, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present disclosure.
The various illustrative logical blocks, modules, and circuits described in connection with the aspects disclosed herein may be implemented within or performed by an integrated circuit (“IC”), an access terminal, or an access point. The IC may comprise a general purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, electrical components, optical components, mechanical components, or any combination thereof designed to perform the functions described herein, and may execute codes or instructions that reside within the IC, outside of the IC, or both. A general purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
It is understood that any specific order or hierarchy of steps in any disclosed process is an example of a sample approach. Based upon design preferences, it is understood that the specific order or hierarchy of steps in the processes may be rearranged while remaining within the scope of the present disclosure. The accompanying method claims present elements of the various steps in a sample order, and are not meant to be limited to the specific order or hierarchy presented.
The steps of a method or algorithm described in connection with the aspects disclosed herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. A software module (e.g., including executable instructions and related data) and other data may reside in a data memory such as RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, a hard disk, a removable disk, a CD-ROM, or any other form of computer-readable storage medium known in the art. A sample storage medium may be coupled to a machine such as, for example, a computer/processor (which may be referred to herein, for convenience, as a “processor”) such the processor can read information (e.g., code) from and write information to the storage medium. A sample storage medium may be integral to the processor. The processor and the storage medium may reside in an ASIC. The ASIC may reside in user equipment. In the alternative, the processor and the storage medium may reside as discrete components in user equipment. Moreover, in some aspects any suitable computer-program product may comprise a computer-readable medium comprising codes (e.g., executable by at least one computer) relating to one or more of the aspects of the disclosure. In some aspects a computer program product may comprise packaging materials.
The previous description of the disclosed aspects is provided to enable any person skilled in the art to make or use the present disclosure. Various modifications to these aspects will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other aspects without departing from the scope of the disclosure. Thus, the present disclosure is not intended to be limited to the aspects shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
Number | Name | Date | Kind |
---|---|---|---|
4796004 | Rich et al. | Jan 1989 | A |
5196825 | Young | Mar 1993 | A |
5225842 | Brown et al. | Jul 1993 | A |
5298904 | Olich | Mar 1994 | A |
5406284 | Lin et al. | Apr 1995 | A |
5479522 | Lindemann et al. | Dec 1995 | A |
5617058 | Adrian et al. | Apr 1997 | A |
5687169 | Fullerton | Nov 1997 | A |
5742772 | Sreenan | Apr 1998 | A |
5764696 | Barnes et al. | Jun 1998 | A |
5812081 | Fullerton | Sep 1998 | A |
5832035 | Fullerton | Nov 1998 | A |
5907427 | Scalora et al. | May 1999 | A |
5933582 | Yamada | Aug 1999 | A |
5952956 | Fullerton | Sep 1999 | A |
5956681 | Yamakita | Sep 1999 | A |
5956683 | Jacbos et al. | Sep 1999 | A |
5960031 | Fullerton et al. | Sep 1999 | A |
5963581 | Fullerton et al. | Oct 1999 | A |
5969663 | Fullerton et al. | Oct 1999 | A |
5995534 | Fullerton et al. | Nov 1999 | A |
6028853 | Haartsen | Feb 2000 | A |
6031862 | Fullerton et al. | Feb 2000 | A |
6091374 | Barnes | Jul 2000 | A |
6111536 | Richards et al. | Aug 2000 | A |
6111538 | Schuchman et al. | Aug 2000 | A |
6133876 | Fullerton et al. | Oct 2000 | A |
6141705 | Anand et al. | Oct 2000 | A |
6177903 | Fullerton et al. | Jan 2001 | B1 |
6178323 | Nagata | Jan 2001 | B1 |
6218979 | Barnes et al. | Apr 2001 | B1 |
6295019 | Richards et al. | Sep 2001 | B1 |
6297737 | Irvin | Oct 2001 | B1 |
6297773 | Fullerton et al. | Oct 2001 | B1 |
6300903 | Richards et al. | Oct 2001 | B1 |
6304623 | Richards et al. | Oct 2001 | B1 |
6351652 | Finn et al. | Feb 2002 | B1 |
6354946 | Finn | Mar 2002 | B1 |
6370599 | Anand et al. | Apr 2002 | B1 |
6400307 | Fullerton et al. | Jun 2002 | B2 |
6400329 | Barnes | Jun 2002 | B1 |
6421389 | Jett et al. | Jul 2002 | B1 |
6430208 | Fullerton et al. | Aug 2002 | B1 |
6437756 | Schantz | Aug 2002 | B1 |
6462701 | Finn | Oct 2002 | B1 |
6466125 | Richards et al. | Oct 2002 | B1 |
6469628 | Richards et al. | Oct 2002 | B1 |
6483461 | Matheney et al. | Nov 2002 | B1 |
6489893 | Fullerton et al. | Dec 2002 | B1 |
6492904 | Richards | Dec 2002 | B2 |
6492906 | Richards et al. | Dec 2002 | B1 |
6501393 | Richards et al. | Dec 2002 | B1 |
6504483 | Richards et al. | Jan 2003 | B1 |
6512455 | Finn et al. | Jan 2003 | B2 |
6512488 | Schantz | Jan 2003 | B2 |
6515588 | Sarabia | Feb 2003 | B1 |
6519464 | Santhoff et al. | Feb 2003 | B1 |
6529568 | Richards et al. | Mar 2003 | B1 |
6538615 | Schantz | Mar 2003 | B1 |
6539213 | Richards et al. | Mar 2003 | B1 |
6549567 | Fullerton | Apr 2003 | B1 |
6552677 | Barnes et al. | Apr 2003 | B2 |
6556621 | Richards et al. | Apr 2003 | B1 |
6560463 | Santhoff | May 2003 | B1 |
6571089 | Richards et al. | May 2003 | B1 |
6573857 | Fullerton et al. | Jun 2003 | B2 |
6577691 | Richards et al. | Jun 2003 | B2 |
6585597 | Finn | Jul 2003 | B2 |
6593886 | Schantz | Jul 2003 | B2 |
6594628 | Jacobs et al. | Jul 2003 | B1 |
6606051 | Fullerton et al. | Aug 2003 | B1 |
6611234 | Fullerton et al. | Aug 2003 | B2 |
6614384 | Hall et al. | Sep 2003 | B2 |
6621462 | Barnes | Sep 2003 | B2 |
6636566 | Roberts et al. | Oct 2003 | B1 |
6636567 | Roberts et al. | Oct 2003 | B1 |
6636573 | Richards et al. | Oct 2003 | B2 |
6642903 | Schantz | Nov 2003 | B2 |
6661342 | Hall et al. | Dec 2003 | B2 |
6667724 | Barnes et al. | Dec 2003 | B2 |
6670909 | Kim | Dec 2003 | B2 |
6671310 | Richards et al. | Dec 2003 | B1 |
6674396 | Richards et al. | Jan 2004 | B2 |
6677796 | Brethour et al. | Jan 2004 | B2 |
6693571 | Melanson et al. | Feb 2004 | B2 |
6700538 | Richards | Mar 2004 | B1 |
6710736 | Fullerton et al. | Mar 2004 | B2 |
6717992 | Cowie et al. | Apr 2004 | B2 |
6748040 | Johnson et al. | Jun 2004 | B1 |
6750757 | Gabig, Jr. et al. | Jun 2004 | B1 |
6759948 | Grisham et al. | Jul 2004 | B2 |
6760387 | Langford et al. | Jul 2004 | B2 |
6762678 | Arens | Jul 2004 | B2 |
6762712 | Kim | Jul 2004 | B2 |
6763057 | Fullerton et al. | Jul 2004 | B1 |
6763282 | Glenn et al. | Jul 2004 | B2 |
6774846 | Fullerton et al. | Aug 2004 | B2 |
6774859 | Schantz et al. | Aug 2004 | B2 |
6778603 | Fullerton et al. | Aug 2004 | B1 |
6781530 | Moore | Aug 2004 | B2 |
6782048 | Santhoff | Aug 2004 | B2 |
6788730 | Richards et al. | Sep 2004 | B1 |
6822604 | Hall et al. | Nov 2004 | B2 |
6823022 | Fullerton et al. | Nov 2004 | B1 |
6831508 | Shima | Dec 2004 | B2 |
6836223 | Moore | Dec 2004 | B2 |
6836226 | Moore | Dec 2004 | B2 |
6845253 | Schantz | Jan 2005 | B1 |
6847675 | Fullerton et al. | Jan 2005 | B2 |
6868073 | Carrender | Mar 2005 | B1 |
6879878 | Glenn et al. | Apr 2005 | B2 |
6882301 | Fullerton | Apr 2005 | B2 |
6895034 | Nunally et al. | May 2005 | B2 |
6898414 | Ekl et al. | May 2005 | B2 |
6900732 | Richards | May 2005 | B2 |
6906625 | Taylor et al. | Jun 2005 | B1 |
6907244 | Santhoff et al. | Jun 2005 | B2 |
6912240 | Kumar et al. | Jun 2005 | B2 |
6914949 | Richards et al. | Jul 2005 | B2 |
6917284 | Grisham et al. | Jul 2005 | B2 |
6919838 | Santhoff | Jul 2005 | B2 |
6922166 | Richards et al. | Jul 2005 | B2 |
6922177 | Barnes et al. | Jul 2005 | B2 |
6924700 | Taura et al. | Aug 2005 | B2 |
6925109 | Richards et al. | Aug 2005 | B2 |
6933882 | Fullerton | Aug 2005 | B2 |
6937639 | Pendergrass et al. | Aug 2005 | B2 |
6937663 | Jett et al. | Aug 2005 | B2 |
6937667 | Fullerton et al. | Aug 2005 | B1 |
6937674 | Santhoff et al. | Aug 2005 | B2 |
6947492 | Santhoff et al. | Sep 2005 | B2 |
6950485 | Richards et al. | Sep 2005 | B2 |
6954480 | Richards et al. | Oct 2005 | B2 |
6959031 | Haynes et al. | Oct 2005 | B2 |
6959032 | Richards et al. | Oct 2005 | B1 |
6963727 | Shreve | Nov 2005 | B2 |
6980613 | Krivokapic | Dec 2005 | B2 |
6989751 | Richards | Jan 2006 | B2 |
7015793 | Gabig, Jr. et al. | Mar 2006 | B2 |
7020224 | Krivokapic | Mar 2006 | B2 |
7020701 | Gelvin | Mar 2006 | B1 |
7027425 | Fullerton et al. | Apr 2006 | B1 |
7027483 | Santhoff et al. | Apr 2006 | B2 |
7027493 | Richards | Apr 2006 | B2 |
7030806 | Fullerton | Apr 2006 | B2 |
7034609 | Risbo et al. | Apr 2006 | B2 |
7042417 | Santhoff et al. | May 2006 | B2 |
7046187 | Fullerton et al. | May 2006 | B2 |
7046618 | Santhoff et al. | May 2006 | B2 |
7057456 | Taura et al. | Jun 2006 | B2 |
7069111 | Glenn et al. | Jun 2006 | B2 |
7075476 | Kim | Jul 2006 | B2 |
7079827 | Richards et al. | Jul 2006 | B2 |
7099367 | Richards et al. | Aug 2006 | B2 |
7099368 | Santhoff et al. | Aug 2006 | B2 |
7129886 | Hall et al. | Oct 2006 | B2 |
7132975 | Fullerton et al. | Nov 2006 | B2 |
7145954 | Pendergrass et al. | Dec 2006 | B1 |
7148791 | Grisham et al. | Dec 2006 | B2 |
7151490 | Richards | Dec 2006 | B2 |
7167525 | Santhoff et al. | Jan 2007 | B2 |
7170408 | Taylor et al. | Jan 2007 | B2 |
7184938 | Lansford et al. | Feb 2007 | B1 |
7190722 | Lakkis et al. | Mar 2007 | B2 |
7190729 | Siwiak | Mar 2007 | B2 |
7206334 | Siwiak | Apr 2007 | B2 |
7206423 | Feng et al. | Apr 2007 | B1 |
7209724 | Richards et al. | Apr 2007 | B2 |
7230980 | Langford et al. | Jun 2007 | B2 |
7239277 | Fullerton et al. | Jul 2007 | B2 |
RE39759 | Fullerton | Aug 2007 | E |
7256727 | Fullerton et al. | Aug 2007 | B2 |
7271779 | Hertel | Sep 2007 | B2 |
7279965 | Hansen et al. | Oct 2007 | B2 |
7286009 | Andersen et al. | Oct 2007 | B2 |
7324479 | Hur | Jan 2008 | B2 |
7348840 | Magrath et al. | Mar 2008 | B2 |
7388886 | Perkins et al. | Jun 2008 | B2 |
7576605 | Lee et al. | Aug 2009 | B2 |
20010049471 | Suzuki et al. | Dec 2001 | A1 |
20020100061 | Tsusaka et al. | Jul 2002 | A1 |
20020109501 | Schroeder | Aug 2002 | A1 |
20030002698 | Ludvigsen | Jan 2003 | A1 |
20030078065 | Hoagland et al. | Apr 2003 | A1 |
20030125090 | Zeira | Jul 2003 | A1 |
20030227984 | Batra et al. | Dec 2003 | A1 |
20040001588 | Hairston | Jan 2004 | A1 |
20040032363 | Schantz et al. | Feb 2004 | A1 |
20040062325 | England et al. | Apr 2004 | A1 |
20040128382 | Shimoda et al. | Jul 2004 | A1 |
20040164902 | Karlsson et al. | Aug 2004 | A1 |
20040202339 | O'Brien et al. | Oct 2004 | A1 |
20040203797 | Burr | Oct 2004 | A1 |
20040207465 | Nilsson | Oct 2004 | A1 |
20040242250 | Sasai et al. | Dec 2004 | A1 |
20040247023 | Sasai et al. | Dec 2004 | A1 |
20040259449 | Onder de Linden et al. | Dec 2004 | A1 |
20050025117 | Inagaki et al. | Feb 2005 | A1 |
20050107104 | Rajkotia | May 2005 | A1 |
20050113157 | Jaakola | May 2005 | A1 |
20060016452 | Goetz et al. | Jan 2006 | A1 |
20060026288 | Acharya et al. | Feb 2006 | A1 |
20060028272 | Ozawa et al. | Feb 2006 | A1 |
20060089138 | Smith et al. | Apr 2006 | A1 |
20060146751 | Obuchi et al. | Jul 2006 | A1 |
20060166663 | Haehnichen et al. | Jul 2006 | A1 |
20060208794 | Morishima | Sep 2006 | A1 |
20060281476 | Lane et al. | Dec 2006 | A1 |
20070054643 | Kraegeloh et al. | Mar 2007 | A1 |
20070073944 | Gormley | Mar 2007 | A1 |
20070254728 | Moallemi et al. | Nov 2007 | A1 |
20070279237 | Julian et al. | Dec 2007 | A1 |
20070281721 | Lee et al. | Dec 2007 | A1 |
20080009275 | Werner et al. | Jan 2008 | A1 |
20080045161 | Lee et al. | Feb 2008 | A1 |
20080279167 | Cardei et al. | Nov 2008 | A1 |
Number | Date | Country |
---|---|---|
1647458 | Jul 2005 | CN |
1722785 | Jan 2006 | CN |
1723677 | Jan 2006 | CN |
851403 | Jul 1998 | EP |
1469594 | Oct 2004 | EP |
2388279 | Nov 2003 | GB |
5180925 | Jul 1993 | JP |
10190880 | Jul 1998 | JP |
11146030 | May 1999 | JP |
2001169345 | Jun 2001 | JP |
2001344352 | Dec 2001 | JP |
2002517855 | Jun 2002 | JP |
2002290944 | Oct 2002 | JP |
2003087863 | Mar 2003 | JP |
2003202976 | Jul 2003 | JP |
2004029182 | Jan 2004 | JP |
2004096453 | Mar 2004 | JP |
2004507714 | Mar 2004 | JP |
2004357281 | Dec 2004 | JP |
2005005962 | Jan 2005 | JP |
2005020350 | Jan 2005 | JP |
2005099018 | Apr 2005 | JP |
2005128965 | May 2005 | JP |
2005202873 | Jul 2005 | JP |
2005295380 | Oct 2005 | JP |
2006054800 | Feb 2006 | JP |
2006054815 | Feb 2006 | JP |
2008503011 | Jan 2008 | JP |
20030008999 | Jan 2003 | KR |
200307141 | Dec 2003 | TW |
I247131 | Jan 2006 | TW |
9964952 | Dec 1999 | WO |
WO0187014 | Nov 2001 | WO |
WO0194974 | Dec 2001 | WO |
WO2004053655 | Jun 2004 | WO |
WO2005083461 | Sep 2005 | WO |
WO2005121959 | Dec 2005 | WO |
2006028547 | Mar 2006 | WO |
Entry |
---|
Chiasserini, C.F. et al., “On the concept of 1-17 distributed digital signal processing in wireless sensor networks,” Military Communications Conference. Milcom 2002, Anaheim, CA, vol. 1, Oct. 7, 2002, pp. 260-264. |
Galton, Ian “Delta-Sigma Data Conversion in Wireless Transceivers,” IEEE Transactions on Microwave Theory and Techniques, IEEE Service Center, Piscataway, NJ, US, vol. 50, No. 1, Jan. 1, 2002, pp. 302-315. |
European Search Report—EP08021227, Search Authority—Munich, Jan. 29, 2009. |
Z. Shi, “Sigma-Delta ADS and DAC for Digital Wireless Communication.” 1999 IEEE Radio Frequency Integrated Circuits Symposium, pp. 57-62. |
I. Galton, “Delta-Sigma Data Conversion in Wireless Transceivers.” IEEE Transactions on Microwave Theory and Techniques, vol. 50, No. 1, Jan. 2002, pp. 302-315. |
Istephanian et al, “Guest Editorial Introduction to the Special Section on M-Health: Beyond Seamless Mobility and Global Wireless Health-Care Connectivity” IEEE Transactions on Information Technology in Biomedicine, IEEE Service Center, Los Alamitos, CA, US. vol. 8 No. 4, Dec. 2004 p. 405-414, XP011122717 ISSN: 1089-771 the whole document. |
Jones at al, “Modelling Mobile Health Systems: An Application of Augmented MDA for the Extended Healthcare Enterprise” EDOC Enterprise Computing Conference, 2005 Ninth IEEE International Enschede, The Netherlands, Sep. 19-23, 2005, Piscataway, NJ, USA, IEEE p. 58-69; p. 60-66. |
ISR-PCT-US07-121477—Oct. 25, 2007. |
ISR-PCT-07-121476—Oct. 25, 2007. |
European Search Report—EP10153190, Search Authority—Munich, European Search Authority—Mar. 11, 2010. |
Gulden P., et al., “Wireless local positioning” IEEE Microwave Magazine IEEE Service Center Piscataway NJ, USA, vol. 4 (4), Dec. 2003, pp. 77-86, XP011107180. |
Kredo K. et al., “Medium Access Control in Wireless Sensor Networks,” Computer Networks, Dec. 28, 2006, pp. 961-994, vol. 51, No. 4, Elsevier Science Publishers BV Amsterdam, NL. |
Magrath, A. J. et al.: “Hybrid Pulse Width Modulation/Sigma Delta Modulation Power Digital-to-Analogue Converter,” IEEE Proceedings: Circuits Devices and Systems, Institution of Electrial Engineers, Stenvenage, GB, vol. 143, No. 3, Jun. 10, 1996, pp. 149-156. |
Roboticsbased obstacleavoidance systems for the blind and visually impaired Navbelt and the guidecane, XP011095797, Mar. 2003. |
Sekine M. et al., “An Energy-Effidient Protocol for Active/Sleep Schedule Synchronization in Wireless Sensor Networks,” IEEE 2006 Asia-Pacific Conference on Communications, Aug. 2006, pp. 1-5. |
Sundararaman B. et al., “Clock Synchronization for Wireless Sensor Networks: a Survey,” Ad Hoc Networks, Elsevier, May 2005, pp. 281-323, vol. 3, No. 3, University of Illinois, Chicago, IL, USA. |
Taiwanese Search report—096113704—TIPO—Jan. 9, 2011. |
Taiwanese Search report—096114067—TIPO—Nov. 20, 2010. |
Taiwanese Search report—096115093—TIPO—Oct. 11, 2010. |
Vasudevan S. et al., “Design and Analysis of a Leader Election Algorithm for Mobile Ad Hoc Networks,” Network Protocols, 2004, ICNP 2004, Proceedings of the 12th IEEE International Conference on Berlin, Germany, Oct. 5, 2004, pp. 350-360. |
Written Opinion—PCT/US07/066887—International Search Authority, European Patent Office—Apr. 10, 2007. |
Xu et al: “Distributed computing paradigms for collaborative signal and information processing in sensor networks” Aug. 1, 2004, Journal of Parallel and Distributed Computing, pp. 945-959, XP004525538. |
Taiwan Search Report—TW096113668—TIPO—Mar. 16, 2011. |
Written Opinion—PCT/US07/066887—International Search Authority, European Patent Office—Oct. 25, 2007. |
International Preliminary Report on Patentability—PCT/US07/066887—International Search Authority, European Patent Office—Jul. 22, 2008. |
Number | Date | Country | |
---|---|---|---|
20080043824 A1 | Feb 2008 | US |