The data communication demands of mobile devices are increasing, particularly with the development of rich multimedia applications which run on such devices. Although a mobile device may have sporadic access to high-speed WiFi connections, often when the device is not particularly mobile (e.g. when in the home, workplace or a hotspot), the rest of the time the data transfer rates to the device are limited by the cellular network (e.g. the 3G network) or other wireless access network infrastructure. Data transfer over this infrastructure is often capped by the subscription data plans offered by a service provider and multimedia applications can easily reach the limited monthly caps. In addition (or instead) the charging structure applied by a service provider can mean that high data usage is very expensive. These mechanisms (caps and/or charging schedules) which artificially constrain data transfer demands may be used by service providers because the backhaul capacity of their network would otherwise be insufficient to meet user demands.
A technique which has been proposed to increase capacity is to use devices in the network, which may be user devices or dedicated devices, to act as relays for data. A relay receives data from one nearby device and transmits the data to another nearby device.
The embodiments described below are not limited to implementations which solve any or all of the disadvantages of known relaying methods and systems.
The following presents a simplified summary of the disclosure in order to provide a basic understanding to the reader. This summary is not an extensive overview of the disclosure and it does not identify key/critical elements of the invention or delineate the scope of the invention. Its sole purpose is to present a selection of concepts disclosed herein in a simplified form as a prelude to the more detailed description that is presented later.
A decentralized relaying algorithm for mobile devices is described. In an embodiment, a mobile device acts as a relay within a network of mobile devices and on contact with a source device downloads messages from the source according to a locally stored relaying probability for each channel of information within the network. These messages are subsequently downloaded to another device which is the end user of the message. Where the relay does not download the message from the source as a result of the decision made based on the relaying probability, a virtual message is downloaded which comprises metadata only and not the payload of the message. The relay updates the stored relaying probabilities for each channel based on locally observable information which includes feedback received from mobile devices to which the relay has downloaded messages. The feedback identifies unique paths for the payload of messages through the network.
Many of the attendant features will be more readily appreciated as the same becomes better understood by reference to the following detailed description considered in connection with the accompanying drawings.
The present description will be better understood from the following detailed description read in light of the accompanying drawings, wherein:
The detailed description provided below in connection with the appended drawings is intended as a description of the present examples and is not intended to represent the only forms in which the present example may be constructed or utilized. The description sets forth the functions of the example and the sequence of steps for constructing and operating the example. However, the same or equivalent functions and sequences may be accomplished by different examples.
Although
Within the system there are one or more information channels, i, and messages (or packets) associated with a particular channel may be published by a single source or by multiple sources. Where multiple sources publish packets from the same channel, each packet has a unique identifier so that duplication can be detected by a relay or user (which may also be referred to as a receiver). For the purpose of the following description, the usefulness (or interest) of a packet to a user depends on whether the user subscribes to the particular channel or not (where a channel may, for example, be a news feed, a social media feed, etc) and whether the packet is delivered to the user in a timely manner, e.g. within a deadline ti associated with messages of channel i (i.e. a message published at time t may be of interest to a user if it reaches the user no later than t+ti)and this time ti may also be referred to as the ‘expiry time’ of a message. Once time t+ti has been reached for a message, that message may be referred to as expired or out-of-date. The value of ti may be the same for all users or may be specified by a user. The deadlines may be different for different channels or may be the same for all channels. It will be appreciated that other criteria may be used in addition to, or instead of, subscription and timeliness to determine the usefulness of a packet to a user.
The steady-state probability pi,u(x) that a message of channel i is received within the deadline by user u under a relaying strategy x may be defined as:
p
i,u(x)=Px[Ai,u≦ti]
where Px[.] is the steady-state probability distribution of random variables under relaying strategy x and Ai,u is the age of a message of channel i when received by user u (assumed infinite if the message is never received by the user). In a stationary and ergodic regime, pi,u(x) corresponds to the delivery rate of channel-i messages to user u (counting only messages received within deadline ti) over an asymptotically large number of published messages.
The value of channel i to user u may be defined by Vu,i(pi,u(x)), where Vi,u is an increasing function Vu,i:[0;1]→R (where R is the set of real numbers). This definition captures both intrinsic user interest for the content of given channel and its timeliness of delivery. Special cases include linear functions such that Vu,i(pi,u(x))=wu,i·pi,u(x) where wi,u is a positive constant that captures user u′s intrinsic preference for channel i. For example, wi,u may take binary values, value 1 if user u subscribes to channel i, and value 0 otherwise. User's preference for a channel can also be inferred from the observed rate of consumption of the content of this channel.
The global system objective of a system, such as shown in
System
where I is the set of all channels and U is the set of all users.
The above optimization problem accounts for buffer constraints at individual user devices, which are implicit in the definition of the delivery probability pi,u(x). However, there is no cost for relays to download messages from sources or to transmit these messages to interested users. In some examples, relays may wish to limit the number of transmissions, for example to save battery power. In order to include this, the objective function in (1) may be replaced by:
where Cr(ar) is a cost function which captures the cost for relay r to transmit and receive messages to be relayed at an average transmission and reception rate ar(x) under strategy x. This cost function may, in some examples, be assumed to be increasing, continuously differentiable, and convex. In the following analysis, the global objective (1) is used for purposes of explanation only and the relaying strategies proposed may be extended to include transmission costs (as in the objective function (2)).
Relaying strategies are described that aim at solving SYSTEM, introduced in (1) using a sub-gradient method that amounts to updating the relay probabilities xi,r as follows, for every channel i and relay r,
Under this dynamics, the objective function in SYSTEM increases over time and converges to a maximum value.
In order to evaluate the gradient in (3), i.e. for every channel j and user u, it is necessary to evaluate δpj,u(x)/δxi,r, for every channel i and relay r. To simplify this computation, techniques from Smoothed Perturbation Analysis (SPA) and stochastic approximation may be used. In the following analysis, the linear utility function Vu,i(pi,u(x))=wu,i·Pi,u(x) (where wi,u is a positive constant) is also used by way of example, but the analysis can be extended to more general classes of utility functions.
Use of SPA to evaluate the gradient of the function pj,u(x), for every channel i and relay r, yields an explicit characterization of the gradient in terms of expectations of some random variables whose realizations can be locally observed by users and estimated by an online procedure described below.
The age Aj,u of a message of channel j when received by user u, if received at all, exceeds the deadline tj for user u, if the message could not have been received within deadline by user u through neither a direct contact with a source of the message nor via any relay. The age Ãj,r,u of the message of channel j at earliest time instant at which it could have been received by user u through relay r (if it was downloaded by relay r) is only less than tj (assuming that the message was generated at time i=0) if both of the following two conditions hold true: (1) there exists a path to user u through relay r within deadline tj and (2) the message is not evicted by the buffer policy at relay r. This may be written:
{Ãj,r,u≦tj}={Dj,r,u≦tj}∩{Nj,r,u≦Br}
where Nj,r,u denotes the number of messages admitted by relay r in the time interval (Dj,r, Dj,r,u], where is the one-hop delay from j to relay r and Dj,r,u is the two-hop delay from j to u through relay r and Br is the size of the buffer at relay r. The parameter Ãj,r,u is defined for each message of channel j and may have a finite value even if the message was not downloaded by relay r. To account for this:
where Rj,r is a binary indicator that takes value 1 if the message was admitted by relay r and value 0, otherwise.
From this it can be observed that Aj,u>tj holds if and only if (1) the message could not have been delivered through a direct contact of user u with a source, i.e. Dj,u>tj, and (2) there exists no path to deliver the message through a relay within the deadline, i.e. Aj,r,u>tj, for every relay r. In other words:
{Aj,u>tj}={Dj,u>tj}∩r{Aj,r,u>tj}
Some additional notation is now defined: Nj,r,ui is the number of channel-i messages downloaded by relay r in the time interval (Dj,r, Dj,r,u] and Kj,r,ui is the number of channel-i messages that are observed by relay r in (Dj,r, Dj,r,u] but not downloaded. Aj,u−r denotes the age of a message of channel j when arriving at user u, assuming that relay r is not used to disseminate the message. Aj,u−r>tj holds if and only if Dj,u>tj and Aj,r′,u>tj, for every relay r′≠r. An indicator Ij,r,u is also defined for a message of channel j, relay r, and user u:
Ij,r,u=1IA
where, for a relation A, 1IA is equal to 1 if A is true and 0 otherwise.
Using this notation, for every channel j∈I and user u∈U, the gradient of the function pj,u(x) is given by, for every channel i and relay r,
The component of the gradient, δpj,u(x)/δxi,r, consists of a positive and a negative element. The positive element is zero for every i≠j and for i=j, it corresponds to the probability that the message of channel i could have been delivered through relay r and not through any other path. The negative element can be interpreted as a negative externality term that captures the effect of increasing the relaying probability xi,r on the probability of delivery of channel-j messages. This term measures the number of channel-i messages downloaded by relay r during the time the channel-j message, which was dropped by r just before meeting user u, was in the buffer of relay r; and the number of channel-i messages that were rejected by relay r during the time the channel-j message was in the buffer and it was at the head of the queue (next to be evicted) when relay r meets user u. The gradient in (4) can be estimated in an online fashion by relays using only locally observable information, as described below. The term ‘locally observable’ is used herein to refer to information which is available at a node (e.g. at a relay) and which may either be computed/observed at the node or provided to the node by another node (e.g. by a user or a source) which computed/observed the information. This is distinct from methods and systems which require full information about the state of the network and the messages carried in that network.
In order to update the relaying probabilities by a relay r based on locally observable information, the following variables may be introduced per message m of channel c that are locally observable by relay r:
where
αi,r,u(m)=(wi,u1IA
and
βi,r,u(m)=wc,u1IA
×[Nc,r,ui(m)1IN
The variables αi,r,u(m) and βi,r,u(m)correspond to the positive and negative elements described above in the discussion following equation (4).
A relay r can observe Yi,r(m)when it receives feedback from users for message m (as indicated by arrow 118 in
The nth feedback from a user to relay r may be denoted Sr(n) (and noting that (Sr(n), n≧0) is a superposition of the instances (Tr,u(m),∀m,∀u)). The channel of the corresponding message may be denoted c(n), and the user from which relay r receives feedback denoted u(n). The relaying probabilities (xi,r; i∈I) may then be updated using the following stochastic approximation algorithm per each new feedback received, for 0<ε<1,
where λjr is the publishing rate of messages of channel j as observed by relay r (and this is equal to the publishing rate of channel j messages if the relay meets a source of channel j at a positive rate). It can be seen that the update rule (5) conveniently aggregates feedback from different users in an online fashion. It can also be shown that the update rule (5) approximates the sub-gradient algorithm specified in (3).
Example implementations of systems, such as shown in
Where the relay does not download a message (based on the decision made using the relaying probability), the relay downloads some metadata associated with the message (block 204) and this metadata may be referred to as a ‘virtual message’ to distinguish it from a ‘real message’ where the actual message content (which may also be referred to as the message payload) is downloaded. This metadata, which may comprise control information, is used in the computation of the positive and negative elements when updating the relaying probability (e.g. using equation (5) above). The metadata comprises a subset of the message (or packet) header and the size of the metadata is significantly smaller than the data payload of the message. As a minimum, this metadata identifies the message (e.g. by a unique identifier) and the channel to which it belongs. The downloaded messages (whether real or virtual) are stored in the buffer 116 of the relay (as shown in
When downloading messages from a source (in block 202), it may be necessary to drop existing (real or virtual) messages which are stored in the buffer. As described above, the buffer operates a FIFO system which may be based on message age or how long ago the message was downloaded from a source. The relay maintains a record of the last dropped real message (block 206) and this is updated each time another real message is dropped. This is shown graphically in
When the relay makes contact with a user, the relay downloads messages to the user which are of interest to that user (block 208). As described, whether a message is of interest to a user may be defined in terms of whether the user has subscribed to the particular channel and whether the message has expired (i.e. whether the message is delivered to the user within a time interval t1 after the message was published). Virtual messages are downloaded as well as real messages as these virtual messages are used by the user when identifying unique paths for messages through the system to that user.
The relay also receives feedback from the user (block 210) for expired messages. This feedback identifies any messages which were observed at the relay (i.e. downloaded from the relay) within the deadline and where the payload of this message could not be downloaded from neither a source nor another relay—this therefore identifies unique paths for real messages from a source, via the particular relay, to the user and therefore may be referred to as ‘positive feedback’. The feedback also identifies any messages which were of interest to the user, which were observed at the relay in either the head-of-the-queue position (e.g. in the position of message 120 in
Although
In addition to storing relaying probabilities for each channel and details of the last-dropped message, a relay may store additional state information or parameters which may be used in updating the relaying probabilities (in block 212). As shown in
If a message of interest (‘Yes’ in block 302) is in the head-of-the-queue position (‘Yes’ in block 304), values (which may be denoted dec_h[M] [i] [u] or dec_h[m] [i]) are stored for each channel i (i.e. not only the channel to which message m belongs) which are set to the difference between the number of channel-i messages in the buffer (both real and virtual) and the number of real channel-i messages in its buffer (block 306). This is actually equal to the number of virtual channel-i messages in the buffer at the time of the event (i.e. at the time that user u observes message m in the head-of-the-queue state), Kc,r,ui(m) (where c is the channel of message m). In the example shown in
Kl,r,u1(m)=0
Kl,r,u2(m)=2
Kl,r,u3(m)=3
As in the state shown, there are no virtual messages from channel 1 (i=1) in the buffer 116, two virtual messages from channel 2 and three virtual messages from channel 3.
If a message of interest (‘Yes’ in block 302) is in the last-dropped record 122 (‘Yes’ in block 308), values (which may be denoted dec_ld[m] [i] [u] or dec_d[m] [i]) are stored for each channel i (i.e. not only the channel to which message m belongs) which are set to the number of real channel-i messages in its buffer (block 310) at the time of the event (i.e. at the time that user u observes message m in the last-dropped record), Nc,r,ui(m) (where c is the channel of message m). In the example shown in
Nl,r,u1(m)=3
Nl,r,u2(m)=1
Kl,r,u3(m)=1
As in the state shown, there are three real messages from channel 1 (i=1) in the buffer 116, and one real message from each of channel 2 and channel 3.
The relay may also store and use estimates of the publishing rate of messages of each channel (λir)when updated the relaying probabilities. As shown in
In an example implementation, the feedback for a message m of channel c provided by a user u (and received by a relay in block 210) may be in the form of ternary feedback (f1(m), f2(m), f3(m)), where f1(m), f2(m) and f3(m) are binary values. In an example, these binary values may be used to adjust the relaying probabilities as follows, for a fixed configuration parameter ε>0:
x
i,r
←x
i,r+ε{circumflex over (λ)}cr[f1(m)1Ic=i−f2(m)(f3(m)(dec—h[m][i][u]+(1−f3(m))dec—ld[m][i][u])].
In this example, f1(m) signals whether an increment of the relaying probability xc,r should be made, f2(m) signals whether a decrement of the relaying probabilities of relay r should be made, and f3(m) signals whether the decrement is because m was either in the head-of-the-queue or the last-dropped state.
In an optimization to this method implemented at a relay, the relay may maintain a list of users that need to provide feedback for each message m. Such a list comprises those users that observed message m from the buffer of relay r or in the last-dropped state at relay r (as created/updated in block 404). Users are only added to the list when they observe message m for the first time, i.e. they are not added to the list again if they subsequently view the same message again. The list of users is updated (in block 406) when feedback is received (in block 210) from a user for message m and any state maintained for message m can be deleted by relay r (in block 408) when feedback is received from all users that needed to provide feedback (i.e. from all users on the list). The state that is deleted comprises the parameters dec_h[m][i][u] and/or dec_ld[m][i][u] for all channels where such records have been generated (e.g. in blocks 306 and 310 of
In another optimization of the methods shown in
The following pseudo-code shows another example implementation of the relaying algorithm at a relay r.
As described above, each relay maintains historical data about all messages irrespective of whether they downloaded them from a source or whether they did not. For messages which are not downloaded, this data comprises metadata (downloaded in block 204) and for messages which are downloaded, this data comprises the messages themselves. In addition, the historical data includes details of messages which were in the last-dropped state or head-of-the-queue state at a particular encounter with a user (in blocks 206, 306 and 310). This record of all messages which could have traversed a particular path through the network, irrespective of whether the payload of the message actually traversed the network, enables unique paths through the network to be identified and the data relating to messages in the head-of-the-queue position or last-dropped state provides an indication of whether the relays are becoming overloaded with messages from a particular channel. Together this information enables the global system objective to be optimized in a fully distributed manner. It will, however, be appreciated, that the particular data recorded in the examples described above, provides just one example of suitable historical data which may be recorded in order to enable the global system objective to be optimized in this distributed manner and based only on locally observable data. In other examples, different data may be stored by the relay (e.g. instead of the data stored in blocks 306 and 310) and this different data may be used in updating the per-channel relaying probabilities.
As described above, a single control variable, the relaying probability, is used to determine whether the relay downloads a message from a source or not. This single control variable is the same for all messages of the channel (or stream) and is only updated when feedback is received regarding an expired message from a user. Use of a single control variable results in a system which can be implemented practically and is scalable to large numbers of mobile devices and large systems of mobile devices. Experimental results show that the use of such a single control variable, compared to a centralized system, does not impact performance.
In order to assist in maintaining these lists, the user may also maintain a Boolean variable for each observed message which can be used to distinguish the case where a user could have downloaded the payload of a message from more than one device, be that device a source or a relay. In an example, this parameter, which may be denoted seen_real[m] may be set to 0 when a real version of message m has not been observed and may be updated to be equal to 1 when a real version of the message m is downloaded.
Otherwise, if message m was already observed at an earlier instance (‘Yes’ in block 704), then two cases are distinguished. First, if message m is a real message (‘Yes’ in block 716), then any entries from inc_list[m] are removed (block 718) and r is appended (in block 722), if seen_real [m] is equal to 0 (‘Yes’ in block 720); then, seen_real [m] is set to 1 (block 724). Second, if m is a virtual message (‘No’ in block 716), r is appended to inc_list[m] (in block 728), if seen_real[m] is equal to 0 (‘Yes’ in block 726). This process is repeated for the next message which is observed at the relay r (block 730).
Although the methods for updating the two lists (dec_list[m] and inc_list[m]) are shown separately in
When a user u meets a source s, the two lists described above and the value of the variable seen_real[m] are also updated, as shown in
The following pseudo-code shows another example implementation of the methods implemented at user u and described above with reference to
As described above, the relaying strategies proposed may be extended to include transmission costs (as in the objective function (2) above). In an example implementation, the gradient with cost functions (which corresponds to equation (4) in the example above) consists of two components:
The first component is identical to that described above and so the same update rules for the relaying probabilities apply for this component and the other component (which relates to the second term in equation (2)) involves computation of ∂ag(x)/∂xi,r for every relay g, relay r and channel i. The communication rate ag(x) for a relay is a sum of the download rate dg(x) and upload rate ag(x). It can be shown that:
And based on this, update rules for the second component may be derived which are similar but different to those for the first component.
Experimental results using the implementations of the algorithm described above (with ε=0.01, although other values were tried resulting in negligible performance changes), show that the algorithm provides similar or better performance than other relaying schemes which are much more complex because they require full information about the state of the network and the messages carried in that network (e.g. which messages are held by which nodes). In situations of low publishing rates, the algorithm described above performs best and outperforms existing relaying schemes. As described above, the algorithms described herein are fully decentralized, require only local observations and allow for general user mobility. It has also been proven that the algorithm converges to optimal points of the underlying global system objective. Results have also shown that the algorithm is more robust than existing relaying schemes whose principles are based on specific user mobility assumptions such as statistical independence of delays through different paths (an assumption which is often invalid).
Furthermore, the methods described above support multi-point to multi-point communications unlike existing techniques which are limited to unicast routing between a source and a user (which may be referred to as an ‘end device’). Point to multi-point routing (i.e. multi-channel multicasting) is supported by the definition of an objective function (and hence by the relaying probability update algorithm and feedback mechanism) that encodes the value of a channel transmission as an aggregate delivery rate across users interested in this channel. The multi-point to multi-point capability is enabled by the fact that for the system described herein it does not matter whether there is a unique source of a channel or there are multiple distributed sources for the same channel (as described above).
The algorithm described above is a distributed algorithm in which a relay updates relaying probabilities based on user expressed interest in packets that they relay is carrying when the user meets the relay. The use of virtual messages, as described above, provides a mechanism that enables the algorithm to estimate the needed parameters to converge to optimal relaying probabilities.
In an example implementation, the algorithms and methods described above may be implemented in an application which runs on the mobile device or may be implemented within the operating system of the mobile device. Where the algorithm is implemented as an algorithm, this may be downloadable to the mobile device from a central location on the request of the person using the mobile device or the application may be pushed to the mobile device by a network operator. A single application may enable a mobile device to act as a relay and a user (i.e. an end user of the messages) or separate applications may enable operation as a user and as a relay.
Computing-based device 1000 comprises one or more processors 1002 which may be microprocessors, controllers or any other suitable type of processors for processing computer executable instructions to control the operation of the device in order to send and/or receive messages and in some examples to act as a relay for messages downloaded from a source. In some examples, for example where a system on a chip architecture is used, the processors 1002 may include one or more fixed function blocks (also referred to as accelerators) which implement a part of the relaying algorithm in hardware (rather than software or firmware). In an example, the algorithm for updating the per-channel relaying probabilities may be implemented in hardware.
Platform software comprising an operating system 1004 or any other suitable platform software may be provided at the computing-based device to enable application software 1006 to be executed on the device. The application software may comprise a relay engine 1008 and/or a user engine 1010. The relay engine 1008 is arranged to operate as described above (e.g. with reference to
The computer executable instructions may be provided using any computer-readable media that is accessible by computing based device 1000. Computer-readable media may include, for example, computer storage media such as memory 1012 and communications media. Computer storage media, such as memory 1012, includes volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EPROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other non-transmission medium that can be used to store information for access by a computing device. In contrast, communication media may embody computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave, or other transport mechanism. As defined herein, computer storage media does not include communication media. Although the computer storage media (memory 1012) is shown within the computing-based device 1000 it will be appreciated that the storage may be distributed or located remotely and accessed via a network 1014 or other communication link (e.g. a link to another mobile device) using communication interface 1016.
The computer-readable media 1012 may also comprise a data store 1018 which is used to store data created by or used by the relay engine 1008 or user engine 1010. In an example, the data store 1018 may store the relaying probabilities, the historical data about messages which have been observed at a source and the record sets relating to messages in the buffer at the time a user observes a message that is of interest to that user and which is in the head-of-the-queue position or last-dropped state (e.g. the record sets created in blocks 306 and 310 of
The communication interface 1016 enables the computing-based device 1000 to receive messages from other devices and to transmit messages to other devices. Any suitable radio protocol may be used for this communication, including cellular protocols, short range protocols, etc. The communication interface 1016 may be arranged such that it can transmit/receive using more than one radio protocol or there may be more than one communication interface 1016 within the device 1000. In a system, such as shown in
The computing-based device 1000 also comprises a user input device 1020 and a display device 1022. In some instances these two devices may be combined into a single device, such as a touch sensitive display. In other examples, a separate keyboard or set of buttons may be provided (in addition to or instead of a touch sensitive display) as a user input device 1020. The display device 1022 may provide a graphical user interface.
Although the present examples are described and illustrated herein as being implemented in a system as shown in
The term ‘computer’ is used herein to refer to any device with processing capability such that it can execute instructions. Those skilled in the art will realize that such processing capabilities are incorporated into many different devices and therefore the term ‘computer’ includes PCs, servers, mobile telephones, personal digital assistants and many other devices.
The methods described herein may be performed by software in machine readable form on a tangible storage medium e.g. in the form of a computer program comprising computer program code means adapted to perform all the steps of any of the methods described herein when the program is run on a computer and where the computer program may be embodied on a computer readable medium. Examples of tangible (or non-transitory) storage media include disks, thumb drives, memory etc and do not include propagated signals. The software can be suitable for execution on a parallel processor or a serial processor such that the method steps may be carried out in any suitable order, or simultaneously.
This acknowledges that software can be a valuable, separately tradable commodity. It is intended to encompass software, which runs on or controls “dumb” or standard hardware, to carry out the desired functions. It is also intended to encompass software which “describes” or defines the configuration of hardware, such as HDL (hardware description language) software, as is used for designing silicon chips, or for configuring universal programmable chips, to carry out desired functions.
Those skilled in the art will realize that storage devices utilized to store program instructions can be distributed across a network. For example, a remote computer may store an example of the process described as software. A local or terminal computer may access the remote computer and download a part or all of the software to run the program. Alternatively, the local computer may download pieces of the software as needed, or execute some software instructions at the local terminal and some at the remote computer (or computer network). Those skilled in the art will also realize that by utilizing conventional techniques known to those skilled in the art that all, or a portion of the software instructions may be carried out by a dedicated circuit, such as a DSP, programmable logic array, or the like.
Any range or device value given herein may be extended or altered without losing the effect sought, as will be apparent to the skilled person.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims
It will be understood that the benefits and advantages described above may relate to one embodiment or may relate to several embodiments. The embodiments are not limited to those that solve any or all of the stated problems or those that have any or all of the stated benefits and advantages. It will further be understood that reference to ‘an’ item refers to one or more of those items.
The steps of the methods described herein may be carried out in any suitable order, or simultaneously where appropriate. Additionally, individual blocks may be deleted from any of the methods without departing from the spirit and scope of the subject matter described herein. Aspects of any of the examples described above may be combined with aspects of any of the other examples described to form further examples without losing the effect sought.
The term ‘comprising’ is used herein to mean including the method blocks or elements identified, but that such blocks or elements do not comprise an exclusive list and a method or apparatus may contain additional blocks or elements.
It will be understood that the above description of a preferred embodiment is given by way of example only and that various modifications may be made by those skilled in the art. The above specification, examples and data provide a complete description of the structure and use of exemplary embodiments of the invention. Although various embodiments of the invention have been described above with a certain degree of particularity, or with reference to one or more individual embodiments, those skilled in the art could make numerous alterations to the disclosed embodiments without departing from the spirit or scope of this invention.