Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
METHOD AND DEVICE FOR ASSOCIATING A STATE TO A NEW VALUE OUTPUT BY A DRIFTING SENSOR
Document Type and Number:
WIPO Patent Application WO/2017/202856
Kind Code:
A1
Abstract:
A method of associating at least one state in a plurality of states to a new value output by a drifting sensor, the method comprising: /a/ receiving a signal from the sensor, said signal comprising a plurality of values; /b/ clustering the values of said signal into a number of clusters equal to the number of the plurality of states, each cluster being associated with a respective state in the plurality of states; /c/ for the new value of the signal, associating at least one state in said plurality of states or a probability rating representing the probability to be associated with one state in said plurality of states for said new value of the signal, the associated state or the associated probability rating being determined based on at least distances (dH, dL) of said new value of the signal to respective clusters.

Inventors:
EDOUARD PAUL (FR)
YANG RUI-YI (FR)
HUTCHINGS CÉDRIC (US)
Application Number:
PCT/EP2017/062442
Publication Date:
November 30, 2017
Filing Date:
May 23, 2017
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
NOKIA TECHNOLOGIES OY (FI)
International Classes:
H03M7/30
Other References:
"Cluster analysis", WIKIPEDIA, 14 May 2016 (2016-05-14), XP002772388, Retrieved from the Internet [retrieved on 20170721]
"Moving average", WIKIPEDIA, 13 May 2016 (2016-05-13), XP002772389, Retrieved from the Internet [retrieved on 20170721]
YU; KOBAYASHI: "An Efficient Forward-Backward Algorithm for an Explicit-Duration Hidden Markov Model", IEEE SIGNAL PROCESSING LETTERS, vol. 10, no. 1, January 2003 (2003-01-01), XP011433579, DOI: doi:10.1109/LSP.2002.806705
LELAND WILKINSON, CLASSIFICATION AND REGRESSION TREES, August 2013 (2013-08-01), Retrieved from the Internet
HARTIGAN AND WONG: "Algorithm AS 136: A K-Means Clustering Algorithm", JOURNAL OF THE ROYAL STATISTICAL SOCIETY. SERIES C (APPLIED STATISTICS), vol. 28, no. 1, - 1979, pages 100 - 108, XP009120262, DOI: doi:10.2307/2346830
Attorney, Agent or Firm:
CABINET PLASSERAUD (FR)
Download PDF:
Claims:
CLAIMS

1 . A method of associating at least one state in a plurality of states to a new value output by a drifting sensor, the method comprising:

/a/ receiving a signal (501 ) from the sensor, said signal comprising a plurality of values (200, 201 , 202, 203);

Ibl clustering (503) the values of said signal into a number of clusters (301 , 302) equal to the number of the plurality of states, each cluster being associated with a respective state in the plurality of states;

Id for the new value of the signal, associating (504) at least one state in said plurality of states or a probability rating representing the probability to be associated with one state in said plurality of states for said new value of the signal, the associated state or the associated probability rating being determined based on at least distances (dH, dL) of said new value of the signal to respective clusters.

2. The method according to claim 1 , wherein, prior to step Ibl, the signal is compressed (502) into a compressed signal having compressed values, the compressed values of the compressed signal being used as the values of the signal in step Ibl.

3. The method according to claim 2, wherein said compressing comprises:

161 initializing an average value (210) to a first value (200) of the signal, lei for each second value in a plurality of second values (201 , 202, 203) of the signal output after the first value from the sensor:

/e1/ if a distance (AV) between the second value and the average value is greater than a predetermined threshold, storing the average value as a compressed value into a memory and setting the average value to the second value,

/e2/ otherwise, updating the average value to a new average value as a function of the second value and the average value.

4. The method according to claim 3, wherein, in the step lei and prior to the test /e2/, another test is executed:

/e3/ if a number of second values used to determine the average value is greater than a predetermined threshold, setting the average value to the second value.

5. The method according to claim 4, wherein, in test /e3/, storage of the average value into a memory is performed prior to setting the average value to the second value.

6. The method according to claim 3, wherein, in step lei, the average value is stored along a number of second values used for the determination of the average value after a previous storage of the average value.

7. The method according to claim 3, wherein each second value is associated with a respective time, and wherein in step lei, the average value is stored along a minimum time among all the times associated with a second value used for the determination of the average value after a previous storage of the average value.

8. The method according to any preceding claim, wherein the clustering of step Ibl comprises the use of a k-means algorithm.

9. The method according to any preceding claim, wherein the clustering of step /b/ comprises the use of an unsupervised clustering algorithm.

10. The method according to claim 3, wherein the clustering of step Ibl comprises a weighting of the values of the signal by a number of second values used for the determination of the average value after a previous storage of the average value.

1 1 . The method according to any preceding claim, wherein step Id comprises the use of a forward algorithm.

12. The method according to any preceding claim, wherein step /c/ comprises the use of a decision tree.

13. A non-transitory computer readable storage medium, having stored thereon a computer program comprising program instructions for associating at least one state in a plurality of states to a new value output by a drifting sensor, the computer program being loadable into a data-processing unit and adapted to cause the data- processing unit to carry out, when the computer program is run by the data- processing device:

/a/ receiving a signal from the sensor, said signal comprising a plurality of values;

Ibl clustering the values of said signal into a number of clusters equal to the number of the plurality of states, each cluster being associated with a respective state in the plurality of states;

Id for the new value of the signal, associating at least one state in said plurality of states or a probability rating representing the probability to be associated with one state in said plurality of states for said new value of the signal, the associated state or the associated probability rating being determined based on at least distances of said new value of the signal to respective clusters.

14. An apparatus comprising means for performing the method of any of claims 1

Description:
METHOD AND DEVICE FOR ASSOCIATING A STATE TO A NEW VALUE

OUTPUT BY A DRIFTING SENSOR

BACKGROUND OF THE INVENTION

The present invention relates to the domain of the sensors and especially to the domain of the use of a sensor while its value(s) may slightly drift.

The approaches described in this section could be pursued, but are not necessarily approaches that have been previously conceived or pursued. Therefore, unless otherwise indicated herein, the approaches described in this section are not prior art to the claims in this application and are not admitted to be prior art by inclusion in this section. Furthermore, all embodiments are not necessarily intended to solve all or even any of the problems brought forward in this section.

Normally, when using a sensor, the users may expect that the output value may be constant if the detected characteristics are constant / are identical. For instance, for a pressure sensor, if the pressure to be detected is constant at 2 bars, it may be expected that the output value of the sensor is constant (e.g. 128 for 2 bars, 64 for 1 bar, 32 for 0.5 bars, etc.).

Nevertheless, this is not always the case.

Due to some technologies used for some sensors, the output value may slightly drift: the output value (e.g. numerical) may be 128 for 2 bars at a time t 0 , between 1 15 and 120 for 2 bars at a time t 0 +2h, etc.

Therefore, when it should be determined whether the output value represents a given state (e.g. a "high" value of the sensor may be associated with the state of the presence of a user on a pressure sensor, a "low" value of the sensor may be associated with the state of non-presence of a user on a pressure sensor) it may be difficult to determine in which state the sensor is.

For instance, in the example of Figure 1 , the output value of a pressure sensor is represented by the curve 100. For instance, this pressure sensor is designed to detect if a user is on a bed (state: presence of the user or "high" state) or not on the bed (state: non-presence of the user or "low" state). Even if this example has only two different states, it is possible to generalize this example to any number of states (e.g. a motion sensor which has three states: one state for "no movement", one state for "walking", one state for "running"). At to, the output value of the pressure may be p 0 which is, at that time t 0 , associated with the low state. Between time t 0 and ti , the output value of the sensor may decrease (due for instance to leaks). At time ti, it is apparent, due to the sudden change of the output value up to pi, that a person is present in the bed (high state). One may detect that this is a "high state" as the pressure pi is greater than pi . Between time ti and t 2, the output value of the sensor may decrease (same reason(s) as above). At time t 2 , it is apparent, due to the sudden change of the output, that the person has left (low state). Between time t 2 and t 3 , the output value of the sensor may decrease (same reason(s) as above). At time t 3 , it is apparent, due to the sudden change of the output value up to p 3 , that a person is present in the bed (high state). Nevertheless, it is noted that p 3 is less than p 0 . Therefore, if the value of p 0 is used as a reference of the low state, it may induce incorrect detections / determination of the state.

Thus, there is a need for accurately determining various states based on a sensor whose output value may drift in time, with possibility noisy conditions. If only one state (i.e. a normal state) may be determined, then the drifting of the sensor is determined by computing a running average or sliding window average of the value of the sensor. This process assumes that, most of the time, the sensor detects a "normal state": this is the reason a simple average may provide a satisfactory result in this specific situation. Nevertheless, if a plurality of states may be detected with important probabilities (e.g. three states may be detected with a respective probability rating of 30%, 30% and 40%), it is not possible to perform a simple mean.

In addition, the memory of the device which should perform such determination could be limited. Therefore, the process used may limit the memory used for said determination. SUMMARY OF THE INVENTION

In a first aspect there is provided a method of associating at least one state in a plurality of states to a new value output by a drifting sensor, the method comprising:

/a/ receiving a signal from the sensor, said signal comprising a plurality of values;

Ibl clustering the values of said signal into a number of clusters equal to the number of the plurality of states, each cluster being associated with a respective state in the plurality of states;

Id for the new value of the signal, associating at least one state in said plurality of states or a probability rating representing the probability to be associated with one state in said plurality of states for said new value of the signal, the associated state or the associated probability rating being determined based on at least distances of said new value of the signal to respective clusters. The received signal may be a part of a more global signal.

For instance, the received signal may be the last x seconds of a longer signal (sliding window).

Thanks to this method, it is possible to set dynamically the values of the states of the signal (e.g. the person is sleeping, the person is walking, the person is running), even if the sensor outputting the signal is drifting.

By clustering the signal, it is possible to avoid assuming any state of the signal before processing it (e.g. no need to associate to a new value a state so that an average value of the state is computed for this state).

The distance of step Id may be a mathematical difference (absolute value) of the new value and the barycenter value of each cluster.

In addition, prior to step Ibl, the signal may be compressed into a compressed signal having values, the values of the compressed signal being used as the values of the signal in step lb/.

The compressing may be an approximation of said signal by a piecewise constant function or staircase function.

The compressing may also comprise: Id/ initializing an average value to a first value of the signal, lei for each second value in a plurality of second values of the signal output after the first value from the sensor:

/e1/ if a distance between the second value and the average value is greater than a predetermined threshold, storing the average value as the compressed value into a memory and setting the average value to the second value,

/e2/ otherwise, updating the average value to a new average value as a function of the second value and the average value.

The first value of the signal may be a value output by the sensor before all second values.

In addition, it may be usual to iterate step lei for each second value in the order of the output by the sensor.

Test /e1/ creates a new compressed value for the signal if the new value is "too" different from the previously computed compressed value (i.e. the average value), for example if it differs by more than a threshold amount.

Test /e2/ updates the previously computed compressed value (i.e. the average value) if the previous tests are not matched. This updating may take into account the average value weighted by the number of second points used (e.g. lei is executed N times since the last storage, then this number would be N) and the new value. These last two values may be added and divided by N+1 .

In the step lei and prior to the test /e2/, another test may be executed: /e3/ if a number of second values used to determine the average value is greater than a predetermined threshold, setting the average value to the second value.

Therefore, the test /e2/ is executed only both tests /e1/ and /e3/ fail. Test /e3/ creates a new compressed value for the signal if no important change in the signal (i.e. greater than the predetermined threshold) has been detected since a predetermined period of time (i.e. a predetermined number of second points). This new creation is motivated by the fact that, if a too great number is used to compute the average value, this average value may be non-representative of the signal.

In a specific embodiment, in test /e3/, storage of the average value into a memory may be performed prior to setting the average value to the second value.

By storing the average value in step /e3/, the compressed value of the signal may be stored. If no storage is performed (which is also possible), it is equivalent to set the value of the compressed signal to the new average value for the period of time extending from the last storage to the current second point.

In step lei, the average value may be stored along a number of second values used for the determination of the average value after a previous storage of the average value.

The storage of the number of second values used for the determination of the average value may be useful for weighting the clustering or for weighting the values of the cluster in the determination of its barycenter.

In a given embodiment, each of the second value may be associated with a respective time/timestamp, and in step lei, the average value may be stored along a minimum time among all the times associated with a second value used for the determination of the average value after a previous storage of the average value. In addition, the clustering of step Ibl may comprise the use of a k-means algorithm or the use of an unsupervised clustering algorithm.

The clustering of step Ibl may also comprises a weighting of the values of the signal by a number of second values used for the determination of the average value after a previous storage of the average value.

Step Id may comprise the use of a forward algorithm (see "An Efficient Forward- Backward Algorithm for an Explicit-Duration Hidden Markov Model" by Yu and Kobayashi, IEEE Signal Processing Letters, Vol. 10, No. 1 , January 2003)or the use of a decision tree (see "Classification and Regression Trees" by Leland Wilkinson, University of Illinois at Urbana-Champaign, August 2013 (retrievable as of 25 May 2016 at http://cda.psych.uiuc.edu/multivariate_fall_2013/systat_cart _manual.pdf)).

A second aspect relates to an apparatus comprising: a processor; and a memory including computer program code, the memory and the computer program code configured to, with the processor, cause the apparatus at least to perform: associating at least one state in a plurality of states to a new value output by a drifting sensor, comprising:

/a/ receiving a signal from the sensor, said signal comprising a plurality of values;

Ibl clustering the values of said signal into a number of clusters equal to the number of the plurality of states, each cluster being associated with a respective state in the plurality of states;

Id for the new value of the signal, associating at least one state in said plurality of states or a probability rating representing the probability to be associated with one state in said plurality of states for said new value of the signal, the associated state or the associated probability rating being determined based on at least distances of said new value of the signal to respective clusters.

A third aspect relates to a computer program product comprising a computer readable medium, having thereon a computer program comprising program instructions. The computer program is loadable into a data-processing unit and adapted to cause the data-processing unit to carry out the method described above when the computer program is run by the data-processing unit. Other features and advantages of the method and apparatus disclosed herein will become apparent from the following description of non-limiting embodiments, with reference to the appended drawings.

According to a further aspect, there is provided an apparatus comprising means for performing any of the above described method steps.

According to various, but not necessarily all, embodiments of the invention there is provided examples as claimed in the appended claims.

BRIEF DESCRIPTION OF THE DRAWINGS

The present invention is illustrated by way of example, and not by way of limitations, in the figures of the accompanying drawings, in which like reference numerals refer to similar elements and in which:

- Figure 1 is an example of a drifting output value of a sensor; - Figure 2 is an example of "compression" of a signal into a piecewise function in a possible embodiment of the invention;

- Figure 3 is an example of "clustering" of a signal in a possible embodiment of the invention;

- Figure 4 is an example of a determination of a cluster associated with a new event in the signal in a possible embodiment of the invention;

- Figure 5 is a flow chart describing a possible embodiment of the present invention;

- Figure 6 is a possible embodiment for a device.

DETAILED DESCRIPTION

Figure 2 is an example of "compression" of a signal into a piecewise function in a possible embodiment of the invention. A signal output by a sensor is often a high frequency sampled set of values. For instance, said of values may be derived from a continuous signal after a sampling of 5 Hz to 50 Hz or may be generated by measurements made by the sensor at 5 Hz to 50 Hz.

Most of the time for small electronic devices (e.g. home connected devices), the whole signal cannot be stored in a memory and the manipulation of said signal may be difficult.

In order to avoid storing unneeded information, the following process may be executed.

Upon receiving a new value V 2Q0 (Figure 2(a), 200) of the signal at time t 0 , it is determined if an average value 210 (namely V) is defined.

If not, the average value is initialized: the average value v is then defined to a value equal to the new value v 2m of the signal (Figure 2(a)) i.e. v = v a = V 2Q0 .

In addition, a number of point N points is initialized to 1 and a starting time t start is set to t.

Upon receiving a new value V 2Q1 (Figure 2(b), 201 ) of the signal at time t v and if the average value v is defined/initialized, said average value v is updated to a new value v 1 which is a function of the old average value v and the new value v 2Q1 . For instance, it is possible to compute:

V - N points + V 201

^ oi ts ^

In addition, it is possible to update the number of points: pj « _ pj 4- po ints ' -paints '

Upon receiving a new value V 202 (Figure 2(c), 202) of the signal at time t 2 , the same process described in relation of Figure 2(b) is executed: as the average value V is defined, said average value v is updated to a new value v 2 that is a function of the old average value v and the new value V 2Q2 . For instance, it is possible to compute: points + V 2 Q2

N 4- 1 addition, it is possible to update the number of points

Nevertheless, it is possible to add further conditions for the updating of the average value v.

For instance, if the number of points N poi nts is greater than a predetermined threshold, the set of the average value v, the starting time t start and the number of points N poi rits may be stored in a memory to represent the compressed signal.

Then, the average value V may be unset (or set to "undefined").

To further compress the signal, it is also possible to skip the storing step (for this condition) and only set the average value v to the next received value of the signal / the last received value of the signal without unsetting the average value V : by doing so, the starting time t start and the number of points N p oint3 are kept without being reset. It is equivalent to setting all the previous "pieces" of the compressed piecewise signal to the new current average value v (e.g. searching all the consecutive and previous storage in the memory where the difference between the stored average value and the current average value is below a predetermined threshold and reset all the found stored average value to the current average value). Alternatively or in addition, if a distance between the new value v 203 (Figure 2(d),

203) of the signal at time t 3 and the average value v is greater than a predefined threshold (e.g. if AV = \v zm - v \ is greater than a predefined threshold), the set of the average value v, the starting time t 3tart and the number of points N points may be stored in a memory to represent the compressed signal. Then, the average value V may be unset (or set to "undefined'). The value v 203 is thus processed as the value v 2m in figure 2(a) and a new average value v is created (220) equal to ¾ 3 ,

Therefore, the "compressed" signal comprises a number of "pieces" of piecewise signal, each piece being defined by a start (e.g. a starting time t start ), a length (e.g. a number of points N potnts ) and a value (e.g. an average value V). The pseudo-code for this compressing may be: foreac (new_signal_value) then if (isset (average value) ) then if ( I new signal value-average value |>thres vail) then store (average_value, nb_value, time_start) ; average value = new signal value ; nb value = 1 ; time start = get time (new signal value) ; else if (nb_value>thres_val2 ) then average value = new signal value ; else average_value = (new_signal_value+average_value* nb_value) / (nb_value+l ) ; nb_value ++ ; endif end if else average value = new signal value ; nb_value = 1 ; time_start = get_time (new_signal_value) ; end if end if

Alternatively, the pseudo code may be also: foreach (new signal value) then if (isset (average_value) ) then if ( I new_signal_value-average_value I >thres_vall ) then store (average value, nb_valuel, time_start) ; average value = new signal value ; nb value 1 = 1 ; nb_value2 = 1 ; time_start = get time (new signal value) ; else if (nb value2>thres val2) then average value = new signal value ; nb_value2 = 1 ; else average_value = (new_signal_value+average_value* nb_value2 ) / (nb_value2+l ) ; nb_valuel ++ ; nb_value2 ++ ; endif end if else average value = new signal value ;

nb valuel = 1 ;

nb_value2 = 1 ;

time_start = get_time (new_signal_value) ;

end if

end if

In the latter pseudo code, the variable nb_value has been split into two variables i.e. nb_value1 and nb_value2. Indeed, nb_value1 represents the number of values used since the last storing of the average value while nb_value2 represents the number of values used since the resetting of the average value. This splitting increases the impact of a new value on the average value.

Figure 3 is an example of "clustering" of a signal in a possible embodiment of the invention. "Cluster analysis" or "clustering" is the task of grouping a set of objects (here the values of the signal) in such a way that objects in the same group (called a cluster) are "closer" to each other than to those in other groups (clusters). The number of clusters may be set to any number greater or equal to 2. "Closer" may be understood as "closer according to a given mathematical distance". Any mathematical distance may be used.

This clustering is possible on the raw signal (i.e. the high frequency sampled signal) but it is advantageous to perform this clustering on a compressed signal (for instance, based on the method described in Figure 2) as the memory and the processing means of the device may be limited. If the signal is not compressed (i.e. the signal is sampled at a given/constant frequency), a clustering algorithm may be applied to the values of the signal without weighting.

If the signal is compressed, a clustering algorithm may be applied to the values of the compressed signal (i.e. V according to Figure 2) with a weighting (i.e. each current point may be weighted by the length / the number of points N points associated with the current point).

Many clustering algorithm may be used such as an unsupervised clustering algorithm (e.g. k-means algorithm, see "Algorithm AS 136: A K-Means Clustering Algorithm" by Hartigan and Wong, Journal of the Royal Statistical Society. Series C (Applied Statistics), Vol. 28, No. 1 (1979), pp. 100-108, published by Blackwell Publishing).

For instance, if two clusters are searched, a clustering algorithm may determine that the values of signal 300 may be split into two clusters 301 and 302.

It is advantageous to use a clustering algorithm that supports update mechanisms: when the clusters are determined and when a new value is received in the signal at a time t c , the cluster may be easily updated without re-computing the whole clusters.

For instance, when a point of the signal is newly received, this point may be associated with the closest cluster (e.g. the cluster whose barycenter is the closest).

Figure 4 is an example of a determination of a cluster associated with a new event in the signal in a possible embodiment of the invention.

In said example, it is assumed that two clusters have been previously determined and that C H is a barycenter of one of the clusters and that c L is a barycenter of the other cluster.

Upon the reception of a new point 403 of the signal 400 at a time t c , the distance d H of said point 403 to C H (line 401 ) is determined and the distance d L of said point

403 to C L (line 402) is determined.

Based on said determined distances (and possible other parameters), it is possible to compute a value representing the probability the new value 403 represents an event of the first cluster (e.g. the user is present in the bed in the case the sensor is detecting a pressure in the bed) or of the second cluster (e.g. the user is not present in the bed in the case the sensor is detecting a pressure in the bed). This probability may be a binary probability (e.g. 0 or 1 only) or a "more complex" probability (e.g. a real value between 0 and 1 ).

For instance, the probability P H that the new value 403 represents an event of the first cluster (whose barycenter is C H ) may be: or

P H = inlval( ^ )

d H + d L where intval represents a function that returns the closest integer value.

P H may also be function of the previous values of the signal.

In addition, P M may be determined based on a learning process (e.g. with a neural network for instance). Therefore, a decision tree may be used to limit the use of memory during the determination of P H . Hysteresis thresholding or forward algorithm may also be used for such determination.

Figure 5 is a flow chart describing a possible embodiment of the present invention. Part of this flow chart can represent steps of an example of a computer program which may be executed by an electronic device. Upon receiving 501 a signal (e.g. a high frequency sampled signal), it is possible to compress it (step 502) as detailed in relation of Figure 2. The reception of said signal may be in one "block" (i.e. receiving a single set of data containing the whole signal) but may also be "on the fly" (i.e. receiving the data as soon as it is generated by the sensor).

The compression (step 502) is optional. The signal may be already compressed or it has been determined that the memory/processing means of the devices are not a limit for processing the data.

It is thus possible to compute (step 503) two or more clusters based on the signal (step 503) as detailed in relation of Figure 3.

For each point of the signal (and especially the last received point if the signal is received on the fly), it is possible to determine a probability rating (step 504) as detailed in relation of Figure 4.

Finally, this probability rating (505) may be output. Alternatively or in parallel, an indication to which state (i.e. cluster) the point is related may be output.

Figure 6 is a possible embodiment for a device that enables the present invention.

In this embodiment, the device 600 comprise a computer, this computer comprising a memory 605 to store program instructions loadable into a circuit 604 and adapted to cause circuit 604 to carry out the steps of the present invention when the program instructions are run by the circuit 604.

The memory 605 may also store data and useful information for carrying the steps of the present invention as described above.

The circuit 604 may be for instance: - a processor or a processing unit adapted to interpret instructions in a computer language, the processor or the processing unit may comprise, may be associated with or be attached to a memory comprising the instructions, or - the association of a processor / processing unit and a memory, the processor or the processing unit adapted to interpret instructions in a computer language, the memory comprising said instructions, or

- an electronic card wherein the steps of the invention are described within silicon, or

- a programmable electronic chip such as a FPGA chip (for « Field- Programmable Gate Array »).

This computer comprises an input interface 603 for the reception of the signal according to the invention and an output interface 606. To ease the interaction with the computer, a screen 601 and a keyboard 602 may be provided and connected to the computer circuit 604.

Expressions such as "comprise", "include", "incorporate", "contain", "is" and "have" are to be construed in a non-exclusive manner when interpreting the description and its associated claims, namely construed to allow for other items or components which are not explicitly defined also to be present. Reference to the singular is also to be construed in being a reference to the plural and vice versa.

A person skilled in the art will readily appreciate that various parameters disclosed in the description may be modified and that various embodiments disclosed may be combined without departing from the scope of the invention.