Patent application title: Method for Reducing the Power Consumption of a Mobile Device
Mel Pullen (Jersey, GB)
IPC8 Class: AH04B138FI
Class name: Radiotelephone equipment detail power supply power conservation
Publication date: 2010-01-21
Patent application number: 20100016035
Patent application title: Method for Reducing the Power Consumption of a Mobile Device
Saul Ewing LLP (Philadelphia)
Origin: HARRISBURG, PA US
IPC8 Class: AH04B138FI
Patent application number: 20100016035
Where a communications device maintains multiple wireless connections to
other devices and networks which use slotted communications protocols,
the slots used by those protocols are arranged so as to minimize the
power consumed by the device. Where multiple radios are used, power is
minimized by avoiding using radios at the same time when those radios are
likely to interfere with each other. Slots used by communication
protocols can also be selected to maximize the time that the
communications device can spend in low power mode.
1. A method of minimizing the power consumption of a communications device
maintaining multiple wireless connections to other devices and networks,
the method comprising simultaneously coordinating the arrangement of the
slotted communications protocols used by each of the said wireless
2. A method according to claim 1 in which the device contains one or more radios used for the purpose of maintaining separate wireless connections to other devices and networks.
3. A method according to claim 1 in which the device contains one or more radios which can be shared by more than one wireless connection to other devices and networks.
4. A method according to claim 1 in which any one or more of the said radios are software defined radios.
5. A method according to claim 1 in which the slotted protocols are arranged in such as way as to ensure that those radios which do not interfere with each other share the same time slots.
6. A method according to claim 1 in which the slotted protocols are arranged in such a way as to ensure that those radios which do interfere with each other do not share the same time slots.
7. A method according to claim 1 in which the slotted protocols are arranged in such a way as to ensure that adjacent time slots are used wherever possible.
8. A method according to claim 1 in which any one or more of the radios are turned off and powered down when not in use.
9. A method according to claim 1 in which not all slots available to the communications protocols are used.
10. A method according to claim 1 in which each radio is provided with an API which can be used both to control its operation and provide information relating to its use.
11. A method according to claim 1 in which the communications device is provided with a single component thata. can obtain or be provided with information relating to the power constraints to which the device is subject together with other items of information which may constrain its operation including but not limited to quality of service and costs; andb. can obtain or be provided with information relating both to the communications networks and/or devices to which the device wishes to remain connected and to the protocols used to communicate with those networks and/or devices; andc. is enabled to evaluate the above information and decide on an selection of slots to be used by the protocols in use which is optimized for the constraints to which the device is subject.
12. A method according to claim 1 in which the communications device is enabled to define the slots used by any or all of the communications protocols in use.
13. A method according to claim 1 in which the communications device is a mobile telephone or other device used to access cellular telephone networks.
14. A method according to claim 13 in which the communications device maintains multiple accounts on cellular telephone networks and in which each account requires a separate wireless connection.
15. A computing device arranged to operate in accordance with the methods as claimed in claim 1.
16. An operating system for causing a computing device to operate in accordance with the methods as claimed in claim 1.
The present invention relates to a method for reducing the power
consumption of a mobile device and in particular, to a method for
improving power management of any device that operates with wireless
communications which uses multiple radios and/or services multiple
It has long been known that the use of slotted protocols improves the efficiency of networked communications using a shared communication medium. The principle was first established at the University of Hawaii in the development of the slotted Aloha protocol used in the first ever wireless computer network (see "Excess capacity of a slotted aloha channel" by Norman Abramson, ARPANET Satellite System Note 26 12735, Stanford Research Institute, November 1972) and was incorporated from there into many subsequent network protocols.
The basis of the slotted protocol is that all transmissions over the shared medium used for network communications are required to consist of packets that must be completely transmitted during a series of fixed time slots, with the slot scheduling determined by means of timers synchronized between all participating entities. This method is twice as efficient as non-slotted protocols, which allow transmission over the shared medium to commence at any time. This is because slotting halves the probability of two or more entities trying to use the network at the same time, which results in packet collision and subsequent retransmission.
Such protocols are widely used in modern wireless communications, as shown the attached figures. FIG. 1 shows the GSM protocol; FIG. 2 shows the UMTS protocol; FIG. 3 shows the Bluetooth protocol, while FIGS. 4 and 5 show versions of the 802.11 protocol. Finally, FIG. 6 shows the DECT protocol used in modern digital cordless telephony.
Recent developments in wireless communications have additionally made use of the fact that slotted protocols can be used to implement power saving strategies. These can be used by all modern computing devices which include the capability of acting as a mobile terminal (MT) when connected to wireless communications networks. Such device include, without being limited to, desktop and laptop computers, Personal Digital Assistants (PDAs), mobile telephones, smartphones, set-top boxes and games consoles, together with converged devices incorporating the functionality of one or more of the classes of device already mentioned, as well as many other industrial and domestic electronic appliances such as digital cameras and digital music players.
Power-saving strategies are especially important for battery operated mobile terminals, for which power is a scarce resource and power saving is a key design and usability constraint. The requirements of wireless communication protocols are typically one of the major drains on the batteries of such devices. The considerations involved are well stated by Chen, Sivalingam and Agrawal "Mobile computers typically have limited energy for computing and communications because of the short battery lifetimes. Conserving battery energy in mobiles should be a crucial consideration in designing protocols for mobile computing. This issue should be considered through all layers of the protocol stack, including the application layer." from Performance comparison of battery power consumption in wireless multiple access protocols, in Wireless Networks 5 (1999) pp 445-460)
It should however be noted that while there is apparently greater utility in implementing power-saving strategies on battery-operated mobile devices, there are considerable benefits to be gained by saving power even on devices that utilize mains electricity, for where such electricity is generated from non-renewable or fossil sources, it is known to contributed to greenhouse gases and global warming. A small saving in one device, when agglomerated over all the applicable devices, can result in a substantial global saving.
Possibly, the simplest such power-saving strategy that can be utilized with a slotted protocol can be implemented at the device level and allows devices to turn off the radios used for wireless communications during time slots when it is known that no communications will occur. "One possible way to reduce receiver power-on time is to broadcast a data transmission schedule for each mobile. This will enable a mobile to switch to standby mode until its allotted slots." from Chen et al, op. cit. "Letting nodes sleep is the most effective way to conserve energy in a wireless network . . . a periodic beacon . . . provides a coarse-level synchronization and denotes the start of a superframe. A superframe has two parts: a reservation window, during which potential senders announce transmission requests, and a data transmission window, during which the actual packet transmissions take place. Receivers can then sleep for most of the second part, except for the periods when announced transmissions occur." from `Tradeoff Analysis of PHY-aware MAC in Low-Rate, Low-Power UWB networks` Alaeddine El Fawal, Jean-Yves Le Boudec, Ruben Mers, Bosidar Radunovic, Jorg Widmer, and Gian Mario Maggio, EPFL Technical Report IC/2005/032
One instance of designing protocols especially for mobile computing can be found in "A Short Look on Power Saving Mechanisms in the Wireless LAN Standard IEEE 802.11", in J. M. Holtsmann and M. Sorsi, editors, Advances in Wireless Communications, pp. 219-226, Kluwer, April 1998. This describes how devices may turn off their radios between time slots when using 802.11 Wireless Ethernet (WiFi) protocols. Similar techniques are used in Bluetooth communications, which operates in the same frequency bands as 802.11.
A general account of a number of techniques for reducing the power consumption networked computing devices can be found in a 1997 presentation for the Center for Embedded Computer Systems at the University of California by Rajesh K. Gupta `Power Management Considerations for Networked Devices` (ICCAD 1997 TUTORIAL Part II: Basics of Wireless Communication Systems`); this can be found online at http://www.ics.uci.edu/˜rgupta/talks/vlsi02/vlsi02-power.ppt.
The measures referred to above deal with how a device can save power when utilizing a single wireless connection. However, there is no prior art that addresses the problems of maximizing power savings when a device is making use of multiple wireless connections. The perception behind this invention is that maximizing the power savings on each individual wireless connection does not necessarily maximize the power savings for the device as a whole.
This can be seen most clearly in the hypothetical case of a wireless computing device which is maintaining two wireless connections, W1 and W2 over two separate radios with two separate protocol stacks. It is a fact that activity on such devices tends to occur in bursts; most of the time they are in some type of low power mode, only waking up at intervals (determined by the slots allocated by the relevant protocols) to see if there is any need to communicate. Let us further assume that there are ten possible time slots, T1 to T10 available to such a device. There are two scenarios that can be considered: 1. The first scenario is where W1 and W2 do not interfere with each other, and are both able to function at the same time. If this is the case, there are power savings to be made by having both connections share the same time slot, as the computing device would then only need to come out of low power mode for a single slot. Were W1 and W2 to be using different time slots, the power consumption would effectively be doubled as the device would need to come out of low power mode for two time slots. 2. The second scenario, which more realistically applies to modern computing devices, is where W1 and W2 do interfere with each other; attempting to use radio receivers and transmitters simultaneously in mobile devices when they are separated by only a few millimetres is extremely likely to be unsuccessful for this reason. If this is the case, there are power savings to be made by ensuring that both connections do not share the same time slot, as the computing device would then have come out of low power mode and activated both radios only to have each of their communications fail due to interference. Where W1 and W2 cannot share the same timeslot, it is additionally possible that even more power savings could be made by making use of adjacent time slots such as T3 and T4 rather than separated slots such as T2 and T7; this is because in the former case the device would only need to come out of low power mode once, while in the latter case the substantial overheads of entering and leaving low power mode would be incurred twice.
Thus it can be seen that it is not possible to optimize power usage in a computing device operating multiple radios by considering each connection in isolation; optimization can only be arrived at by taking all the connections together.
It should be noted that where there are more that two radios, some of which can share the same timeslots and some of which cannot share the same timeslots, both of the above scenarios may operate simultaneously.
A common example of a computing device which maintains multiple wireless connections would be a mobile telephone with connections to a cellular network, to an 802.11 wi-fi network and also to Bluetooth. It is expected that many other additional wireless connections will become available to such computing devices in the future, such as telephones that are able to maintain multiple simultaneous cellular connections (such as two or more GSM services or a mixture of GSM and CDMA services). Currently, simultaneous multiple accounts are not managed well by mobile telephones, and typically require two separate devices.
In summary, the problems in power optimization posed by computing devices with multiple wireless standards have not hitherto been dealt with.
Though there has been some innovation in the area of devices with multiple wireless connections from Broadcom Corporation, their InConcert® technology is aimed at maximizing throughput when using 802.11 and Bluetooth networks, which use the same frequencies; it should be noted that this is a different problem which requires a different solution, and is not related to power reduction nor with managing multiple accounts.
According to a first aspect of the present invention there is provided a method of minimizing the power consumption of a communications device maintaining multiple wireless connections to other devices and networks, the method comprising simultaneously coordinating the arrangement of the slotted communications protocols used by each of the said wireless connections.
According to a second aspect of the present invention there is provided a communications device arranged to operate in accordance with a method of the first aspect.
According to a third aspect of the present invention there is provided an operating system for causing a communications device to operate in accordance with a method of the first aspect.
Embodiments of the present invention will now be described, by way of further example only, with reference to the accompanying drawings, in which
FIGS. 1 to 6 show various communications protocols;
FIGS. 7 and 8 show radio repetition rates;,and
FIG. 9 shows how data for each radio type is organized as a hierarchy in accordance with an embodiment of the present invention.
An ideal situation would be for wireless communication protocols to allow mobile terminals to negotiate with other elements in the network infrastructure in order to define the slots that they will listen on. However, the allocation of slots in existing protocols is either pre-defined or, where variation is allowed, this is normally done outside the control of the mobile terminal; for example, this is part of the functionality provided in the Base Station Controller/Base Transceiver Station in 3GPP cellular networks. In the absence of any framework for influencing slot allocation, a mobile terminal has to select the best match from the various options available.
In normal use, where multiple radios are known to interfere with each other, this will quite possibly involve dropping some paging slots if there is a clash. It should be noted that there is no reason why this cannot be done. For all slotted protocols, there is some degree of flexibility and redundancy in the usage of the slots allocated, and for a mobile terminal to miss a transmission in one or more slots is not critical.
Therefore, provided it is possible to control the available radio interfaces, a computing device implementing multiple slotted protocols can arrange to do so in a way that optimizes power usage.
The current generation of computing devices enabled for wireless communications (such as cellular, WiFi and Bluetooth) generally rely on dedicated hardware to handle the radio related aspects of their operation. Typically, these consist either of specific chipsets or else of customized Application Specific Integrated Circuits (ASICs) for each radio interface. These handle the modulation and demodulation of signals together with much of the lower levels of the communications protocols associated with the communication. The implementation of the protocols in dedicated hardware is predetermined by the manufacturer and does not offer the flexibility needed to adjust the parameters of the communications protocols in use to take advantage of this invention.
Therefore a preferred implementation of this invention makes use of computing devices with one or more generic Software Defined Radios rather than dedicated hardware. A Software Defined Radio (SDR) is one that handles all the modulation and demodulation of wireless signals in software rather than relying on any dedicated hardware circuitry; it is anticipated that in the future, computing devices will be able to utilize wireless communications methods by means of SDR which would otherwise only be accessible if a suitable dedicated radio ASIC had been included in the device at manufacture time. The Software Defined Radio Forum (http://www.sdrforum.org/) exists to promote and develop this technology.
It should be noted that while SDR technology lends itself to the implementation of this invention, the description and claims contained herein are not intended to preclude any implementations that are based on more flexible dedicated hardware solutions.
The basic elements of a system implementing this invention are as follows: The computing device is provided with a respective applications programming interface (API) for each radio. The API supplies information and methods relating to the controlling of its power usage, together with information and methods which define and control its receipt of paging requests from other wireless devices. An example API is provided below. The computing device is additionally provided with a single software, component that is aware both of the power constraints to which the device is subject and also of the communication networks and services to which the user wishes to remain connected. This information may be provided by the user either directly or indirectly (via a link to overall settings such as user profiles) or may be arrived at programmatically, using inbuilt rules. This software component can also be provided with other items of information which may affect the operation of the device. Although the aim is to reduce the total power consumption, manipulating the standard workings of a communication protocol can affect other aspects of performance, such as Quality of Service (QoS). As an example, a computing device that polls the airwaves for signals ten times per second is going to be able to provide a quicker response than a computing device that polls for signals once every second. The ability of the invention to take account of additional information relating to issues such as QoS, which vary depending on the circumstances and needs of the user, is considered to be one of the advantages of this invention. The various slotted communication protocols can then be evaluated to decide on an optimal selection of paging slots for which the radios on the device will be woken up; the APIs provided for each radio are used to implement the consequent strategy.
A preferred implementation of this invention on a computing device which itself implements low-power mode may be to pre-process all the available data in order to ensure that no radio interferes with any other radio, and that the time spent in sleep or idle mode was as long as possible.
Note that if the device is maintaining wireless connections to multiple accounts on services such as cellular networks, the single software component referred to above will need to ensure that the relevant identities on the appropriate networks have all been registered before setting up exclusive slots to monitor each account.
Furthermore, `interleaving` the power on times of the various radios will be essential when software defined radio is used (either single converter or multiple IF selection), as there is effectively a single piece of hardware.
This utility can be extended if the computing device or MT can define the slots it will listen on. At present the slot structure is defined either by the protocol or where variation is allowed, this is normally in the base station controller (BSC) and/or the base transceiver station (BTS). Without this, the best match of the various options will have to be selected, perhaps dropping some paging slots when there is a clash.
An API to control multiple software defined radios in such a way as to minimize the power consumption will now be described. This control is achieved by only operating radios one at a time. The common `burst` mode activities of the radios being considered allows this mechanism to be implemented.
Radios may be operated intermittently to reduce power consumption. These bursts of activity may be to send or receive a beacon (synchronize, scan--depends on the radio standard) or to send or receive data.
Radios may have a range of repetition rates that are continuously variable between two ranges as shown in FIG. 7 or they may have only a lower limit as shown in FIG. 8, in which case the upper limit would be that the radio can be on continuously.
A radio may also have a set of defined rates instead of a range. It may also have a set of defined frequencies, phase and number of cycles. These may be different for different modes and in different rates.
Overview of the API
The API contains two parts. The first part is the set of data structures that contain data about the radios available to be controlled. The second part is the set of commands that most radio systems will be expected to respond to. This second part is based on the commands used in the Software Defined Radio Commercial Handset guidelines (SDRF-04-A-0006-V0.0 25th. August 2004) issued by the SDR Forum (www.sdrforum.org). Note there are no standards for the data structures that define the possible configurations of the radios.
A radio subsystem can be queried (e.g. via the operating system of the mobile communications device) to determine the characteristics of each of the radios. Below the level of this API there may be a `plug in` mechanism to allow different physical radio hardware to represent itself as part of the radio subsystem.
The radio system is interrogated and the list of radios that the subsystem supports can be enumerated. The data for each radio type is organized as a hierarchy as shown in FIG. 9.
The radio subsystem inquiry tree is enumerated under program control. This interrogation may be instigated by the radio subsystem requesting it. This allows for new devices being plugged in. At present the SDR forum does not include a radio initiated request for interrogation. The system has to issue get_config commands.
The radios are enabled either by user control or limited by environmental controls. For each of the radios that are enabled a set of repetition rates are found to allow each of the radios to be switched on only when no other radio is on. This mechanism is common to many of the use cases described below.
These use cases are the actions from the upper levels. In particular the enabling of a radio is not to be confused with the low level enable command which effectively powers on the radio. At this level this is likely to be a user command that has enabled or disabled the use of a specific type of radio (e.g. switching on Bluetooth).
Startup 1. All the radios are enumerated, 2. Read the parameters for each radio found 3. Find environmental limits in force (airplane, low power etc.) 4. Find repetition pattern for all allowed radios 5. Set radio patterns or repetitions 6. Enable radios 7. Start radios
Radio Removed 1. Find repetition pattern for remaining radios 2. If existing radios are in use, defer change in repetitions.
Radio Disabled 1. Stop radio. 2. Disable radio. 3. Remove radio from repetition pattern 4. Find new repetition pattern for remaining radios 5. Set radio patterns or repetitions
Radio Enabled 1. Find environmental limits in force (airplane, low power etc.) 2. Find new repetition pattern for all allowed radios 3. Set radio patterns or repetitions 4. Enable radio 5. Start radio
Radio Inserted 1. Read the parameters of the new radio 2. Find environmental limits in force (airplane, low power etc.) 3. Find repetition pattern for all allowed radios 4. Set radio patterns or repetitions 5. If existing radios are in use, defer change in repetitions. 6. Enable new radio 7. Start new radio
Low Power 1. Find radios that are to be used 2. Stop and disable all other radios 3. Find repetition pattern for radios 4. Set radio patterns or repetitions
Other compliance based use cases may require activities above the radio subsystem. The control requests below allow for these, but the subsystem will not necessarily respond to all aspects. For example it may be necessary to use only certain frequency channels for Bluetooth when visiting certain countries.
Entering a Radio Restriction Area (Airplane Mode) 1. Receive an airplane mode request (see below) 2. Stop and possibly disable radios not allowed 3. Find repetition pattern for remaining radio 4. Set radio pattern or repetition
Entering Radio Off Area (Hospital) 1. Receive a beacon receive mode command 2. Stop and possibly disable all radios (not necessarily low power) 3. Enable beacon reception
These requests are short strings that can be supplied as push messages. This allows airplane mode to be imposed once a device enters an area by pushing the request on one of the radio channels. Interleaving radios will also require monitoring and debugging control requests.
All radios at lowest repetition rate as well as lowest power output.
Only certain radios are allowed. This request sends the radios allowed. See the beacon setting for the situation where only a specific radio is allowed.
All Radios Off
This is reset manually by the user.
A radio connects to a service all the time or at the maximum rate. This allows the device to act as a monitor for that radio channel
Link to a service and report data transfers via another service. This can be used to test operation of a protocol when the device has no other means of connection like a serial, IrDA, USB port. The reporting may be the complete data or just a summary of the monitored link or service.
Send the N last control requests. This requires the subsystem to maintain the last N requests so it is preferable that a maximum value for N is defined. As these requests are small, there could be a large value for N (e.g. 100,000).
Set a radio to listen for a beacon. This mode can be used to indicate when the radio has left a region.
Set a radio to send a beacon. This mode can be used to indicate if a device leaves a region. This mode can also be used for security purposes.
Lower Level Command
These commands control the radios and the subsystem more directly. These are equivalent to the commands proposed by the SDR forum.
This is different from the radio transmitting or receiving. The configuration is set in the radio and it is ready to operate: a start command starts the radio.
The radio is no longer ready to be used and should be consuming no power.
Some radios may have intelligence and can be set with high level parameters. Others will require that the waveform or burst pattern is set explicitly. This command sends frequency, phase, modulation, cycles, time etc. in the format that is appropriate to the radio. The SDR forum command is set_config.
Sends the rate where the other radio components have either been set by the radio pattern command or cannot be set. This is for radios that only have repetition rates, i.e. those radios that are not frequency hopping. The SDR forum commands do not discriminate and so the set_config command is the only one available.
Read the inquiry tree and load up the radio parameters. The SDR forum commands are get config and capability exchange. There is currently an undefined overlap in these two commands.
This takes a list of radios and make sure that the repetition rates are synchronized. This may be necessary so the two radios work as a network, forwarding packets. Although this functionality is discussed in the SDR forum, there are no low level commands specified.
Many advantages accrue through the use of this invention, including: It enables a reduction of power consumption and avoids the wastage of power that would otherwise occur when a device is concurrently connected to multiple wireless standards; this is applicable to all classes of devices, whether mobile or mains powered. As applied to software defined radio, it allows operation on multiple wireless standards. When used on communication devices such as cellular telephones, it allows multiple concurrent accounts for wireless delivered services.
Although the present invention has been described with reference to particular embodiments, it will be appreciated that modifications may be effected whilst remaining within the scope of the present invention as defined by the appended claims.
Patent applications by NOKIA CORPORATION
Patent applications in class Power conservation
Patent applications in all subclasses Power conservation