The present invention concerns a filter arranged to suppress a slow drift from a signal representing a quantity of interest. Embodiments of the invention relate to a digital implementation of the aforesaid drift suppression filter, and to a proximity detector that uses the aforesaid filter to discriminate between a legitimate signal, for example the approach of a person, and a drift generated by temperature variations or 0 any other reason. These are not, however, the only applications of the invention.
In several measuring and sensing applications, relevant information is carried by an electric value (i.e., a voltage or a current) that represents a quantity of interest, to which is superposed a spurious value that may be constant or drifting slowly. Since the presence of the spurious baseline is a limit to the sensitivity and 5 precision of the measure, a number of algorithms and filters have been devised to eliminate it from the signal of interest.
Capacitive proximity detectors are used in many modern portable devices, including mobile phones and tablets, to determine whether the device is close to a body part of a user. This information is important in several ways: it is used to detect 0 whether the telephone is being actively manipulated by a user, and whether the user is looking at the display, in which case the information displayed can be adapted, and/or the device switch from a low power state to an active one. Importantly, this information is used to adapt the power level of the radio transmitter to comply with body dose limits. Capacitive proximity detection is used also in touch-sensitive displays and panels.
Capacitive proximity detection depends critically on drift suppression. Typically, the capacity of the approaching user’s body, seen from an electrode on the device, is many times smaller than the background capacity of the electrode itself. This background value and its fluctuations would totally mask the proximity signal, were they not eliminated.
Supposing that the signal that must be measured varies much faster than the drifts in the baseline, the latter can be suppressed by a straightforward high-pass filter. In some cases, the same result is obtained by computing a running average value of the signal, that is taken to represent the drift, and subtracting it from the original signal.
In many real cases, however, this simple approach is not sufficient. Drift suppressors tend to reduce the desired signal as well as the drift, particularly when the signal of interest varies gradually, such as it would be the case – in a portable device – of a user approaching quite slowly to the proximity sensor.
Documents US10,136,399B1, US10,423,278B2, US10,298,280B2 and US2021/0083664A1 disclose capacitive detectors providing proximity-awareness in a portable device, such as a portable phone, and various circuits and algorithms used to process the signal accounting for background and drift.
The present invention proposes a method of removing a drift from a proximity signal that is suitable for portable devices equipped with capacitive proximity sensors but could be applied usefully to other uses. A capacitive sensor is also part of the invention, as well as a portable device so equipped.
With respect to other known solutions, the proximity sensor of the invention exhibits a significantly better immunity against drift and is therefore less sensitive to temperature changes. It retains its efficacity in detecting proximity even if the approach is very slow.
According to the invention, these aims are attained by the object of the attached claims.
Exemplar embodiments of the invention are disclosed in the description and illustrated by the drawings in which:
The detector is sensitive to the capacitance Cx of an electrode 20 that will increase slightly at the approach of a user’s hand, face or body. As already discussed, the variations due to body proximity are overshadowed by the own capacity of the electrode which, in turn, is not stable. The capacity signal preferably amplified and processed by an analogue processor 23, which may also subtract a programmable offset, and converted into raw digital values by an A/D converter 25. The samples R(k) may be encoded as 16 bits integers, or in any other suitable format.
The device represented in
The raw samples R(k) contain also, in a non-ideal world, noise and unwanted disturbances that are attenuated by a filter 30. The filter 30 may be a digital low-pass filter, dimensioned in consideration of the bandwidth of the expected signal, or any other suitable filter. The filter 30 provides a series of samples U(k) useful for the processing in the successive stages.
Although the filter 30 is represented as a simple block to simplify the drawing, it may in fact comprise several processor units for reducing noise. It may include FIR low-pass filter, llR low-pass filter, and nonlinear algorithm, according to the need. It has been found that the part of the signal that is most significant for the purpose of controlling the functions of a portable phone, for example, falls within a spectrum of frequency of a few Hertz.
Block 62 represents a drift suppression unit that is used to estimate and suppress the drift, be it of thermal nature or otherwise, superimposed to the capacity variations. Unit 60 is a baseline estimator that generates a digital signal A(k) that approximate the instantaneous value of the baseline, which is supposed to be an effect of the drift. The baseline is subtracted digitally from the proximity signal U(k) and the result is the drift-suppressed signal D(k). A discriminator 50 then generates a flag signal ‘PROX’ that indicates the proximity of the user’s hand, face or body. The invention is not limited to a binary output, however. In variants, the decision unit 50 may be a multi-level discriminator that generates a several flags, according to the level of proximity, or any other useful variable. The output of the detector needs not be materialized in an output terminal: the flag may be encoded in a value stored in a register of the proximity sensor that is accessible through a communication bus, such as l2C or SPI.
The various block making up the proximity sensor are represented separate and distinct in the drawing but should in fact be interpreted as functional units. In a practical implementation, they may be realized in part or completely in software and may share code and data resources.
The capacitive proximity sensor may be part of a cellphone, a laptop, a tablet, or another connected portable device. In this case, the capacitive electrode 20 could serve also as RF antenna, be a part of a metallic chassis of the phone, or simply a copper area on a PCB.
The generation of the baseline signal A(k) will now be explained referring do
An important aspect of the method of the invention is the estimation of the variation of the useful signal Un.The variation is represented by a quantity Δvar that is preferably computed at each new useful sample U(k) (step 305). A possible manner of estimating the variation of U(k) is the difference between a sample and the preceding one, Δ01 = U(k) - U(k - 1) or a running average Δvar of the differences U(k) - U(k - 1) in a suitable window, for example the last N received samples of U(k): Δvar = (U(k) - U(k - N - 1))/N where N may take any suitable value, for example N=8. At the step 305 the method of the invention receives a new value of the useful signal U(k) and computes or receives a corresponding new value of Avar.
Step 308 checks whether the proximity flag is raised, i.e. there have been indications that a conductive body is nearby. If the result of this test is positive, the method tests (step 130) whether the variation Δvar is in a predetermined region of acceptation. In the example, Δvar is compared (step 312) with an upper threshold T1 which will be, in most cases, positive and, (step 322) with a lower threshold T2 that may be negative.
If the PROX flag is not asserted, the method follows the right branch from the test 308, which is completely symmetrical to the left one. The variation Δvar is compared (314) with an upper threshold T3 which will be, in most cases, positive and, (324) with a lower threshold T4 that may be negative. Numerically, T3 may differ from T1 and T4 from T2, or they could be equal. Advantageously, this symmetrical processing avoids that strongly negative variations (for example, when the user suddenly moves away from the sensor) are not detected.
If Δvar is neither above the upper threshold nor below the lower one, no matter whether the proximity flag is asserted or not, the value of the baseline is incremented (step 330) by a value derived from the proximity signal. Preferably, the increment will be a value related to the slope, or derivative of the proximity signal such that the successive increments yield back, by integration, the original shape. In a possible variant, the baseline signal A(k) is incremented by the average slope signal Δvar· Alternatively, the baseline signal is incremented by the instantaneous slope Δ01 = U(k) - U(k - 1). Other expressions are possible, however.
If Δvar is above the upper threshold or below the lower one, the baseline is incremented by a fixed amount, irrespective of the values of U(k) and Δvar. This takes place in one of the cells 316, 326, 318, 328, according to the sign of the exceeded threshold and the flag state. The operation that is done is always the same, but the value of the fixed amount D1, D2, ..., D4 may be different.
It is important to reset the value of the baseline A(k) to that of the proximity signal U(k) from time to time. It was found advantageous to do this operation whenever the value of the baseline exceeds that of the proximity signals (cells 335 and 338).
Plot 130 is the proximity signal U(k) coming from the filter unit 30. It exhibits a steeply rising step, indicating a conductive body approaching the sensor, followed by a falling step after some time, showing that the conductive body has been moved away. This pattern of proximity is superposed to a slowly changing baseline, as it may be due to a thermal drift. Plot 140 is the corresponding average slope Δvar taken on a window of 8 samples. The rising and falling steps are marked in this plot by a positive and a negative peak.
The threshold values T2 and T1 are marked by the dashed line 144. Inside the intervals 148, 149, the baseline signal A(k) is incremented by fixed values and has a linear slope, except when it is limited by the intervention of the reset test (335, 338 in
Subtracting the baseline from the proximity signal provides a drift-suppressed signal. Plot 160 is the result of this suppression when the baseline is incremented by the average slope Δvar· Plot 165 is the same when the baseline is incremented by the instantaneous slope Δ01. The former retains some noise, due the finite resolution of the numeric algorithm, while the latter is very close to a square signal, with minimal noise.
Note that this tracking method may improve by using a debouncer and/or a limiter on the signals to avoid the occurrence of very large values of Δ01 when Δvar transiently crosses the ~0 value, for example during fast taps.
In a portable wireless device, the sensor and method disclosed herein can be used advantageously to detect when the device is brought close, for example to the user’s head. In such cases, the device can be configure to take specific actions, for example: switching off a display, inhibiting a tactile input, adapting a radio transmission power.
20
21
23
24
25
30
40
50
60
62
139
140
144
148
149
150
155
160
165
220
230
240
305
308
312
314
316
318
322
324
326
328
330
335
338
The present application claims the benefits of prior date of U.S. Provisional Application 63/335,524 of Apr. 27, 2022, the contents whereof are hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
63335524 | Apr 2022 | US |