Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
FORCE SIGNAL PROCESSING
Document Type and Number:
WIPO Patent Application WO/2021/005327
Kind Code:
A1
Abstract:
A method of processing a number of force values is described. Each force value corresponds to a sensor location. The sensor locations are spaced apart along a direction. The method includes receiving the force values (S11). The method also includes determining whether the force values include one or more candidate peaks (S12). Each candidate peak corresponds to a local maximum of the force values. The method also includes, in response to at least one candidate peak exceeds a minimum force threshold (S13), interpolating the force values and estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the candidate peaks (S14) which exceed the minimum force threshold.

Inventors:
MICCI RICCARDO (GB)
NATHAN AROKIA (GB)
Application Number:
PCT/GB2020/051452
Publication Date:
January 14, 2021
Filing Date:
June 17, 2020
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
CAMBRIDGE TOUCH TECH LTD (GB)
International Classes:
G06F3/041
Domestic Patent References:
WO2019030513A12019-02-14
WO2016102975A22016-06-30
WO2017109455A12017-06-29
WO2016102975A22016-06-30
Foreign References:
US20140210791A12014-07-31
US20170262099A12017-09-14
KR20170093985A2017-08-16
EP2902886A12015-08-05
JP2015097068A2015-05-21
JP2010026938A2010-02-04
Attorney, Agent or Firm:
DUNLEAVY, Christopher et al. (GB)
Download PDF:
Claims:
Claims

1. A method of processing a plurality of force values, each force value

corresponding to a sensor location, wherein the sensor locations are spaced apart along a direction, the method comprising:

receiving the plurality of force values;

determining whether the plurality of force values include one or more candidate peaks, each candidate peak corresponding to a local maximum of the plurality of force values;

in response to at least one candidate peak exceeds a minimum force threshold: interpolating the plurality of force values;

estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the candidate peaks which exceed the minimum force threshold.

2. A method according to claim l, further comprising in response to at least one peak force value exceeds a second force threshold, outputting each peak force value which exceeds the second force threshold and the corresponding peak coordinates.

3. A method according to claim l or claim 2, further comprising, for each peak coordinate:

in response to determining that the peak coordinate is associated with a tracked touch event:

adding the peak coordinate to a coordinate buffer which stores a number of previously estimated peak coordinates for the tracked touch event;

calculating an average coordinate based on the coordinate buffer;

outputting the average coordinate and the peak force value in response to determining that the peak coordinate is not associated with any tracked touch event:

storing the peak coordinate and the corresponding peak force value to a new tracked touch event;

outputting the peak coordinate and the corresponding peak force value.

4. A method according to any one of claims l to 3, wherein interpolating the plurality of force values comprises calculating a polynomial spline using the plurality of force values.

5. A method according to claim 4, wherein each candidate peak corresponds to a candidate sensor location and a candidate force value, and wherein estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the one or more candidate peaks comprises, for each candidate peak:

in response to determining that the candidate sensor location is equal to a minimum or maximum sensor location:

calculating stationary points of a first spline segment connecting the candidate sensor location and the adjacent sensor location;

determining whether a first stationary point corresponding to a maximum is located within the first spline segment;

in response to a positive determination, assigning a peak coordinate equal to the first stationary point and assigning a

corresponding peak value equal to evaluating the first spline segment at the peak coordinate;

in response to a negative determination, assigning a peak coordinate equal to the candidate sensor location and assigning a corresponding peak value equal to the candidate force value;

in response to determining that the candidate sensor location does not correspond to a minimum or maximum sensor location:

calculating stationary points of a second spline segment connecting the candidate sensor location and the adjacent sensor location corresponding to the largest force value;

in response to determining that a second stationary point corresponding to a maximum is located within the second spline segment, assigning a peak coordinate equal to the second stationary point and assigning a corresponding peak value equal to evaluating the second spline segment at the peak coordinate;

in response to determining that a stationary point corresponding to a maximum is not located within the second spline segment:

calculating stationary points of a third spline segment connecting the candidate sensor location and the other adjacent sensor location; in response to determining that a third stationary point corresponding to a maximum is located within the third spline segment, assigning a peak coordinate equal to the third stationary point and assigning a corresponding peak value equal to evaluating the third spline segment at the peak coordinate.

6. A method according to claim 4, wherein each candidate peak corresponds to a candidate sensor location and a candidate force value, and wherein estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the one or more candidate peaks comprises, for each candidate peak:

in response to determining that the candidate sensor location corresponds to a minimum or maximum sensor location:

calculating stationary points of a first spline segment connecting the candidate sensor location and the adjacent sensor location;

determining whether a first stationary point corresponding to a maximum is located within the first spline segment;

in response to a positive determination, assigning a peak coordinate equal to the first stationary point and assigning a corresponding peak value equal to evaluating the first spline segment at the peak coordinate;

in response to a negative determination, assigning a peak coordinate equal to the candidate sensor location and assigning a corresponding peak value equal to the candidate force value;

in response to determining that the candidate sensor location does not correspond to a minimum or maximum sensor location:

calculating stationary points of a second spline segment connecting the candidate sensor location to one of the adjacent sensor locations and:

in response to determining that a second stationary point corresponding to a maximum is located within the second spline segment, assigning the second stationary point as valid and high priority;

in response to determining that the second stationary point is located within the third spline segment, assigning the second stationary point as valid and low priority;

calculating stationary points of a third spline segment connecting the candidate sensor location to the other adjacent sensor location; in response to determining that a third stationary point corresponding to a maximum is located within the third spline segment, assigning the third stationary point as valid and high priority;

in response to determining that the third stationary point corresponding to a maximum is located within the second spline segment, assigning the third stationary point as valid and low priority; assigning a peak coordinate and corresponding peak value according to: in response to the second stationary point is valid and there is no valid third stationary point, assigning the peak coordinate equal to the second stationary point and assigning the corresponding peak value equal to evaluating the second spline segment at the peak coordinate; in response to the third stationary point is valid and there is no valid second stationary point, assigning the peak coordinate equal to the third stationary point and assigning the corresponding peak value equal to evaluating the third spline segment at the peak coordinate;

in response to the second stationary point is high priority and the third stationary point is low priority, assigning the peak coordinate equal to the second stationary point and assigning the corresponding peak value equal to evaluating the second spline segment at the peak coordinate;

in response to the third stationary point is high priority and the second stationary point is low priority, assigning the peak coordinate equal to the third stationary point and assigning the corresponding peak force value equal to evaluating the third spline segment at the peak coordinate;

in response to the second and third stationary points are both high priority or both low priority, assigning the peak coordinate equal to whichever of the second and third stationary points corresponds to the larger force value and assigning the corresponding peak force value equal to evaluating the respective spline segment at the peak coordinate.

7. A method according to any one of claims 1 to 3, wherein interpolating the plurality of force values comprises:

obtaining a frequency spectrum by calculating a discrete Fourier transform based on the plurality of force values; generating a zero-inserted frequency spectrum by inserting a plurality of zero values at a high frequency end of the frequency spectrum;

obtaining interpolated force values based on calculating an inverse discrete Fourier transform of the zero-inserted frequency spectrum.

8. A method according to claim 7, wherein estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the one or more candidate peaks comprises, for each candidate peak:

searching for a local maximum of the interpolated force values using the candidate peak as a starting location;

in response to locating a local maximum of the interpolated force values which has not already been assigned to another candidate peak, assigning a peak force value equal to the local maximum and assigning a corresponding peak coordinate equal to a location of the local maximum.

9. A method according to claim 7 or claim 8, further comprising transforming the plurality of force values corresponding to sensor locations to a plurality of transformed force values corresponding to equi-spaced locations, wherein the frequency spectrum is obtained by calculating a discrete Fourier transform of the plurality of transformed force values.

10. A method according to claim 9, wherein the transformation of the plurality of force values to the plurality of transformed force values comprises interpolation based on the pair of sensor locations and force values bracketing each equi-spaced location.

11. A method comprising:

processing a plurality of first force values according to any one of claims 1 to 10, each first force value corresponding to a first sensor location, wherein the first sensor locations are spaced apart along a first direction;

processing a plurality of second force values according to any one of claims 1 to

10, each second force value corresponding to a second sensor location, wherein the second sensor locations are spaced apart along a second direction which is different to the first direction;

wherein peak coordinates estimated based on the first force values are matched with peak coordinates estimated based on the second force values to obtain two- dimensional coordinates.

12. A method according to claim 11, wherein peak force values are estimated based on an average or a weighted average of first peak values determined based on the first force values and second peak values determined based on the second force values.

13. A method of processing signals from a touch panel which comprises a layer of piezoelectric material arranged between a plurality of first electrodes and at least one second electrode, the method comprising:

receiving one or more piezoelectric signals from the first electrodes;

for each piezoelectric signal:

calculating a corrected piezoelectric value by subtracting a first DC offset value from the piezoelectric signal;

determining whether the corrected piezoelectric value exceeds a piezoelectric signal threshold:

in response to a positive determination, setting a force value equal to the sum of a previous force value and the corrected piezoelectric value;

in response to a negative determination, setting the force value equal to the previous force value;

adding the force value to a buffer storing a number of previous force values or adding the corrected piezoelectric value to a buffer storing a number of previous corrected piezoelectric values;

calculating a gradient value, an average value and a variance value of the values stored in the buffer;

determining whether the gradient value is below a gradient threshold and the variance value is below a variance threshold:

in response to a positive determination, updating a second DC offset value to equal to the average value;

in response to a negative determination, not updating the second DC offset value;

calculating a corrected force value based on the force value and the second DC offset value.

14. A method according to any one of claims 1 to 10, wherein the plurality of force values correspond to corrected force values calculated according to claim 13.

15. A method according to claim 11, wherein the plurality of first force values and the plurality of second force values correspond to corrected force values calculated according to claim 13. 16. Apparatus comprising a controller configured to carry out a method according to any one of claims 1 to 15.

17. Apparatus for processing piezoelectric signals received from a touch panel which comprises a layer of piezoelectric material arranged between a plurality of first electrodes and at least one second electrode, the apparatus comprising:

a plurality of first force channels, each first force channel configured to:

receive piezoelectric signals from one or more first electrodes of the touch panel which correspond to first sensor locations which are spaced apart along a first direction;

calculate a first force value corresponding to the received piezoelectric signals;

a location processing module configured to receive the plurality of first force values, and to:

determine whether the plurality of first force values include one or more first candidate peaks, each first candidate peak corresponding to a local maximum of the plurality of first force values;

in response to at least one first candidate peak exceeds a minimum force threshold:

interpolate the plurality of first force values;

estimate a number of first peak coordinates and corresponding first peak force values based on the interpolated first force values and the first candidate peaks which exceed the minimum force threshold.

18. Apparatus according to claim 17, further comprising:

a plurality of second force channels, each second force channel configured to: receive piezoelectric signals from one or more first electrodes of the touch panel which correspond to second sensor locations which are spaced apart along a second direction which is different from the first direction;

calculate a second force value corresponding to the received piezoelectric signals; wherein the location processing module is further configured to receive the plurality of second force values, and to:

calculate a plurality of second force values corresponding to piezoelectric signals which correspond to first electrodes arranged at second sensor locations which are spaced apart along a second direction which is different to the first direction;

determine whether the plurality of second force values include one or more second candidate peaks, each second candidate peak corresponding to a local maximum of the plurality of second force values;

in response to at least one second candidate peak exceeds a minimum force threshold:

interpolate the plurality of second force values;

estimate a number of second peak coordinates and

corresponding second peak force values based on the interpolated second force values and the second candidate peaks which exceed the minimum force threshold;

wherein the location processing module is further configured to match first peak coordinates with second peak coordinates to obtain two-dimensional coordinates. 19. Apparatus according to claim 17 or claim 18, wherein each first or second force channel is configured to calculate the corresponding force values as corrected force values according to claim 13.

20. A system comprising:

apparatus according to any one of claims 17 to 19; and

a touch panel which comprises a layer of piezoelectric material arranged between a plurality of first electrodes and at least one second electrode.

Description:
Force signal processing

Field

The present invention relates to methods of processing signals from a touch panel for force sensing.

Background

Touch screen panels having force-sensing capabilities can enhance user experience through three-dimensional multi-touch interaction.

In a touch panel, drive and sensing electrodes are used for projective capacitive touch detection. To add force-detection capabilities, a piezoelectric layer, an electrode (which may be the drive or sensing electrode) and a counter electrode, which is held at a fixed voltage or ground, are employed. Additional dielectric layers such as PET thin film, adhesives and cover glass may be included to integrate the layers and provide mechanical robustness. Together, the configuration of the layers in the sensor stack defines a sensor architecture.

Examples of touch sensors combining capacitive sensing with piezoelectric based force- detection capabilities are described in WO 2016/102975 A1. This document also describes examples of embedded touch panels (in which electrodes are interspersed with display elements such as polarisers etc), in which a patterned electrode is positioned between a user input surface and the drive and sensing electrodes. Further examples of touch sensors combining capacitive sensing with piezoelectric based force- detection capabilities are described in WO 2017/ 109455 A1.

EP 2 902 886 A1 describes a touch input device including a touch panel, a push amount calculating unit and a touch detection signal generating unit. The touch panel includes a piezoelectric sensor and an electrostatic sensor. The piezoelectric sensor outputs to a push amount calculating unit a push signal corresponding to a displacement amount obtained by pushing an operation surface. The electrostatic sensor outputs touch signals corresponding to a touch and a non-touch, to a touch detection signal generating unit. The touch detection signal generating unit outputs to the push amount calculating unit the touch detection signals binarized according to a touch state and a non-touch state. The push amount calculating unit integrates differences between push signals and a reference potential during a period in which a touch detection signal indicating a touch state is inputted, generates a push amount detection signal and outputs the push amount detection signal. The push amount calculating unit resets a reference potential during a period in which a touch detection signal indicating a non touch state is inputted.

JP 2015/097068 A describes a touch input device including a touch panel having a piezoelectric substance, and a pressure detection part for detecting a static pressure load to the touch panel. The pressure detection part detects the static pressure load on the basis of an integrated value of an electric signal occurring when the piezoelectric substance is pressed.

Touch panels which use piezoelectric based force-detection without a secondary location sensing method (for example resistive or capacitive touch sensing) have been proposed. For example JP 2010-026938 A describes a touch panel which includes a piezoelectric body layer containing a polyvinylidene fluoride-ethylene tetrafluoride copolymer, a first electrode provided on one surface of the piezoelectric body layer, and a second electrode provided on the other surface of the piezoelectric body layer.

Summary

According to a first aspect of the invention, there is provided a method of processing a number of force values. Each force value corresponds to a sensor location. The sensor locations are spaced apart along a direction. The method includes receiving the force values. The method also includes determining whether the force values include one or more candidate peaks. Each candidate peak corresponds to a local maximum of the force values. The method also includes, in response to at least one candidate peak exceeds a minimum force threshold, interpolating the force values and estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the candidate peaks which exceed the minimum force threshold.

The method may also include receiving the sensor locations corresponding to the force values. The method may also include retrieving stored sensor locations corresponding to the force values.

The peak coordinates maybe estimated to a precision which is less than a minimum spacing of the sensor locations. In other words, the estimated peak coordinates may lie between adjacent sensor locations.

The number of peak coordinates and corresponding peak force values estimated maybe less than or equal to the number of candidate peaks.

The method may also include outputting any estimated peak coordinates and the corresponding peak force values.

The method may also include, in response to at least one peak force value exceeds a second force threshold, outputting each peak force value which exceeds the second force threshold and the corresponding peak coordinates.

The method may also include, for each peak coordinate, in response to determining that the peak coordinate is associated with a tracked touch event, adding the peak coordinate to a coordinate buffer which stores a number of previously estimated peak coordinates for the tracked touch event, calculating an average coordinate based on the coordinate buffer and outputting the average coordinate and the peak force value. The method may also include, for each peak coordinate, in response to determining that the peak coordinate is not associated with any tracked touch event, storing the peak coordinate and the corresponding peak force value to a new tracked touch event and outputting the peak coordinate and the corresponding peak force value.

Interpolating the plurality of force values may include calculating a polynomial spline using the plurality of force values. The polynomial spline may be a cubic spline.

Each candidate peak may correspond to a candidate sensor location and a candidate force value. Estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the one or more candidate peaks may include, for each candidate peak, in response to determining that the candidate sensor location is equal to a minimum or maximum sensor location, calculating stationary points of a first spline segment connecting the candidate sensor location and the adjacent sensor location, determining whether a first stationary point corresponding to a maximum is located within the first spline segment, in response to a positive determination, assigning a peak coordinate equal to the first stationary point and assigning a corresponding peak value equal to evaluating the first spline segment at the peak coordinate, and in response to a negative determination, assigning a peak coordinate equal to the candidate sensor location and assigning a corresponding peak value equal to the candidate force value.

Estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the one or more candidate peaks may include, for each candidate peak, in response to determining that the candidate sensor location does not correspond to a minimum or maximum sensor location, calculating stationary points of a second spline segment connecting the candidate sensor location and the adjacent sensor location corresponding to the largest force value, in response to determining that a second stationary point corresponding to a maximum is located within the second spline segment, assigning a peak coordinate equal to the second stationary point and assigning a corresponding peak value equal to evaluating the second spline segment at the peak coordinate, in response to determining that a stationary point corresponding to a maximum is not located within the second spline segment, calculating stationary points of a third spline segment connecting the candidate sensor location and the other adjacent sensor location, in response to determining that a third stationary point corresponding to a maximum is located within the third spline segment, assigning a peak coordinate equal to the third stationary point and assigning a corresponding peak value equal to evaluating the third spline segment at the peak coordinate. Each candidate peak may correspond to a candidate sensor location and a candidate force value. Estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the one or more candidate peaks may include, for each candidate peak, in response to determining that the candidate sensor location corresponds to a minimum or maximum sensor location, calculating stationary points of a first spline segment connecting the candidate sensor location and the adjacent sensor location, determining whether a first stationary point corresponding to a maximum is located within the first spline segment, in response to a positive determination, assigning a peak coordinate equal to the first stationary point and assigning a corresponding peak value equal to evaluating the first spline segment at the peak coordinate, and in response to a negative determination, assigning a peak coordinate equal to the candidate sensor location and assigning a corresponding peak value equal to the candidate force value.

Estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the one or more candidate peaks may include, for each candidate peak, in response to determining that the candidate sensor location does not correspond to a minimum or maximum sensor location, calculating stationary points of a second spline segment connecting the candidate sensor location to one of the adjacent sensor locations and, in response to determining that a second stationary point corresponding to a maximum is located within the second spline segment, assigning the second stationary point as valid and high priority, in response to determining that the second stationary point is located within the third spline segment, assigning the second stationary point as valid and low priority, calculating stationary points of a third spline segment connecting the candidate sensor location to the other adjacent sensor location, in response to determining that a third stationary point corresponding to a maximum is located within the third spline segment, assigning the third stationary point as valid and high priority, and in response to determining that the third stationary point corresponding to a maximum is located within the second spline segment, assigning the third stationary point as valid and low priority. A peak coordinate and a corresponding peak value may be assigned according to, in response to the second stationary point is valid and there is no valid third stationary point, assigning the peak coordinate equal to the second stationary point and assigning the corresponding peak value equal to evaluating the second spline segment at the peak coordinate, in response to the third stationary point is valid and there is no valid second stationary point, assigning the peak coordinate equal to the third stationary point and assigning the corresponding peak value equal to evaluating the third spline segment at the peak coordinate, in response to the second stationary point is high priority and the third stationary point is low priority, assigning the peak coordinate equal to the second stationary point and assigning the corresponding peak value equal to evaluating the second spline segment at the peak coordinate, in response to the third stationary point is high priority and the second stationary point is low priority, assigning the peak coordinate equal to the third stationary point and assigning the corresponding peak force value equal to evaluating the third spline segment at the peak coordinate, and in response to the second and third stationary points are both high priority or both low priority, assigning the peak coordinate equal to whichever of the second and third stationary points corresponds to the larger force value and assigning the corresponding peak force value equal to evaluating the respective spline segment at the peak coordinate.

Interpolating the force values may include obtaining a frequency spectrum by calculating a discrete Fourier transform based on the plurality of force values, generating a zero-inserted frequency spectrum by inserting a number of zero values at a high frequency end of the frequency spectrum, and obtaining interpolated force values based on calculating an inverse discrete Fourier transform of the zero-inserted frequency spectrum.

Obtaining interpolated force values may include calculating the inverse discrete Fourier transform of the zero-inserted frequency spectrum and removing forced-periodicity artefacts. Removing forced-periodicity artefacts from the inverted zero-inserted frequency spectrum may include removing a segment of interpolated force values which are less than a minimum of the force values or a last value of the force values. When a segment of interpolated force values are removed, the remaining interpolated force values may be warped to continuously span the range between minimum and maximum sensor location coordinates. Estimating a number of peak coordinates and corresponding peak force values based on the interpolated force values and the one or more candidate peaks may include, for each candidate peak, searching for a local maximum of the interpolated force values using the candidate peak as a starting location, and in response to locating a local maximum of the interpolated force values which has not already been assigned to another candidate peak, assigning a peak force value equal to the local maximum and assigning a corresponding peak coordinate equal to a location of the local maximum.

The method may also include transforming the force values corresponding to sensor locations to transformed force values corresponding to equi-spaced locations, wherein the frequency spectrum is obtained by calculating a discrete Fourier transform of the transformed force values.

The transformation of the force values to the transformed force values may include interpolation based on the pair of sensor locations and force values bracketing each equi-spaced location.

The method may include processing a number first force values and a number of second force values. Each first force value may correspond to a first sensor location. The first sensor locations maybe spaced apart along a first direction. Each second force value may correspond to a second sensor location. The second sensor locations may be spaced apart along a second direction which is different to the first direction. Peak coordinates estimated based on the first force values may be matched with peak coordinates estimated based on the second force values to obtain two-dimensional coordinates. The matching may take account of the corresponding peak force values. Peak force values may be estimated based on an average or a weighted average of first peak values determined based on the first force values and second peak values determined based on the second force values.

According to a second aspect of the invention, there is provided a method of processing signals from a touch panel which includes a layer of piezoelectric material arranged between a plurality of first electrodes and at least one second electrode. The method includes receiving one or more piezoelectric signals from the first electrodes. The method also includes, for each piezoelectric signal, calculating a corrected piezoelectric value by subtracting a first DC offset value from the piezoelectric signal. The method also includes, for each piezoelectric signal, determining whether the corrected piezoelectric value exceeds a piezoelectric signal threshold, in response to a positive determination, setting a force value equal to the sum of a previous force value and the corrected piezoelectric value and in response to a negative determination, setting the force value equal to the previous force value. The method also includes, for each piezoelectric signal, adding the force value to a buffer storing a number of previous force values or adding the corrected piezoelectric value to a buffer storing a number of previous corrected piezoelectric values. The method also includes, for each

piezoelectric signal, calculating a gradient value, an average value and a variance value of the values stored in the buffer. The method also includes, for each piezoelectric signal, determining whether the gradient value is below a gradient threshold and the variance value is below a variance threshold, in response to a positive determination, updating a second DC offset value to equal to the average value and in response to a negative determination, not updating the second DC offset value. The method also includes, for each piezoelectric signal, calculating a corrected force value based on the force value and the second DC offset value.

The second DC offset value may be initialised to zero. The method may include outputting the corrected force value.

When the buffer stores a number of force values, calculating a corrected force value based on the force value and the second DC offset value may comprise subtracting the second DC offset value from the force value.

When the buffer stores a number of corrected piezoelectric values, calculating a corrected force value based on the force value and the second DC offset value may comprise subtracting from the force value a product of the second DC offset value and the number of corrected piezoelectric values stored by the buffer.

When the buffer stores a number of corrected piezoelectric values, calculating a corrected force value based on the force value and the second DC offset value may comprise subtracting each buffered corrected piezoelectric value which exceeds the piezoelectric signal threshold, and adding each difference of a buffered corrected piezoelectric value and the second DC offset which exceeds the second DC offset.

The force values processed by the first aspect may correspond to corrected force values calculated according to the second aspect. The first force values and the second force values processed by the first aspect may correspond to corrected force values calculated according to the second aspect

According to a third aspect of the invention, there is provided apparatus including a controller configured to carry out the method of the first and/ or second aspects.

According to a fourth aspect of the invention, there is provided apparatus for processing piezoelectric signals received from a touch panel which includes a layer of piezoelectric material arranged between a plurality of first electrodes and at least one second electrode. The apparatus includes a number of first force channels. Each first force channel is configured to receive piezoelectric signals from one or more first electrodes of the touch panel which correspond to first sensor locations which are spaced apart along a first direction. Each first force channel is configured to calculate a first force value corresponding to the received piezoelectric signals. The apparatus also includes a location processing module configured to receive the plurality of first force values. The location processing module is also configured to determine whether the first force values include one or more first candidate peaks. Each first candidate peak corresponds to a local maximum of the first force values. The location processing module is also configured to, in response to at least one first candidate peak exceeds a minimum force threshold, interpolate the plurality of first force values, and estimate a number of first peak coordinates and corresponding first peak force values based on the interpolated first force values and the first candidate peaks which exceed the minimum force threshold. The first force channels and the location processing module may be implemented in a single device. The first force channels and the location processing module maybe implemented using one or more micro-controllers or application specific integrated circuits. The apparatus may also include a number of second force channels. Each second force channel may be configured to receive piezoelectric signals from one or more first electrodes of the touch panel which correspond to second sensor locations which are spaced apart along a second direction which is different from the first direction. Each second force channel may be configured to calculate a second force value corresponding to the received piezoelectric signals. The location processing module may be further configured to receive the plurality of second force values. The location processing module may be further configured to calculate second force values corresponding to piezoelectric signals which correspond to first electrodes arranged at second sensor locations which are spaced apart along a second direction which is different to the first direction. The location processing module may be further configured to determine whether the second force values include one or more second candidate peaks. Each second candidate peak may correspond to a local maximum of the second force values. The location processing module may be further configured to, in response to at least one second candidate peak exceeds a minimum force threshold, interpolate the plurality of second force values, and estimate a number of second peak coordinates and corresponding second peak force values based on the interpolated second force values and the second candidate peaks which exceed the minimum force threshold. The location processing module maybe further configured to match first peak coordinates with second peak coordinates to obtain two-dimensional coordinates. The first force channels, the second force channels and the location processing module may be implemented in a single device. The first force channels, the second force channels and the location processing module may be implemented using one or more micro-controllers or application specific integrated circuits. Each first or second force channel may be configured to calculate the corresponding force values as corrected force values according to the second aspect.

A system may include the apparatus and a touch panel. The touch panel may include a layer of piezoelectric material arranged between a number of first electrodes and at least one second electrode.

Brief Description of the Drawings

Certain embodiments of the present invention will now be described, by way of example, with reference to the accompanying drawings, in which:

Figure 1 is a schematic cross section of a touch panel for piezoelectric sensing;

Figure 2 schematically illustrates a system for piezoelectric sensing;

Figure 3 schematically illustrates a force profile of a user interaction with a touch panel; Figure 4 illustrates an idealised piezoelectric signal corresponding to the force profile shown in Figure 3;

Figure 5 presents an example of a measured piezoelectric signal;

Figure 6 schematically illustrates a force signal processing module;

Figure 7 is a process-flow diagram of a method of calculating force values from corresponding piezoelectric signals;

Figure 8 is a process-flow diagram of a method of determining user interaction locations;

Figure 9 is a process flow diagram of a method of determining a number of candidate peaks;

Figure 10 is a process flow diagram of a method of generating and/or updating force information;

Figure 11 is a process-flow diagram of a first method of interpolating force values and estimating peaks;

Figure 12 is a process-flow diagram of a second method of interpolating force values and estimating peaks;

Figure 13 is a process-flow diagram of a third method of interpolating force values and estimating peaks;

Figure 14 illustrates a method of calculating transformed force values corresponding to equi-spaced locations;

Figure 15 illustrates a frequency spectrum;

Figure 16 illustrates zero-insertion into the frequency spectrum shown in Figure 15; Figure 17 schematically illustrates an example of interpolated force values;

Figure 18 schematically illustrates an example of corrected interpolated force values; Figure 19 presents an experimental example of interpolated force values and corrected interpolated force values;

Figure 20 presents a comparison of measured force values to interpolated force values obtained using a cubic polynomial spline;

Figure 21 presents a comparison of measured force values to corrected interpolated force values obtained using a Fourier transform method; and Figure 22 presents a comparison of interpolated force values shown in Figure 20 to corrected interpolated force values shown in Figure 21.

Detailed Description of Certain Embodiments

In the following, like parts are denoted by like reference numerals.

A problem which is encountered in piezoelectric force sensing is that the signals generated by applying force to a piezoelectric material are inherently transient.

Consequently, output signals from piezoelectric force sensors require processing to allow measurements of static or slowly varying applied forces. The methods of the present specification are concerned with improving the accuracy and reliability of forces measured using a piezoelectric based touch panel system, whilst maintaining or improving the speed of processing the piezoelectric force signals received from the touch panel. The present specification is also concerned with improving measurements of static or slowly varying applied forces without relying on a secondary measurement method such as capacitance sensing for detecting the presence and/or location(s) of one or more user interactions.

Touch panel system

Referring to Figure 1, a simplified cross-section of a piezoelectric touch panel 1 is shown.

The touch panel 1 includes first and second layer structures 2, 3, a common electrode 4, a number of first sensing electrodes 5 and a number of second sensing electrodes 6.

The first layer structure 2 has a first face 7 and a second, opposite, face 8. The first layer structure 2 includes one or more layers, including at least a layer of piezoelectric material 9. Each layer included in the first layer structure 2 is generally planar and extends in first and second directions x, y which are perpendicular to a thickness direction z. The one or more layers of the first layer structure 2 are arranged between the first and second faces 7, 8 such that the thickness direction z of each layer of the first layer structure 2 is perpendicular to the first and second faces 7, 8. The first sensing electrodes 5 are disposed on the first face 7 of the first layer structure 2, and the common electrode 4 is disposed on the second face 8 of the first layer structure 2. Preferably, the piezoelectric layer 9 is formed of a piezoelectric polymer, for example a suitable fluoropolymer such as polyvinylidene fluoride (PVDF). However, the piezoelectric layer may alternatively be formed from a layer of a piezoelectric ceramic such as lead zirconate titanate (PZT).

The second layer structure 3 has a third face 10 and a fourth, opposite, face 11. The second layer structure 3 includes one or more dielectric layers 12. Each dielectric layer 12 is generally planar and extends in first and second directions x, y which are perpendicular to a thickness direction z. The one or more dielectric layers 12 of the second layer structure 3 are arranged between the third and fourth faces 10, 11 such that the thickness direction z of each dielectric layer 12 of the second layer structure 3 is perpendicular to the third and fourth faces 10, 11. The second sensing electrodes 6 are disposed on the third face 10 of the second layer structure 3, and the fourth face 11 of the second layer structure 3 contacts the first sensing electrodes 5. Alternatively, the first sensing electrodes 5 may be disposed on the fourth face 11.

Preferably, the dielectric layer(s) 12 include layers of a polymer dielectric material such as polyethylene terephthalate (PET) or layers of pressure sensitive adhesive (PSA) materials. However, the dielectric layer(s) 12 may include layers of a ceramic insulating material such as aluminium oxide.

Preferably, the common electrode 4, the first sensing electrodes 5 and/or the second sensing electrodes 6 are formed of indium tin oxide (ITO) or indium zinc oxide (IZO). However, the common electrode 4, the first sensing electrodes 5 and/or the second sensing electrodes 6 may be formed of conductive polymers such as polyaniline, polythiphene, polypyrrole or poly(3,4-ethylenedioxythiophene) polystyrene sulfonate (PEDOT/PSS). The common electrode 4, the first sensing electrodes 5 and/or the second sensing electrodes 6 may take the form of metal films such as aluminium, copper, silver or other metals suitable for deposition and patterning as a thin film. The common electrode 4, the first sensing electrodes 5 and/or the second sensing electrodes 6 may be formed from a metal mesh, nanowires, optionally silver nanowires, graphene, or carbon nanotubes.

Although the examples described in this specification relate primarily to methods for piezoelectric force sensing, the touch panel 1 may optionally be used for capacitance measurements in addition to piezoelectric force sensing. For example, to measure the self-capacitance of each first electrode 5 and each second electrode 6, or to measure mutual capacitances between a pair of a first electrode 5 and a second electrode 6.

Referring also to Figure 2, a force sensing system 13 is shown.

The force sensing system 13 includes a touch panel 1, a measurement front end 14, and a force signal processing module 15. Optionally, in some examples the system 13 may also include a capacitive signal processing module 16. The first sensing electrodes 5 each extend in the first direction x and the first sensing electrodes 5 are disposed in an array evenly spaced in the second direction y. The second sensing electrodes 6 each extend in the second direction y and the second sensing electrodes 6 are disposed in an array evenly spaced in the first direction x. The common electrode 4 is extensive such that the common electrode 4 at least partially underlies each of the first and second sensing electrodes 5, 6. The common electrode 4 maybe substantially coextensive with the second face 8 of the first layer structure 2.

When the optional capacitive signal processing module 16 is included, each intersection 17 of a first sensing electrode 5 with a second sensing electrode 6 may effectively provide a separate touch sensor for mutual capacitance sensing.

The touch panel 1 may be bonded overlying a display (not shown) of an electronic device (not shown) which incorporates the force sensing system 13. For example, the force sensing system 13 maybe incorporated into a mobile telephone, a tablet computer, a portable or laptop computer, a display, a television, and so forth.

Herein, the term“user interaction” will generally refer to a user pressing a touch panel 1 or a layer of material overlying the touch panel 1. A user interaction may involve a user's digit or a stylus (whether conductive or not). A user interaction will generally be understood as involving a user pressing the touch panel 1 with sufficient force to cause straining of the layer of piezoelectric material 9 and a detectable piezoelectric response. The location of a user interaction may change with time as a user moves a digit or stylus. The touch panel 1 and system 13 support the measurement and tracking of one or more concurrent user interactions, sometimes referred to as“multi-touch” interactions. When the optional capacitive signal processing module 16 is included, a user interaction may additionally include a user's digit or conductive stylus being proximate to the touch panel l without direct physical contact or without applying significant force.

The measurement front end 14 performs piezoelectric force measurements on the touch panel 1. The measurement front end 14 measures forces by detecting the voltages induced between the first sensing electrodes 5 and the common electrode 4 by straining of the piezoelectric layer 9 in response to one or more user interactions. The measurement front end 14 also measures voltages induced between the second sensing electrodes 6 and the common electrode 4. In this way, the measurement front end 14 may provide two-dimensional resolved measurements of forces applied to the touch panel 1 by one or more user interactions. When the optional capacitive signal processing module 16 is included, the

measurement front end 14 may also measure mutual capacitances for each intersection 17 of the first and second sensing electrodes 5, 6.

When the optional capacitive signal processing module 16 is included, the

measurement front end 14 may measure piezoelectric force signals and capacitances concurrently. For example, the measurement front end 14 maybe configured as described in WO 2017/109455 A1, or as described in WO 2016/102975 A2, and the entire contents of both documents are hereby incorporated by reference. In particular, suitable combined force and capacitance touch panel systems 13 are shown in, and described with reference to, Figures 4 to 23 of WO 2017/ 109455 A1. Furthermore, suitable combined force and capacitance touch panel systems 13 are shown in, and described with reference to, Figures 15 to 29 of WO 2016/102975 A2.

The measurement front end 14 outputs piezoelectric signals 18. The piezoelectric signals 18 correspond to amplified and/ or integrated piezoelectric voltages induced between the first sensing electrodes 5 and the common electrode 4 and/or between the second sensing electrodes 6 and the common electrode 4. The measurement front end 14 may include a low-frequency cut-off filter configured to reject a pyroelectric response of the layer of piezoelectric material 9. The low frequency cut-off may take a value between 1 Hz and 7 Hz. The measurement front end 14 may include a notch filter configured to reject a mains power distribution frequency, for example, 50 Hz or 60 Hz. When the optional capacitive signal processing module 16 is included, the

measurement front end 14 may also output capacitance signals 19. When the measurement front end 14 is configured to measure piezoelectric signals and capacitances concurrently, for example, when the measurement front end 14 is configured as described in WO 2017/109455 A1 or as described in WO 2016/102975 A2, the piezoelectric signals 18 and capacitance signals 19 are obtained by frequency separation of signals corresponding to each sensing electrode 5, 6 to obtain the signals 18, 19.

When the optional capacitive signal processing module 16 is included, the capacitive signal processing module 16 receives and processes the capacitance signals 19 to determine capacitance information 20, which may include a number of user

interactions and the x-y coordinates of each user interaction. The capacitive signal processing module 16 may function in the same way as a conventional capacitive touch controller, and may be provided by a conventional capacitive touch controller. In some examples, the capacitive signal processing module 16 also provides driving signals for the capacitance measurements to the measurement front end 14. The self-capacitances of the sensing electrodes 5, 6, or the mutual capacitances between any pair of a first sensing electrode 5 and a second sensing electrode 6, may be measured by the capacitive signal processing module 16 according to known methods.

The force signal processing module 15 receives the piezoelectric signals 18. The force signal processing module 15 is configured to measure, using the piezoelectric signals 18, one or more output forces F corresponding to user interactions applying force to the touch panel 1. The calculation of output forces F does not depend upon input of the capacitance information 20 or the unprocessed capacitance signals 19. The force signal processing module 15 is configured to analyse the measured output forces F in order to determine force information 21 which includes the number of user interactions, the x-y coordinates of each user interaction and also a force applied by each user interaction.

When the optional capacitive signal processing module 16 is included, the force signal processing module 15 may also receive the capacitance information 20, which may be useful for confirming the force information 21. Although the first and second sensing electrodes 5, 6 have been shown as being substantially rectangular, any other electrode shapes or patterns known for use in projected capacitance touch panels maybe used. For example, diamond patterned electrodes maybe used for the first and second sensing electrodes 5, 6.

The first layer structure 2 of the touch panel 1 may include only the layer of piezoelectric material 9, such that the first and second opposite faces 7, 8 are faces of the piezoelectric material layer 9. Alternatively, the first layer structure 2 may include one or more dielectric layers 12 which are stacked between the layer of piezoelectric material 9 and the first face 7 of the first layer structure 2. The first layer structure 2 may include one or more dielectric layers 12 stacked between the second face 8 of the first layer structure 2 and the layer of piezoelectric material 9.

The second layer structure 3 may include a single dielectric layer 12, such that the third and fourth opposite faces 10, 11 are faces of a single dielectric layer 12. Alternatively, a second layer structure 3 need not be used, and the second sensing electrodes 6 could instead be disposed on the first face 7 along with the first sensing electrodes 5.

In Figures 1 and 2, the first and second faces 7, 8 and the layers of the first and second layer structures 2, 3 are shown extending along orthogonal axes labelled x and y, and the thickness direction of each layer of the first and second layer structures 2, 3 is aligned with an axis labelled z which is orthogonal to the x and y axes. However, the first, second and thickness directions x, y, z need not form a right handed orthogonal set as shown. For example, the first and second directions x, y may intersect at an angle of 30 degrees or 45 degrees or any other angle greater than o degrees and less than 90 degrees.

The details of the touch panel 1 and system 13 described hereinbefore, and further details discussed with reference to WO 2017/ 109455 A1 and WO 2016/102975 A2 are provided for the purposed of understanding the methods of the present specification, but the methods of the present specification are not limited to the touch panel 1 and system 13. The methods of the present specification may be employed with any touch panel system which includes an array of piezoelectric sensors. Referring also to Figure 3 a schematic force input 22 applied to the touch panel 1 is shown. The layer of piezoelectric material 9 is poled and becomes polarised with a polarisation P in response to straining caused by a user interaction applying force to the touch panel 1. The polarisation P of the layer of piezoelectric material 9 results in a corresponding charge Q piezo (t ) being developed between the common electrode 4 and the sensing electrodes 5, 6. The straining which produces the polarisation P may result from a compression or a tension. The straining which produces the polarisation P may be an in-plane stretching of the piezoelectric material layer 9. Intimate contact between the layer of piezoelectric material 9 and the sensing electrodes 5, 6 is not required.

Generally, a greater straining of the layer of piezoelectric material 9 (caused by a more forceful user interaction) will result in a greater polarisation P, and a correspondingly larger magnitude of charge Q piezo (t ) being induced on proximate sensing electrodes 5, 6. A piezoelectric response I piezo (t), which is the current associated with the charge Q piezo (t ), maybe amplified and/or integrated to determine a piezoelectric signal 18.

Referring also to Figure 4, an idealised piezoelectric signal 23 corresponding to the force input 22 is shown.

Piezoelectric signal 23 represents an idealised example of a piezoelectric signal 18. A piezoelectric signal 18, 23, for example as output from and/ or amplified by the measurement front end 14, is a transient signal. The induced piezoelectric voltages decay with time due to leakage currents. Moreover, the output of an integrating charge amplifier, which may be used to amplify a piezoelectric current I piezo , also decays with time.

For example, during a first loading period, t 0 £ t £ t 1 , the force 22 increases steadily from zero to a first force value F 1 . Provided that the rate of increase of the force 22 is fast compared to the rate of decay of the piezoelectric signal 23, the corresponding piezoelectric signal 23 decreases steadily during the first loading period t 0 £ t £ t 1 , reaching a first peak value of V 1 as the force 22 reaches the first force value F,. The force 22 is held constant at F, for a first holding period, t 1 < t £ t 2 . During the first holding period, t 1 < t £ t 2 , the piezoelectric signal 23 decays upwards from the first peak value V 1 towards, in the ideal case, zero DC offset. The force 22 increases again from the first force value F, 1 to a second force value F 2 during a second loading period t 2 < t £ t 3 . Provided that the rate of increase of the force 22 is fast compared to the rate of decay of the piezoelectric signal 23, the corresponding piezoelectric signal 23 decreases steadily during the second loading period t 2 < t £ t 3 , reaching a second peak value of V 2 as the force 22 reaches the second force value F 2 .

The force 22 is then held constant at F 2 for a second holding period, t 3 < t £ t 4 . During the second holding period, t 3 < t £ t 4 , the piezoelectric signal 23 decays upwards from the second peak value V 2 towards, in the ideal case, zero signal.

At the end of the second holding period, t 3 < t £ t 4 , the user interactions ends with the release of the force 22 during an unloading period t 4 < t £ t 5 . Provided that the rate of decrease of the force 22 is fast compared to the rate of decay of the piezoelectric signal

23, the corresponding piezoelectric signal 23 increases steadily during the unloading period t 4 < t £ t 5 , reaching a third peak value V 3 , as the force 22 reaches zero. The third peak value V 3 , resulting from unloading rather than loading, has opposite sign to the first and second peak values V 1 , V 2 . After the end of the user interaction, the piezoelectric signal 23 decays towards, in the ideal case, zero DC offset.

Although Figure 4 illustrates the piezoelectric signal 23 becoming negative in response to loading and positive in response to unloading, the polarity of the piezoelectric signal

23 maybe reversed in other examples, depending on the configuration of the touch panel 1 and system 13.

When the piezoelectric signal 23 is ideal, as illustrated in Figure 4, the decay of the piezoelectric signal 23 may be compensated for by various methods such as, for example, simple conditional integration of the piezoelectric signal 23 based on the gradient and/ or values of the piezoelectric signal 23. By integrating the piezoelectric signal 23 when the gradient and value of the piezoelectric signal 23 have the same sign, an estimated measurement proportional to the applied force 22 may be recovered.

However, when a touch panel 1 and system 13 for combined force and capacitance measurements is used in practice, piezoelectric signals 23 may be subjected to variations in DC offsets and significant sources of noise which may prevent the reliable operation of simple value and gradient based conditional integrations.

Without wishing to be limited by theory or particular, specific, examples, it may be helpful for understanding the present specification to discuss potential sources of DC offset variations and noise for a touch panel 1 and system 13. The touch panel 1 and system 13 may often be installed in a handheld, battery operated device (not shown). Such devices are typically ungrounded, or only weakly grounded, which may increase the susceptibility to noise pickup and to variation in DC offsets. Additionally, a user may frequently become charged with static electricity as a result of interactions between their clothing, footwear and/ or their environment. This may further contribute to variations in DC offsets by capacitive coupling, and may also result in electrostatic discharging of the user's digit and/or stylus upon an initial contact with the touch panel 1. Such couplings and/or electrostatic discharges can apply charges Q es to the sensing electrodes 5, 6 close to a user interaction which may equal, or even substantially exceed, charges Q piezo resulting from applied forces. Furthermore, short interactions such as tapping a touch panel 1 in rapid succession may confuse gradient and value based approaches because the signal from one tap may not have completely decayed before the next tap commences, leading to inaccurate measurements of forces. The preceding discussion is not exhaustive, and many additional factors may contribute to DC offset variations and noise levels of a touch panel 1 and system 13. Therefore, there is a need for methods of measuring forces applied to a touch panel 1 with improved reliability, without sacrificing sensitivity and/ or computational speed, and without any requirement to receive capacitance information 20 and/or unprocessed capacitance signals 19.

Example of measured piezoelectric signals

Referring also to Figure 5, an example of a measured piezoelectric signal 24 obtained using an example of the touch panel 1 and system 13 is shown. Measured piezoelectric signal 24 is an example of a piezoelectric signal 18. The measured piezoelectric signal 24 is plotted against the primary vertical axis. It may be observed that the measured piezoelectric signal 24 deviates from the ideal piezoelectric signal 23 in several ways. In particular, the measured piezoelectric signal 24 includes noise, and the DC offset during a sustained user interaction applying a substantially contact load is not zero.

Force values 25, F(t) determined according to a method described hereinafter in relation to Figure 7 are plotted against the secondary vertical axis of Figure 5. The methods detailed in the present specification are intended to address the issues encountered when piezoelectric measurements are implemented in practice, by providing methods to measure forces applied to a touch panel l which are more robust against variations in DC offsets and other sources of noise. The methods detailed in the present specification also permit force values to be used to determine the locations of user interactions. In this way, a force sensing touch system 13 maybe used to determine a number of user interactions, as well as the location and applied force of each user interaction, without a need for input of capacitance information 20 or unprocessed capacitance signals 19. This may provide an improved touch panel system which is less complex than a touch panel system which uses a combination of capacitive and piezoelectric measurements to provide location and force information. At the same time, the methods detailed in the present specification may be efficiently executed by a controller, application specific integrated circuit (ASIC), microcontroller or microprocessor at a speed which is sufficient to avoid introducing excessive latency which might be perceptible by a user. Excessive latency may be annoying to a user or, if the latency becomes too large, it may cause providing correct input to become difficult or impossible.

Although touch panel systems based on piezoelectric measurements only have been proposed, such systems have not been widely adopted for use as touch panels. This is believed to be because of the hereinbefore discussed difficulties in obtaining reliable measurements of static or slowly varying forces within a challenging noise

environment, and also because of the difficulty of determining accurate user interaction locations from piezoelectric measurements. The methods of the present specification may provide improvements in measurement of force values F and also in determining the coordinates of one or more user interactions.

Force signal processing module

Referring also to Figure 6, one example configuration of a force signal processing module 15 is shown. The force signal processing module 15 includes a number of force channels 26 and a location processing module 27. Each force channel 26 receives a piezoelectric signal 18 from the front end module 14, and calculates a force value F corresponding to the received piezoelectric signal 18. The force values F may be calculated as described hereinafter with reference to Figure 7. Each piezoelectric signal 18 may correspond to a single first or second electrode 5, 6. Alternatively, a piezoelectric signal 18 may correspond to a group of two or more adjacent first electrodes 5 or a group of two or more adjacent second electrodes 6. A first group 28 of force channels 26 receives and processes piezoelectric signals 18 originating from the first electrodes 5 and a second group 29 of force channels 26 receives and processes piezoelectric signals 18 originating from the second electrodes 6.

Let P(t) denote a time dependent piezoelectric signal 18 in general. Let Pi denote a piezoelectric signal P(t i ) at time t i , and similarly let P i+1 denote a piezoelectric signal P(t i + dt) at time t i + dt , in which St is, for example, a sampling interval. Similarly, let F(t) denote a time dependent force value in general, F i denote a force value F(t i ) at timet i , and similarly let F i+1 denote a force value F(t i + dt) at time t i + dt .

If the measurement front end 14 outputs a number N of piezoelectric signals 18, P(t) corresponding to the first electrodes 5, let Py n (t) denote the n th of N piezoelectric signals 18, P(t). Additionally, let Py n,i denote a piezoelectric signal Py n (t i ) at time t i , and let Py n,i+1 denote a piezoelectric signal Py n (t i + dt) at time t i + dt . Similarly, let Fy n (t) denote the n th of N corresponding force values F(t). Additionally, let Fy n,i denote a force value Fy n (t i ) at time t i , and let Py n,i+1 denote a force value Fy n (t i + dt) at time t i + dt . Let y n denote a sensor location corresponding the n th of N piezoelectric signals Py n,i and the n th of N force values Fy n,i . The sensor location y n may be a centroid of a particular first electrode 5 or a centroid of a group of two or more adjacent first electrodes 5. If the measurement front end 14 outputs a number M of piezoelectric signals 18, P(t) corresponding to the second electrodes 6, let Px m (t) denote the m th of M piezoelectric signals 18, P(t). Additionally, let Px m,i denote a piezoelectric signal Px m (t i ) at time t i , and let Px m,i+i denote a piezoelectric signal Px m (t,+ St) at time t i + dt . Similarly, let Fx m (t) denote the m th of M corresponding force values F(t). Additionally, let Fx m,i denote a force value Fx m (t;) at time U, and let Px m,i+i denote a force value Fx m (t,+ St) at time t i + dt . Let x m denote a sensor location corresponding the m th of M piezoelectric signals Px m,i and the m th of m force values Fx m,i . The sensor location x m may be a centroid of a particular second electrode 6 or a centroid of a group of two or more adjacent second electrodes 6. The location processing module 27 is configured to receive the first electrode 5 force values Fy n,i (also referred to as first force values Fy n, i ) and the second electrode force values Fx m,i (also referred to as second force values Fx m, i . The location processing module 27 processes the first force values Fy n,i and second force values Fx m,i separately. Although processing of the first force values Fy n,i shall be described, the processing of the second force values Fx m,i is the same.

The location processing module 27 analyses the first force values Fy n,i to determine whether the first force values Fy n,i include one or more candidate peaks R 1 , ..., R KC , letting Kc denote a number of candidate peaks and R k denote the k th of Kc candidate peaks. An example of determining candidate peaks R k is further described with reference to Figure 9. Each candidate peak R k corresponds to a local maximum in the first force values Fy n,i , for example maximum F k which is equal to one of the first force values Fy n,i , at a candidate location y k which is equal to one of the sensor locations y„. For brevity, let R k = {y k , F * k } denote the pair of values corresponding to the k th of Kc candidate peaks.

Where there is a need to distinguish between candidate peaks R k calculated for the first and second force values Fy n,i , Fx m, i let the notation Ry k = {y k , Fy * k } denote the k th of a number Kyc of candidate peaks determined for the first force values Fy n,i . Similarly, let Rx k = {x k , Fx * k } denote the k th of a number Kxc of candidate peaks determined for the second force values Fx m, .

Provided that at least one of the candidate peaks R k exceeds a minimum force threshold F thresh , i.e. Fk > F thresh , the first force values Fy n,i are interpolated to estimate

interpolated force values G corresponding to coordinates y other than the first sensor locations y n . Depending on the nature of interpolation used, the interpolated force values G may correspond to one or more continuous functions of position, for example G(y). Alternatively, the interpolated force values G may take the form of a number Nint of discrete values G 1 , ..., G n , ... G Nint corresponding to interpolated locations yint , ..., yint n , ..., yint Nint which are more closely spaced than the original sensor locations y n .

Where there is a need to distinguish between interpolated force values G for the first and second force values Fy n,i , Fx m, i let Gy denote the interpolated force values for the first force values Fy n,i , and let Gx denote the interpolated force values for the second force values Fx m, . i Location processing module 27 analyses the interpolated force values G and the candidate peaks R k to determine whether one or more peaks H 1 ,..., H K is (or are) present, with K denoting a total number of peaks found and H k denoting the k th of K peaks. Each peak H k includes a peak coordinate yp k and a corresponding peak force value Fp k . For brevity, let H k = { yp k , Fp k } denote the pair of values corresponding to the k th of K candidate peaks. In general, the number K of peaks may be less than or equal to the number Kc of candidate peaks. Where there is a need to distinguish between peaks H for the first and second force values Fy n, , Fx m, i let Hy k = {yp k , Fyp k } denote the pair of values corresponding to the k th of Ky peaks determined for the first force values Fy n,, , and let Hx k = {xp k , Fxp k } denote the pair of values corresponding to the k th of Kx peaks determined for the second force values Fx m, .

In general, the number of peaks determined from first and second force values Fy n,i , Fx m,i should be identical, i.e. Kx = Ky. However, the ordering of peaks Hy k , Hx k corresponding to the same user interaction may differ with respect to the index k. Consequently, the location processing module 27 maybe configured to match peak coordinates yp k estimated based on the first force values Fy n,i with peak coordinates xp k estimated based on the second force values Fx m,i to obtain two-dimensional coordinates ( xp k , yp k ) for a particular user interaction. The matching is preferably based on the peak force values Fyp k , Fxp k and/ or on information about user interactions tracked since an earlier point of time.

The force channels 26 and the location processing module 27 may be implemented by a single device such as, for example, a micro-controller or an application specific integrated circuit. Alternatively, the force channels 26 and the location processing module 27 may be implemented using two or more devices such as micro-controllers, application specific integrated circuits and so forth. In some examples, the force signal processing module 15 and the front end module 14 may be integrated as a single device, for example a micro-controller, an application specific integrated circuit and so forth.

Method of calculating force values

Referring also to Figure 7, a process flow diagram for a method of calculating force values F i from corresponding piezoelectric signals P i , 18 is shown. The method of calculating force values F from corresponding piezoelectric signals P i , 18 maybe carried out by each force channel 26. A piezoelectric signal P i is received (step S1). Optionally, a common mode value P CM , obtained as an average of piezoelectric signals Pi across all channels, may be subtracted from the piezoelectric signal P i at this stage. For example, the measurement front end 14 may measure and output the common mode value P CM to each of the force channels. The received piezoelectric signal P i may be a piezoelectric signal Py n,i corresponding to a first electrode 5 or a piezoelectric signal Px m,i corresponding to a second electrode 6.

A corrected piezoelectric value Pc i = Pi - P off is calculated by subtracting a first DC offset value P off from the piezoelectric signal Pi (step S2). In some examples the first DC offset P off may be initialised by a calibration routine executed when a device (not shown) incorporating the touch panel 10 is powered on, woken from a sleep mode or is idle for an extended duration. In some examples, the first DC offset P off may be pre- calibrated. In either case, the first DC offset P off may be set based on an average value measured for the piezoelectric signal P(t) during a period in which there are no user interactions. This condition may be easier to confirm for the case of pre-calibration.

However, if the optional capacitive signal processing module 16 is included, capacitance information 20 may be used to confirm the absence of user interactions for the purposes of initialising or re-calibrating the first DC offset. The corrected piezoelectric value Pc i is compared against a piezoelectric signal threshold P thresh (step S3), for example, the condition Pc i > P thresh may be tested.

Alternatively and preferably, the condition | Pc i | > P thresh may be tested. This condition roughly corresponds to testing whether or not the force channel is detecting a user interaction. Strictly, this condition tests whether an applied force is changing.

The piezoelectric signal threshold P thresh may be pre-calibrated, or may be calibrated by a routine executed when a device (not shown) incorporating the touch panel 10 is powered on, woken from a sleep mode or is idle for an extended duration. In some examples, the piezoelectric signal threshold P thresh maybe set to a multiple of between 3 and 5 times a standard error measured for the piezoelectric signal P i during a period in which there are no user interactions. This condition may be easier to confirm for the case of pre-calibration. However, if the optional capacitive signal processing module 16 is included, capacitance information 20 may be used to confirm the absence of user interactions for the purpose calibrating the piezoelectric signal threshold P thresh - If the corrected piezoelectric value Pc i satisfies | Pc i | > P thresh , i.e. if a user interaction is occurring (step S3 |Yes), then the force value F i for the force channel 26 is set equal to the sum of the corrected piezoelectric value Pet and the previous force value F i-1 (step S4). For example, the force value F may be updated as F i = F i-1 + Pc i . The force value F i for each channel 26 may be initialised or re-initialised to zero when a device (not shown) incorporating the touch panel 10 is powered on, woken from a sleep mode or is idle for an extended duration. The force value F for each channel 26 may also be re- initialised to zero when a particular event is detected such as, for example, detecting the end of a user interaction when the user removes an applied force, in response to being idle for an extended duration, and so forth.

If the corrected piezoelectric value Pc i does not satisfy | Pc i | > P thresh , i.e. if | Pc i | < P thresh and a user interaction is not occurring (step S 3 INo), then the force value F for the channel is set equal to the previous force value F i-1 (step S5), i.e. F i = F i-1 . This has the effect of holding the channel force value F constant whilst the piezoelectric signal P i (or preferably its magnitude | P i | ) is below the piezoelectric signal threshold P thresh -

A linear regression analysis is performed on a buffer { F i-Nbuff+1 ,..., F -1 , F i } which stores the most recent channel force value F and a number Nbuff-1 of previous channel force values F i-Nbuff+1 ,..., F -2 , F i-1 (step S6) . For example, the force value F is added to the front of a buffer { F i-Nbuff ,..., F -2 , F i-1 and displaces the oldest measurement F i-Nbuff , and the regression analysis is then performed on the updated buffer { F i-Nbuff+1 ,..., F -1 , F i }. The regression analysis determines a gradient an offset d F in the form of an average of the buffered force values { F i-Nbuff+1 ,..., F -2 , F i-1 , F i }, and a variance s 2F . Alternatively, instead of storing force values { F i-Nbuff+1 ,..., F -1 , F i }, the buffer may store Nbuff previous values of the processed piezoelectric values { Pc i-Nbuff+1 ,... Pc i-1 , Pc i }, and the linear regression analysis (step S6) may be conducted on the values of the processed piezoelectric signal Pc i to determine a gradient , offset dPc, and variance s 2 Pc in terms of the processed piezoelectric signal Pc. The gradient is compared against a pre-calibrated gradient threshold DF and the variance s 2 F is compared against a pre-calibrated variance threshold s 2 thresh (step S 7 ). Both conditions < DF and s 2 F < s 2 thresh must be met. This situation is taken as corresponding to inactivity of the force channel 26.

The dual condition for inactivity may permit distinction of an idle period during which both the gradient / and the variance s 2 F are low, from an active period during which a user interaction applies a relatively consistent force. The inventors have discovered that when a user attempts to apply a consistent force to the touch panel, although the gradient of the buffer { F i-Nbuff+1 ,..., F i-1 , F i } may be relatively low, the variance s 2 F of the buffer { F i-Nbuff+1 ,..., F i-1 , F i } remains relatively high. Without wishing to be bound by theory, it is speculated that the relatively high variance s 2 F during such periods may result from humans being unable to apply truly static force, resulting in continuous small changes in the applied force. The gradient threshold DF and the variance threshold s 2 thresh may be calibrated based on values of the gradient / and the variance s 2 F obtained during a period in which there are no user interactions.

Alternatively, when the buffer stores corrected piezoelectric values { Pc i - Nbuff+1 ,..., Pc i-1 , Pc i } instead of force values { F i-Nbuff+1 ,..., F i-1 , F i }, the test for inactivity (step S7) may be performed in terms of the corrected piezoelectric values Pc i by comparing the gradient against a pre-calibrated gradient threshold DP and comparing the variance s 2 Pc against a pre-calibrated variance threshold sp 2 thresh -

If the buffer { F i-Nbuff+1 ,..., F i-1 , F i } is determined to correspond to an idle period (step S7I Yes), then a second DC offset value F off is updated to be equal to the offset dF (step S8). Alternatively, when the buffer stores corrected piezoelectric values { Pc i - Nbuff+1 ,..., Pc i-1 , Pc i } instead of force values { F i-Nbuff+1 ,..., F i-1 , F i }, then the second DC offset value P off2 is expressed in terms of corrected piezoelectric values Pc i , and is updated to be equal to the offset d P. The second DC offset value F off , P off2 is initialised to zero when a device (not shown) incorporating the touch panel 10 is powered on.

If the buffer { F i-Nbuff+1 ,..., F i-1 , F i } is determined to correspond to an active period (step S7INo), then the second DC offset value F off , P off2 is not updated. A corrected force value Fc; is computed based on the force value F and the second DC offset value F off , P off2 then output (step S9). For example, the corrected force value Fc i may be output to the location processing module 27. In this way, the calculation of corrected force values Fc; may take account of drift in the DC offset of each force channel 26 over time. The corrected force value Fci may be computed according to Fc i = F i - F off , by subtracting the second DC offset in terms of force F off from the force value F i .

Alternatively, when the buffer stores corrected piezoelectric values { Pc i - Nbuff+1 ,..., Pc i-1 , Pc i } instead of force values { F i-Nbuff+1 ,..., F -1 , F i }, the corrected force value Fc i may be computed according to Fc i = F i - Nbuff×P off2 , by subtracting the product of the buffer size Nbuff and the second DC offset in terms of corrected piezoelectric signal P off2 from the force value F.

In a further alternative, the calculation of the corrected force value Fc; using the second DC offset in terms of corrected piezoelectric signal P off2 may be carried out in a more robust way by:

1. Subtracting each buffered corrected piezoelectric signal value { Pc i - Nbuff+1 ,..., Pc i-1 ,, Pc i } which satisfies | Pc i | > P thresh from the force value F i and

2. Adding each buffered corrected piezoelectric signal value { Pc i - Nbuff+1 ,..., Pc i-1 , Pc i } which satisfies |Pc i - P off2 | > P thresh to the force value F i .

Whilst the touch panel 10 remains in use (step S10), the calculation repeats starting with reception of the next piezoelectric signal Pi+i (step Si).

Although the method of calculating force values has been described in the context of the system 13 and in terms of providing corrected force values Fc; to the location processing module 27, the method of calculating force values described hereinbefore may be used in any piezoelectric touch panel in order to calculate corrected force values Fc; based on transient piezoelectric signal P i inputs. For example, the method of calculating force values may be used to calculate corrected force values Fc i ; for combined force and capacitance measurement devices as described in WO 2017/109455 A1 or WO

2016/102975 A2. It will be appreciated that whilst the corrected force values Fc; are proportional to a force applied to the touch panel 10, conversion to an actual force value in Newtons (or equivalent units) requires use of one or more calibration coefficients. In general, force channels 26 corresponding to different sensor locations y n , x m may experience different piezoelectric signal P i , 18 magnitudes in response to identical forces applied directly over said sensor locations y n , x m . This results from bending behaviour of the touch panel 10 stack-up, in combination with the boundary conditions and/ or support of the touch panel 10 within a device (not shown). Calibration coefficients maybe determined in advance for each force channel 26, for example, by applying known forces at known locations on the touch panel 10. The force channels 26 may include such pre-calibrated geometric effects in the calculation of the output corrected force values Fci.

Alternatively, correction of force values F for pre-calibrated geometric effects may be deferred to the location processing module 27. This may allow more precisely estimated peak coordinates xp k , yp k to be used when determining which calibration coefficients to use.

Method of determining user interaction locations

Referring also to Figure 8, a process-flow diagram of a method of determining user interaction locations is shown. The method of determining user interaction locations may be carried out based on force values F i , Fy n i , Fx m,i which are corrected force values Fc i calculated according to the method of calculating force values described with reference to Figure 7. However, this is not essential and the method of determining user interaction locations may be carried out based on force values Fy n i , Fx m, , F i or corrected force values Fc i calculated according to any suitable method. The method of determining user interaction locations will be described in the context of the location processing module 27.

However, the method of determining user interaction locations may also be carried out by any suitable apparatus which receives force values F corresponding to sensor locations x m , y n spaced in one or more directions.

Force values Fy n i , ..., Fy N i , Fx 1 i , Fx M,i are received (step S11). Each force value Fy n i , Fx m,i corresponds to a sensor location y n , x m . For example, the force values Fy 1 i , ..., Fy N i , Fy 1 i , ..., FX M,i may be received from the first and second groups 28, 29 of force channels 26 of the system 13. The force values Fy n i , ..., Fy N i , Fx 1,i , ..., Fx M,i are analysed to determine whether the force values Fy n i , ..., Fy N i , Fx 1,i , ..., Fx M,i include one or more candidate peaks R k (step S12). Force values Fy n i , ..., Fy N i corresponding to the first electrodes 5 are processed to determine a first set of Kyc candidate peaks Ry k = { y k , Fy * }, and force values Fx 1 i ,, ..., FX M,i corresponding to the second electrodes 6 are processed to determine a second set of Kxc candidate peaks Rx k = {x k , Fx * }. Any suitable peak-finding method may be used to determine candidate peaks Ry k , Rx k , and one example is further described hereinafter (see Figure 9). The numbers of candidate peaks Kyc, Kxc maybe zero, in other words, there are not necessarily any candidate peaks Ry k , Rx k -

In other words, the process of determining candidate peaks (step S12) corresponds to performing rough identification of the locations of one or more user interactions, with a precision equal to the spacing between sensor locations x m , y n . The location processing module 27 tests whether any candidate peaks R k exceed a minimum force threshold F thresh (step S13). Any candidate peaks R k which do not exceed the minimum force threshold are removed from the listing of candidate peaks R k . The test is conducted separately for the first force values Fy n,i and second force values Fx m i , and different thresholds Fy thresh and Fx thresh may be used for the first force values Fy n,i and the second force values Fx m,i respectively. For example, the first candidate peaks Ry k may be tested according to the condition Fy * > Fy thresh , and the second candidate peaks Rx k may be tested according to the condition Fx k > Fx thresh -

When processing two-axis force data such as the first and second force values Fy n,i , Fx m,i , the location processing module 27 may enforce equal numbers Kyx, Kxc of candidate peaks Ry k , Rx k . For example, if there are either Kyc = o first peaks Ry k or Kxc = o second peaks Rx k after the removal of below threshold F thresh , Fy thresh , Fx thresh candidate peaks Ry k , Rx k (step S13INo), then the method returns to obtain the next force values Fy n,i+i , Fx m,i+i (step S11).

If there are different numbers Kyx, Kxc of candidate peaks Ry k , Rx k after the removal of below threshold F thresh , Fy thresh , Fx thresh candidate peaks Ry k , Rx k (step Si3|Yes), then the location processing module 27 may, in order from smallest to largest candidate peak value Fp * , remove first or second candidate peaks Ry k , Rx k as necessary until the numbers Kyx, Kxc of candidate peaks Ry k , Rx k are equal Kyx=Kxc. For example, if there were Kyc= 4 first candidate peaks Ry k which satisfy Fy * > Fy thresh , and Kxc= 2 second candidate peaks Rx k which satisfy Fx * > Fx thresh , the location processing module 27 may remove the two first candidate peaks Ry k having the lowest candidate peak values Fy * k In some examples, each force channel 26 may have a separately calibrated minimum force threshold. For example, for the first candidate peaks Ry k = {y k , Fy * k }, each candidate peak value Fy * k maybe compared to a minimum force threshold Fy thresh , (y / d which is a function of the corresponding candidate location y. Similar position dependent minimum force threshold Fx thresh (x k ) may be employed for assessing the second candidate peaks Rx k = {x k , Fx * }.

The threshold F thresh or position dependent thresholds F thresh (x k ), F thresh (y k ) maybe determined from calibration experiments, for example, based on a multiple between three and five times a standard error measured for the corresponding force channel(s) during a period in which there are no user interactions.

If at least one candidate peak R k satisfies the minimum force condition (step S13|Yes), then interpolated force values G are determined based on the corresponding force values F i , and it is estimated whether any peaks H k are present based on the

interpolated force values G and the candidate peaks R k (step S14). The number K of peaks H k found may be less than or equal to the number Kc of input candidate peaks R k , and it is possible for the number K of peaks H k to be zero. Each peak H k includes a peak coordinate yp k , xp k and a corresponding peak force value Fp k . In theory, the number K of peaks H k , is limited only by the resolution (spacing) of the first and/ or second electrodes 5, 6. In practice, the number K of peaks H may typically be one, two or three. For example, many common input gestures utilise a single digit or two digits. A larger number K of peaks Hk, for example four, five or more may indicate erroneous detections and may be factored into an estimate of the measurement quality. Depending on the nature of interpolation used, the interpolated force values G may correspond to one or more continuous functions of position, for example G(y).

Alternatively, the interpolated force values G may take the form of a number Nint of discrete values G 1 ..., G n , ... G Nint corresponding to interpolated locations yint , ..., yint n , ..., yint Nint which are more closely spaced than the original sensor locations y n . When two-axis data such as the first and second force values Fy n i , Fx m,i , are processed, the location processing module 17 may ensure equal numbers Kyc=Kxc> o of first and second candidate peaks Ry k , Rx k as described hereinbefore (step S13|Yes), before testing for any first peaks Hy k = { yp k , Fyp k } based on first interpolated force values G y and first candidate peaks Ry k , and testing for any second peaks Hx k = { xp k , Fxp k } based on second interpolated force values Gx and second candidate peaks Rx k .

Determining interpolated force values G may be based on calculating a polynomial spline h(y) using the corresponding force values F i . The polynomial spline h(y) is preferably a cubic spline. An example of determining interpolated force values G based on calculating a polynomial spline h(y) is further described hereinafter (Figure 11).

Alternatively, determining interpolated force values G may be based on applying Fourier transform methods to the corresponding force values F i (Figure 13).

The location processing module 27 checks whether any estimated peaks H, Hy k , Hx k correspond to a peak force Fp k , Fyp k , Fxp k which exceeds a registration threshold value F reg (step S15). The registration threshold F reg is larger than the minimum force threshold F thresh and has a different purpose. Whereas the minimum force threshold F thresh is calibrated to exclude noise in the input force values F, Fy n i , Fx m,i ,the registration threshold F reg is set to provide a minimum force, i.e. a minimum signal, before the system 13 registers a user interaction. The registration threshold F reg may be adjustable according to one or more of the intended use of a touch panel 10, user preferences, by an operating system or software being executed by a device (not shown) including the touch panel 10 receiving input from the system 13, and so forth. The registration threshold F reg may behave in a similar way to a“dead-zone” of a steering wheel, joystick or other type of controller peripheral for a computing device.

In some examples, to avoid sudden jumps in the input when the registration threshold F reg is exceeded, the location procession module 27 may subtract the registration threshold F reg from the peak forces Fp k , Fyp k , Fxp k prior to output.

The location processing module 27 does not enforce equal numbers Ky, Kx of peaks Hy k , Hx k at this stage (see S17 and Figure 10). Different registration thresholds Fy reg and Fx reg may be used for the first force values Fy n,i and the second force values Fx m,i respectively. For example, the first peaks Hy k maybe tested according to the condition Fyp k > Fy reg , and the second candidate peaks Rx k maybe tested according to the condition Fxp k > Fx reg . In some examples, each force channel 26 may have a separately adjustable registration threshold. For example, for the first peaks Hy k = { yp k , Fyp k }, each candidate peak value Fypu may be compared to a registration threshold Fy reg (yp k ) which is a function of the corresponding peak location yp k . Similar position dependent registration thresholds Fx reg (xp k ) may be employed for assessing the second peaks Hx k = (xp k , Fxp k }.

Position dependent registration thresholds Fy reg (y), Fx reg (x) may also be adjusted by an operating system or software receiving input from the system 13, for example, to specify two or more distinct input zones on the touch panel 10 surface, each of which may have a different registration threshold F reg set.

If at least one peak H, Hy k , Hx k exceeds the registration threshold value(s) F reg (step Si5|Yes), a global touch flag is set to a value of true (step S16) and force information 21 is generated or updated (step S17). For single axis data, for example if only one set of force values F is processed, the force information 21 may simply include the estimated peaks H k (step S17). Optionally, the location processing module 27 may attempt to assign each peak H to one or more active touch events E 1 , .. ,E j ... ,E Ne , with E j denoting the j th of Ne active touch events. The location processing module 27 may assign peaks H k to active touch events E j based on the proximity of the peak location yp k , xp k to a previously measured coordinate ye j x e j of the touch event E j . If the location processing module 27 is unable to assign a peak H k to an existing active touch event E j , for example because the two are separated by excessive distance, then the location processing module 27 may open a new touch event E j to store the peak H k . Similarly, if an existing active touch event E j , does not have a peak H k assigned to it, then that event E j is deemed to have finished, and removed from a list of active events E j .

Two-axis data, for example processing of first and second force values Fy n i , ... Fy m, ,may simply be handled in the same way as single axis data. However, in some examples the location processing module 27 preferably matches first peaks Hy k with corresponding second peaks Hx k , for example to generate two- dimensional peaks H2 k = {{x2 k , y2 k ), F2 k ), in which y2 k is a first coordinate of the merged peak H2 k , x2 k is a second coordinate of the merged peak H2 k and F2 k is an aggregate peak force for the merged peak H2 k . The first coordinate y2 k may be set equal to the corresponding first peak coordinate yp k . Alternatively, if the location processing module 27 assigns a pair of first and second peaks Hy k , Hx k to an active event E j , then the first coordinate y2 k may be set equal to the an average of the first peak coordinate yp k and one or more previously stored event coordinates ye j . The second coordinate x2 k may be set in the same way as the first coordinate y2 k . The aggregate peak force F2 k may be determined as an average, or weighted average, of the corresponding first and second peak forces Fyp k , Fxp k . Weighting coefficients may be pre-calibrated using known forces applied at known coordinates x, y. Weighting coefficients used to calculate an aggregate peak force F2 k may depend on the coordinates (x2 k , y2 k ) of the merged peak H2 k .

Although under ideal conditions the number Ky of first peaks Hy k would be equal to the number Kx of second peaks Hx k , in practice noise or other unexpected factors may result in unequal numbers Ky, Kx of first and second peaks Hy k , Hx k . The location processing module 27 may optionally enforce equal Ky = Kx numbers of first and second peaks Hy k , Hx k when matching the merged peaks H2 k to active touch events E j and generating merged peaks H2 k .

For example, if the number Ky of first peaks Hy k is Ky= 4 and the number Kx of second peaks Hx k is Kx= 2, then the location processing module 27 may start discarding first peaks Hy k , in order from lowest to highest peak value Fyp k , until only two first peaks Hy k remain. The remaining Ky= 2 first peaks Hy k and Kx= 2 second peaks Hx k maybe matched to generate merged 2D peaks H2 k , and checked for assignment to active touch events E j . One option for matching first and second peaks Hy k , Hx k may be based on relative peak force values Fyp k , Fxp k . For example, if four peaks are Hy 1 = {yp 1 , Fyp 1 }, Hy 2 = {yp 2 , Fyp 2 }, Hx 1 = {xp 1 , Fxp 1 }, Hx 2 = {xp 2 , Fxp 2 }, then if Fyp 1 > Fyp 2 and

Fxp, < Fxp 2 , then a first 2D peak H2 1 would be formed by merging Hy, and Hx 2 and a second 2D peak H2 2 would be formed by merging Hy 2 and Hx 1 Alternatively, if the number K y of first peaks Hy k is Ky= 4 and the number Kx of second peaks Hx k is Kx= 2, then the location processing module 27 may compare each of the first and second peaks Hy k , Hx k against coordinates ( xe j , ye j ) of the active touch events E j , in order to determine which of the first and second peaks Hy k , Hx k correspond to tracked events E j . Any surplus peaks Hy k , Hx k may be discarded. When two peaks, for example two first peaks Hy k are both within a predetermined distance of a tracked event E j , the location processing module 27 may select the larger peak Hy k .

By basing matching of two or more pairs of peaks Hy k , Hx k on comparisons with tracked events E j , ambiguity of touch locations may be avoided. For example, although a user may consider that they are touching two fingers to a touch panel 10

simultaneously, at the scan rate of the touch panel 10 the contact times of the two fingers are likely to be separated by at least one sampling interval. The rates of increasing the applied force may also be dissimilar. By comparing peaks Hy k , Hx k with tracked events E j , an initial touch will open a first event E 1 , and when the second touch is registered, the event E 1 will match with a first peak Hy k and a second peak Hx k , leaving a single pair of first and second peaks Hy k , Hx k to match with one another. This approach may clearly be extended to third or further touch events (although as already noted, more than three user concurrent user interactions maybe uncommon).

Further examples of matching first and second peaks are outlined with reference to Figure 10.

If no peaks H, Hy k , Hx k exceed the registration threshold value(s) F reg (step S15INo), the global touch flag is set to a value of false (step S18). Any currently tracked touch events E j may also by reset/ removed in response to the global touch flag being set to false. In some examples, some or all of the channel 26 force values Fy n,i , Fx m,i may also be reset to zero in response to the global touch flag being set to false.

The force information 21 is output (step S19). The force information 21 may include peaks H k , Hy k , Hx k , merged peaks H2 k and/or active touch events E j . The force information 21 may be output to one or more processors of a device (not shown) incorporating the touch panel 10 or using the touch panel 10 as a peripheral.

Whilst the system 13 remains active (step S20 I Yes), the subsequent force values F i+ , Fy n,i+i , Fx m,i+1 are obtained (step S11). Although the method of determining user interaction locations has been explained primarily with reference to 2-axis data obtained from first and second groups 28, 29 of force channels 26, the method is equally applicable to any sets of 2-axis force values. In some examples, only a single axis of force measurement may be used, and the method of determining user interaction locations is equally applicable to such examples. For instance, the force signal processing module 15 may obtain piezoelectric signals 18 corresponding to only the first electrodes 5 or only the second electrodes 6, providing a single axis of force sensing. Such an example may be used for a slider control, or in combination with two-dimensional capacitance sensing in a system 13 which includes a capacitance signal processing module 16.

Example of determining candidate peaks

Referring also to Figure 9, a process flow diagram for an exemplary method of determining a number of candidate peaks R k , Ry k , Rx k is shown (step S12). However, the method of determining user interaction locations (step S12) may employ any suitable alternative methods for determining candidate peaks.

The method of determining a number of candidate peaks Ry k is described in relation to first force values Fy n,i . However, the method of determining a number of candidate peaks may be applied identically to the second force values Fx m i , or any other set of force values F which correspond to sensor locations spaced along a direction.

The set of first force values { Fy 1.i , ..., Fy n i , ..., Fy N i } is searched to find the maximum value, which is stored to a temporary variable F max , and the corresponding index n is stored to a temporary variable n* where 1£n*£N (step S21). The maximum value F max and the maximum index n* are temporary variables which are internal to the method of determining a number of candidate peaks Ry k . An index n is initialised to the maximum index n* an increment variable INC is initialised to a value of +1, and a peak candidate counter k is set to a value of one (step

S22).

The index n is incremented to a new value by addition of the increment variable INC (step S23). The overall effect of steps S22 and S23 is simply to start scanning the first force values { Fy 1.i , ..., Fy n i , ..., Fy N i } from the location of the maximum value F max . The spatial gradient dFy/ dy of the first force values { Fy 1.i , ..., Fy n i , ..., Fy N i } is determined for the n th of N first force values Fy n,i , and the sign of the gradient dFy/ dy is determined (step S24). The spatial gradient maybe determined using any suitable numerical measure of gradient such as, for example, a forward difference gradient, a backward difference gradient or a central difference gradient. The calculation of the may take account of the sensor locations y„. However, since

only the sign of the gradient is needed, the sensor locations y„ may be omitted from the gradient calculations.

If the gradient is negative (step S24|Yes), the first force value Fy n,i

corresponding to the current index n is stored to another temporary variable F min (step S25). The minimum force value F min keeps track of the lowest first force value Fy n,i seen when scanning away from the maximum force value F max · The new value of F min overwrites any already stored value. The index n is incremented again (step S23) and the gradient condition re-tested (step S24).

If the gradient is zero or positive (step S24INo), the difference between the currently stored maximum and minimum force values F max - F min is compared against a peak shift threshold D peak (step S26). This condition is applied in order to reduce the possibility of noise on the falling edge of a peak being falsely registered as a minimum.

If the difference F max - F min is less than or equal to the peak shift threshold D peak (step S26INo), then a minimum between two peaks has not been found, and the index n is incremented (step S23).

If the difference F max - F min is more than the peak shift threshold D peak (step S26 I Yes), then a minimum between two peaks has been found, and the first force values Fy n,i corresponding to the index values between and including the maximum index n* and the current index n are excluded from further consideration by the method of determining a number of candidate peaks (step S27). For example, the excluded (already analysed) first force values Fy n,i may be removed from the set of first force values { Fy 1 , ..., Fy N i }· Alternatively, a mask vector of length N maybe maintained, holding a value of true (unity) for first force values Fy n,i which are not excluded and a value of false (zero) for excluded first force values Fy n,i . Any other suitable method of tracking the excluded/non-excluded first force values Fy n,i may be used. In some examples, the force values Fx i corresponding to the range between and including n* to n-INC may alternatively be excluded from further consideration, so that the n th force value Fx i is not excluded in step S27.

The value of the increment variable INC is checked for the equality INC = -1 (step S28). Since the increment variable INC is initialised to +1, this condition corresponds to checking whether the gradient scanning (steps S23 to S27) has been carried out in both directions away from the maximum index n*.

If the increment variable INC does not equal -1 (step S28 |No) then the increment variable INC is set to INC = -1 and the minima finding loop (steps S23 to S27) is repeated moving in the other direction (step S29). If the increment variable INC satisfies INC = -1 (step S28 I Yes) then the minima finding loop in both directions is completed, and a peak candidate Ry k = {y k , Fy * } is assigned with candidate location y k = y n * and candidate peak value Fy * = F max (step S30).

If there is any remaining non-excluded data (step S31|Yes), the candidate peak counter k is incremented to k+1 (step S31a) and the maximum value of the remaining non- excluded first force values Fy n,i is found (step S21).

If all data has been excluded (step S31INo), the candidate peaks Ry k are output, and the number Kyc of candidate peaks Ry k is set as the current value of the counter k.

Although not shown in Figure 9 for visual clarity, it will be appreciated that if the index n is incremented (step S23) to a value of n > N or n < 1, the method will move directly to step S28. Method of generating and/ or updating force information

Referring also to Figure 10, a process flow diagram is shown for an exemplary method of generating and/or updating force information 21 (step S17). However, the method of generating and/or updating force information 21 (step S17) may employ any suitable alternative methods for generating and/or updating force information 21. An upper bound index value K tot is determined (step S32). For single axis data H k , the upper bound index value K tot is set equal to the number K of peaks H k , K tot = K.

When first and second peaks Hy k , Hx k are processed, the upper bound index value K t ,, t is set to the smaller of the numbers Ky, Kx, i.e. K tot = min {Ky, Kx}. Additionally, whichever of the first and second peaks Hy k , Hx k has the lower number Ky, Kx is flagged as a primary peak set. For example, if Ky = 2 and Kx = 3, then the first peaks Hy k will be flagged as the primary peaks and the second peaks Hx k as the secondary peaks. This is because the less numerous peak set is less likely to contain an

erroneous/false peak.

The remainder of the method of generating and/or updating force information 21 shall be explained on the assumption that the first peaks Hy k are the primary peak set for two-axis data. However, the method is equivalent if the second peaks Hx k were the primary peak set.

Index k is initialised to k= 1 (step S33).

The k th of K ot peaks H k is checked against zero or more active touch events E j , to determine whether the peak H k corresponds to an already active touch event E j (step

S34)

As previously defined, E j denotes the j th of Ne active touch events, and is associated with stored coordinate ye, (or xe j ) for single axis data, or coordinate ( xe j , ye j ) for two axis data. For the purposes of explaining the method of generating and/or updating force information 21, it shall be helpful to define further properties for each active touch event E j . In particular, active touch events E j may be tracked as a function of time Eft), letting E j t 1 ) be denoted as E and E j t i dt) be denoted as E +1 and so forth. Similarly, the coordinates of event E j at time t j may be denoted (xe j , ye j i ) and so forth.

Each active touch event may be denoted as E = {Fe j,i (xe j , ye j i ) Cbuff j } with Fe i denoting the force value associated with the active touch event E j at time t i and Cbuff j {( (xe j , ye j ,, ..., ( xe j,i-Nbuff2 +i , ye j,i-buff2 +1 )} being a coordinate buffer storing the current coordinate (xe j , ye j i ) of the j th active touch event E j and Nbuff2-1 previous coordinates. For single axis data, only values ye j i or xe j , i will be stored by coordinate buffer Cbuff j . The coordinate buffer Cbuff j maybe omitted in some examples. Consequently, when k th of K tot peaks H k is checked against zero or more active touch events Ej, the check is made against the active touch events from time t-dt, i.e. H k is tested against

For example, the absolute distance between the peak coordinate ypk of the k th peak Hk and the most recent coordinate ye j i-1 may be checked for each of Ne active touch events Denoting the distance between the k th peak and j th active touch event as dj, then for single axis data dj = | yp k - ye j i-1 |. If the distance dj is less than an association threshold dassoc, then the k th peak Hk is assigned as corresponding to the th active touch event. Only one peak H k may be assigned to an active touch event at each time t. The association threshold dassoc may be set or determined during calibrations of a touch panel, and will in general depend on factors including but not limited to the pitch or separation between electrodes, the mechanical support conditions and so forth. The association threshold d assoc may be set based on a typical width, or centre-to- centre distance, for a pair of fingers alongside one another, for example, d assoc = 20 mm.

If two or more distances dj are less than the association threshold dassoc, then the k th peak is assigned to the closest, i.e. the active touch event E i-1 having the lowest value of dj. Alternatively in a case where two or more distances dj are less than the association threshold d assoc , the k th peak may instead be assigned to the active touch event having the event force value Fe j i , closest in value to the peak force Fp k . In other examples, a combination of distances dj and relative force values Fe j i , Fp k may be used to resolve ambiguities when two or more distances dj are less than the association threshold dassoc

If all of the distances dj are greater than or equal to the association threshold dassoc, then the k th peak is not assigned to any active touch event E j (step S34|no). Similarly, if the k th peak cannot be assigned to an active touch event because all touch events E j have already been assigned to other peaks H, then the k th peak is not assigned to any active touch event E j (step S34I no).

For two-axis data, checking associations with active touch events Ej also includes the process of matching first and second peaks Hy k , Hx k to form pairs corresponding to a two-dimensional coordinate of a user interaction. In a first stage, the k th primary peak Hy k is checked against the active touch events in exactly the same way as for single-axis data.

If the k th primary peak Hy k is matched against the active touch event then all of the Kx secondary peaks Hx k2 ( k2 is an index 1≤k2≤Kx) are checked for matching against the j th active touch event E j,i+1 . If a matching secondary peak Hx k2 is found, then the k th primary peak Hy k and k2 th secondary peak Hx k2 are assigned to the active touch event E j,i+1 (step S34|yes). Optionally, the k th primary peak Hy k and k2 th secondary peak Hx k2 may be merged into a 2D peak H2 k . Only one primary peak Hy k and one secondary peak Hx k may be assigned to each touch event E j,i- .

Optionally, a ratio | Fyp k - Fxp k | may also be tested against a pre-calibrated threshold or against a fraction of the primary peak force value Fyp k , and the secondary peak Hx k may be assigned as matching only if the difference | Fyp k - Fxp k | is sufficiently low.

If a matching secondary peak Hx k is not found, then despite the k th primary peak Hy k matching an active touch event E j,i- no assignment is made (step S34INo).

If the k th primary peak Hy k does not match any active events E j , then no assignment is made (step S34INo).

If the k th peak H k (or k th primary peak Hy k ) is not assigned to an active touch event (step S34INo) then a new touch event E j,i is opened and populated (step S35). For example, the number Ne of events is incremented by one, and the Ne1+ th event E Ne+ ,i is populated setting the event force value equal to the peak force value as Fe Ne+ ,i = Fp k , and adding the peak coordinate to the coordinate buffer Cbuff Ne+1 = { yp k }.

When two-axis data is being processed, the k th primary peak Hy k needs to be matched to a secondary peak Hx k before opening the new event E Ne+ ,i · Using the index k2 again to denote the k2 th of Kx secondary peaks Hx k , a peak difference value pd k = I Fyp k - Fxp k2 I is calculated between the k th primary peak Hy k and each secondary peak Hx k . The k2 th secondary peak Hx k2 having the smallest peak difference value pd k is matched to the k th primary peak Hy k . The k2 th secondary peak Hx k2 is removed from the set of secondary peaks Hx available for matching with the primary peaks Hy. Optionally, the calculation of peak difference values pd k2 may be weighted to account for geometry and boundary condition derived differences in responsivities of the first and second electrodes force values Fy n,i , Fx m,i . For example, peak difference values pd k2 may be calculated according to pd k2 = I aFyp k - βFxp k2 I . The coefficients a and β may adjust the force values to be proportional to actual force applied to the touch panel to, and may be pre-calibrated using known forces applied at known locations. In some examples, the weighting coefficients a, β may be functions of peak coordinates, for example peak difference values pd k2 may be calculated according to pd k2 = I a(yp k )Fyp k - β(xp k2 )Fxp k2 I . Using weighted peak difference values pd k2 may enable a more reliable comparison of the relative heights of first and second peak force values Fyp k , Fxp k2 .

Once a pairing of the k th primary peak Hy k with a k2 th secondary peak Hx k2 is established, the Ne+1 th event E Ne+1,i may be populated by setting the event coordinate equal to the peak coordinate ye j,i = yp k , setting the event force value equal to the average of the peak force values as Fe Ne+1,i = 0.5 × ( Fyp k + Fxp k2 ) , and when the coordinate buffer is used, adding the first and second peak coordinates to the coordinate buffer Cbuff Ne+1 = {(xp k2 ,yp k )}.

Optionally, the event force value Fe Ne+1,i may be calculated using the weighting coefficients a, β, according to Fe Ne+1,i = 0.5 ×( aFyp k + βFxp k2 ). In some examples, the weighting coefficients a, β maybe functions of peak coordinates yp k , xp k2 , and the event force value Fe Ne+1,i may be calculated as Fe Ne+1,i = 0.5 ×(a(yp k ) Fyp k + β(xp k )Fxp k2 ).

If the k th peak H k (or k th primary peak Hy k and k th secondary peak Hx k2 ) is assigned to the j th active touch event E j,i+1 (step S34|Yes), the event force value Fe j,i is updated (step S36). For single-axis data, the force value Fey; of the/ 1 ' active touch event is assigned as the k th peak force value Fe j,i = Fp k .

For two-axis data, the event force value Fey; is set equal to the average of the k th first peak force value Fyp k and k2 th second peak force value Fxp k2 peak force value, according to Fe j,i = 0.5 × ( Fyp k + Fxp k2 ) . Optionally, the event force value Fe j,i maybe calculated using the weighting coefficients a, β, as to Fe j,i = 0.5 × ( aFyp k - βFxp k2 . In some examples, the weighting coefficients a, β may be functions of peak coordinates, and the event force value Fe j,i may be calculated as Fey; = 0.5 x(a(yp k) Fyp k +

β(xp 2 )Fxp k2 ). The event coordinate (xe j,i , ye j,i ) is updated (step S37). For single axis data, the k th peak coordinate y is added to the coordinate buffer Cbuff j . If the coordinate buffer Cbuff j is full, then the oldest coordinate ye j,i-buf 2+ is displaced. The event coordinate ye j,i is set equal to an average of the Nbuff2 coordinates stored in the coordinate buffer Cbuff j . In some examples, the coordinate buffer Cbuff j may store a single previous value,

Nbuff2 = 1.

In other examples, instead of an average over the coordinate buffer, the event coordinate ye j,i may be set according to:

In which f is an index and the C f are weighing coefficients, wherein a sum over the weighing coefficients C f evaluates to unity. The values of C f generally decrease with increasing value of the index/, for example reciprocally or exponentially with f. In this way, the more recent coordinates may contribute more significantly to the event coordinate ey j,i than the older coordinates.

Using the coordinate buffer Cbuff j in this way may be helpful because changes in the calculated peak coordinates yp k , xp k2 between sampling intervals t i , t i +dt may be smoothed out, avoiding“jittering” of the user interaction location.

In other examples, the coordinate buffer Cbuff j may not be used, and the event coordinate ye j,i may simply be set equal to the k th peak coordinate yp k .

The processing for two-axis data is the same, except that all the coordinates involved are two-dimensional vectors.

If the index k is not equal to the upper bound index K tot (step S38 |No), the index value is incremented (step S39) and the touch event E j generating or updating process is repeated (steps S34 to S37).

If the index k is not equal to the upper bound index K tot (step S38 |No), the force information 20 is compiled (step S40). Any events E j which have not been assigned a peak H k (or a pair of first and second peaks Hy k , Hx k ) are removed from the listing of events E j For two-axis data, any unmatched secondary peaks Hx k may also be removed. The force information 21 is compiled, and includes the updated and/or newly created active touch events E j,i . Optionally, the force information 21 may also include the peaks H k , Hy k , Hx k and/ or the received force values Fy n,i , Fy m,i .

Method using polynomial splines

Referring also to Figure 11, a process-flow diagram of a first exemplary method of interpolating force values and estimating peaks H is shown (step S14). However, the method of interpolating force values and estimating peaks H (step S14) may employ any suitable alternative methods for generating and/or updating force information 21.

The first method of interpolating force values and estimating peaks H will be explained with reference to the first force values Fy n,i and the corresponding sensor locations y„ and candidate peaks Ry k = {y k , Fy * }. However, the first method of interpolating force values and estimating peaks H is equally applicable to the second force values Fx m,i or any other set of force values F i corresponding to sensor locations spaced apart along a direction. A polynomial spline h(y) is calculated for the force values Fy n,i and corresponding sensor locations y n (step S41). The interpolated force values G(y) are equivalent to the polynomial spline G(y) = h(y). The polynomial spline h(y) is composed of a number N-1 of spline segments h n (y). The n th of N-1 spline segments h n (y) connects the n th force value Fy n,i at the n th sensor location y„ to the n+i th force value Fy n+1,i at the n+ 1 th sensor location y n+1 . Calculation of the polynomial spline h(y) is conventional, with continuity enforced between adjacent spline segments h n ( y ) and h n+1 (y ) and, depending on the degree of the polynomial spline, also enforcing continuity of one or more derivatives of the adjacent spline segments h n (y) and h n+1 (y). A cubic polynomial spline h(y) is preferred, because the quadratic roots of the first derivative have closed form solutions which enable efficient calculation of stationary points. However, lower or higher order polynomial splines h(y) may be used depending on the application and the available computational resources for finding stationary points of the spline segments h n (y). The list of candidate peaks Ry k determined previously (step S12, steps S41 to S62) is retrieved, and the number Ky c of candidate peaks Ry k is determined or retrieved (step

S42). An index value k is set to k= 1, corresponding to the first of Ky c candidate peaks Ry k (step S43).

Check if the k th candidate peak Ry k corresponds to an edge channel (step S44). This corresponds to checking whether y k = y 1 or y k = y N .

It the k th candidate peak Ry k corresponds to an edge channel (step S44|Yes), then stationary points S n are calculated for the spline segment h n (y ) connecting the candidate sensor location y k and the adjacent sensor location y n , followed by determining those stationary points S n which correspond to maxima (step S45). If y k = y 1 the stationary points S 1 of the spline segment h 1 (y) are calculated, whereas if y k = y N the stationary points S 1 of the spline segment h N-1 (y) are calculated.

The stationary points S n of the n th of N- 1 spline segments h n (y) may be denoted as S n = {s n,1 , ... , s n,r , ..., s n , Ndeg-1 }, with Ndeg denoting the degree of the polynomial spline h(y) and r an index with 1 £ r £ Ndeg. In practice, Ndeg is at least quadratic, i.e. Ndeg=2.

In the preferred example of a cubic spline h(y), Ndeg = 3 and S n = {s n,1 s n,2 } (s n, = s n,2 for an inflexion point). In the specific example of a cubic spline, the stationary points s n,1 , s n,2 may be determined using the closed form quadratic equation. Stationary points S n of higher degree Ndeg >3 polynomial splines h n (y) may need to be solved using numerical root-finding methods.

It should be noted that although each spline segment h n (y) is only used to define a portion of the overall polynomial spline h(y), the equation for each spline segment h n (y ) may be solved to find the stationary points S n (roots), even though said stationary points S n may lie outside of the range y n to y n+1 over which the spline segment h n (y ) defines the polynomial spline h(y).

The discussion of the following processes of the method of interpolating force values and estimating peaks H will assume for brevity that the polynomial spline h(y) is cubic ( Ndeg = 3). However, the method of interpolating force values and estimating peaks H may be extended to polynomial spline h(y) of greater or lesser degree Ndeg than cubic. Which of the stationary points S n = { s n,i , s„ .2 ) is the maximum is determined, for example based on the sign of the second derivative of the equation for the spline segment h n (y). Inflection points (or undulation points depending on degree), with the second derivative equal to zero, are considered unlikely in practice and if such stationary points occur, these are ignored for the purposes of finding peaks. For the purposes of this description, assume that the stationary point s n,i denotes the maximum of the equation for the n th cubic spline segment h n (y). The validity of the calculated maximum s n,i is checked (step S46). If the maximum s n,1 lies within the range for which the corresponding spline segment h n (y) defines the polynomial spline h(y), then the maximum s n,1 corresponds to a valid peak (step S46 Yes). For example, if y k = y 1 then the maximum s n 1 must satisfy y 1 ≤ s 1,1 < y 2 in order to be valid. Similarly, if y k = y N-1 then the maximum s N,1 must satisfy

y N-1 ≤S N ≤y N in order to be valid. This condition corresponds to finding a maximum s n,i which lies on the polynomial spline h(y). A maximum s n,1 outside the range over which the segment h n (y ) defines the polynomial spline h(y) does not actually occur on the polynomial spline h(y). If the calculated maximum s n,i is valid (step S46 Yes), then a k th peak Hy k = { yp k , Fyp k } is set by assigning the peak coordinate yp k equal to the maximum s n,i and assigning the peak force Fyp k equal to the value of the spline segment h n s n,1 at the maximum (step S47). For edge channels, n may take the values 1 or N-1. If the calculated maximum s n,i is not valid (step S46 |No), then a k th peak Hy k = { yp k , Fyp k } is set by assigning the peak coordinate yp k equal to the candidate coordinate y k and assigning the peak force Fyp k equal to the candidate force value Fy* k (step S48).

It the k th candidate peak Ry k does not correspond to an edge channel (step S44INo), then stationary points S n are calculated for the spline segment h n (y) connecting the candidate sensor location y k and an adjacent sensor location y n corresponding to the largest force value, followed by determining the maximum s n,1 (step S49).

For example, if y k =y n , then if Fy n+1,i > Fy n-1,i the stationary points S n for the spline segment h n (y ) are calculated, whereas if Fy n+1,i < Fy n-1,i the stationary points S n-1 for the spline segment h n l (y ) are calculated. The calculation of stationary points S n is the same as described hereinbefore (step S45) for an edge channel. The corresponding maximum s n,1 or s n-1,1 is determined from the stationary points S n or S n-1 as described hereinbefore.

The calculated maximum s n,1 or s n-1,1 is tested for validity (S50). The calculated maximum s n,1 or s n-1,1 is valid if it lies within the range over which the corresponding spline segment h n (y ) or h n l (y ) defines the polynomial spline h(y), and invalid otherwise. This is the same condition applied to maxima S 1,1 , S N,1 calculated for an edge channel (step S46). If the calculated maximum s n,1 or s n-1,1 is valid (step S50 I Yes), then a k th peak Hy k =

{ yp k , Fyp k } is set (step S47). For example, if Fy n+1,i > Fy n-1,i then the k th peak Hy k =

{ yp k , Fyp k } is set by assigning the peak coordinate yp k equal to the maximum s n,1 and assigning the peak force Fyp k equal to the value of the spline segment h n (s n 1 at the maximum. However, if Fy n+1,i < Fy n-1,i then the k th peak Hy k = {yp k , Fyp k } is set by assigning the peak coordinate yp k equal to the maximum s n-1,1 and assigning the peak force Fyp k equal to the value of the spline segment h n-1 ( s n-1,1 ) at the maximum.

If the calculated maximum s n,1 or s n-1,1 is not valid (step S50 |No), then stationary points Sn are calculated for the other spline segment h n (y ) connecting the candidate sensor location y k and the other adjacent sensor location y n , followed by determining the maximum s n-1,1 or s n,1 (step S51).

For example, if Fy n+1,i > Fy n-1,i so that the stationary points S n and maximum s n,1 for the 12 th spline segment h n (y ) were calculated first (step S49), then if the first calculated maximum s n,1 is not valid (step S50 I no), then the stationary points S n-1 and maximum S n-1 , 1 for the n-1 th spline segment h n-1 (y) are calculated second (step S51). Alternatively, if Fy n+1,i < Fy n-1,i so that the stationary points S n-1 and maximum s n-1,1 for the n-1 th spline segment h n l (y ) were calculated first (step S49), then if the first calculated maximum s n- 1 , 1 is not valid (step S501 no), then the stationary points S n and maximum s n,1 for the n th spline segment h n (y ) are calculated second (step S51).

The second calculated maximum, s n-1,1 or s n,1 as appropriate, is checked for validity (step S52). If the second calculated maximum, s n-1,1 or s n,1 , is valid (step S52 I Yes), then the k th peak Hy k = {yp k , Fyp k } is set using the calculated maximum, s n-1,1 or s n,1 (step S47). However, if no valid maximum s n,1 is found in either spline segment h n {y), h n-1 (y ) (step S52INo), then no peak H is assigned, and after incrementing k to k+ 1 (step S53), the k+ 1 th candidate peak Ry k+1 is processed (step S44). If the k th peak Hy k has been set, check whether all candidate peaks Ry k have been processed, i.e. whether k < Kc (step S54). If k<Kc (step S54|Yes), then there are further candidate peaks Ry k to process, and after incrementing k to k+ 1 (step S53), the k+ 1 th candidate peak Ry k+i is processed (step S44). If k≥ Kc (step S54INo), then there are no further candidate peaks Ry k to process.

Second method using polynomial splines

Referring also to Figure 12, a process-flow diagram of a second exemplary method of interpolating force values and estimating peaks H is shown (step S14). However, the second exemplary method of interpolating force values and estimating peaks H (step S14) may employ any suitable alternative methods for generating and/or updating force information 21.

The second exemplary method of interpolating force values and estimating peaks H will be explained with reference to the first force values Fy n,i and the corresponding sensor locations y n and candidate peaks Ry k = { y k , Fy * k }. However, the second exemplary method of interpolating force values and estimating peaks H is equally applicable to the second force values FX m,i or any other set of force values F i corresponding to sensor locations spaced apart along a direction.

For brevity, the second exemplary method of interpolating force values and estimating peaks H will be explained with reference to a cubic polynomial spline h(y) and taking the stationary point s n,1 to correspond to the maximum of the n th of N- 1 spline segments h n (y).

The second exemplary method of interpolating force values and estimating peaks H is identical to the first method for processing edge channels (steps S41 to S48).

The difference occurs if the k th candidate peak Ry k does not correspond to an edge channel (step S44INo). Stationary points S n and corresponding maxima s n,1 are calculated for both spline segments h n (y ) connecting to the candidate location y k (steps S55 and S56). For example, if the candidate location y k corresponds to the n th sensor location y k =y n , then first stationary points S n-1 and a corresponding first maximum s n-1,1 are calculated for a first spline segment h n-1 ( y ) connecting the sensor locations y n-1 and y n (step S55).

Additionally, second stationary points S n and a corresponding second maximum s n,1 are calculated for a second spline segment h n (y ) connecting the sensor locations y n and y n+1 (step S56). The validity of the first and second maxima s n-1,1 , s n,1 are tested (step S57). Compared to the first method (steps S50, S52), the second method determines validity of the first and second maxima s n-1,1 , s n,1 according to different criteria.

In particular, if the first maximum s n-1,1 lies within the range y n-1 ≤ s n-1,1 < y n of the first spline segment h n-1 (y), then the first maximum s n-1,1 is assigned as valid and flagged as high priority. However, if the first maximum s n-1,1 lies within the range y n ≤ s n-1,1 < y n+1 of the second spline segment h n (y), then the first maximum s n-1,1 is still assigned as valid, but is flagged as low priority. If the first maximum s n-1,1 lies outside the range of the first and second spline segments h n-1 (y), h n (y), i.e. if s n-1,1 < y n-1 or y n 1 s n-1,1 , then the first maximum s n-1,1 is assigned as invalid.

Similarly, if the second maximum s n,1 lies within the range y n ≤ s n,1 < y n 1 of the second spline segment h n (y), then the second maximum s n,1 is assigned as valid and flagged as high priority. However, if the second maximum s n,1 lies within the range y n-1 ≤ s n,1 < y n of the first spline segment h n-1 (y), then the second maximum s n,1 is still assigned as valid, but is flagged as low priority. If the second maximum s n,1 lies outside the range of the first and second spline segments h n-1 (y), h n (y), i.e. if s n,1 < y n-1 or y n 1 < s n-1 , then the second maximum s n,1 is assigned as invalid. If both of the first and second maxima s n-1,1 , s n,1 are invalid (step S57INo), then no peak Hy k is assigned, the index k is incremented to k+ 1 (step S53) and the next candidate peak Ry k is considered (step S44).

If the first maximum s n-1,1 is valid (step S57I Yes) and the second maximum s n,1 is invalid (step S58I Yes), then the k th peak Hy k is assigned based on the first maximum Sn- 1 , 1 (step S59). If both maxima s n-1,1 , s n,1 are valid (step S57|Yes) and the first maximum s n-1,1 is high priority whilst the second maximum s n,1 is low priority (step S58|Yes), then the k th peak Hy k is assigned based on the first maximum s n-1,1 (step S59).

If the second maximum s n,1 is valid (step S57I Yes) and the first maximum s n-1,1 is invalid (step S58 |No, step S60| Yes), then the k th peak Hy k is assigned based on the second maximum s n,1 (step S61). If both maxima s n-1,1 , s n,1 are valid (step S57|Yes) and the second maximum s n,1 is high priority whilst the first maximum s n-1,1 is low priority (step S58INo, step S60|Yes), then the k th peak Hy k is assigned based on the second maximum s n,1 (step S61).

If both maxima s n-1,1 , s n,1 are valid (step S57|Yes) and both maxima s n-1,1 , s n,1 have equal priority (step S58INo, step S6o|No), then the k th peak Hy k is assigned based on whichever of the first or second maxima s n-1,1 , s n,1 corresponds to the largest value of the polynomial spline h(s n-1,1 ), h( s n-1 ).

Method using Fourier transforms

Referring also to Figure 13, a process-flow diagram of a third exemplary method of interpolating force values and estimating peaks H is shown (step S14). However, the method of interpolating force values and estimating peaks H (step S14) may employ any suitable alternative methods for generating and/or updating force information 21. The third exemplary method of interpolating force values and estimating peaks H will be explained with reference to the first force values Fy n,i and the corresponding sensor locations y n and candidate peaks Ry k = {y k , Fy * k }. However, the third exemplary method of interpolating force values and estimating peaks H is equally applicable to the second force values Fx m,i , or any other set of force values F, corresponding to sensor locations spaced apart along a direction.

If the sensor locations y n are not equally spaced, then the force values Fy n,i and corresponding sensor locations y n are shifted to equi-spaced locations y' n and transformed force values Fy' n,i (step S63). This process may be omitted if sensor locations y n are approximately equally spaced. Referring also to Figure 14, an exemplary method of calculating transformed force values Fy' n,i is described in further detail hereinafter.

Letting Φ n = Φ(ω n ) represent the complex magnitude corresponding to the n th of N frequencies ω n , a frequency spectrum Φ n is obtained by calculating a discrete Fourier transform of the force values Fy n,i or the transformed force values Fy' n,i (step S64). Only half of the values Φ n are unique, up to the Nyquist frequency w nyq , and the remaining frequencies ω n > w nyq correspond to reflected values Φ n . The frequency spectrum Φ n maybe obtained using a fast Fourier transform (FFT) algorithm.

For example, referring also to Figure 15, an array storing the frequency spectrum Φ n is schematically illustrated.

A first block 30 holds unique values of the frequency spectrum Φ n , up to w nyq . A second block 31 holds the same N/ 2 values of the frequency spectrum Φ n , reflected about the Nyquist frequency w nyq . In other words, Φ n1 = Φ n2 for index values n1 < N/ 2 and n2 = N- n 1 .

A zero-inserted frequency spectrum Φzero n is obtained by inserting a number N zero of zeros above the Nyquist frequency w nyq (step S65). The zero-inserted frequency spectrum Φzero n includes a total number Mint = N+Nzero values in total.

For example, referring also to Figure 16, a block of zeros 32 is inserted between the first and second blocks 30, 31.

Interpolated force values G are obtained by calculating an inverse discrete Fourier transform of the zero-inserted frequency spectrum Φzero n (step S66). The

interpolated force values G take the form of a number Nint = N + Nzero of discrete values G 1 , ..., G n , ... G Nint corresponding to interpolated locations yint 1 , ..., yint n , yint Nint which are more closely spaced than the original sensor locations y n . It should be noted that the interpolated locations yint 1 , ..., yint n , yint Nint span the same range as the sensor locations y n such that yint 1 = y 1 and yint Nint = y N .

Forced periodicity artefacts maybe removed from the interpolated force values G (step

S67). Referring also to Figure 17, an example of interpolated force values G, 33 is shown.

The process of obtaining the Fourier transform (step S64), inserting zeros (step S65) and then calculating the inverse Fourier transform (step S66) forces the interpolated force values G to be periodic, which may cause a tail artefact region 34 to be introduced.

Referring also to Figure 18, the tail artefact region 34 may be removed to form truncated interpolated force values G trun , 35. The truncated interpolated force values G trun , 35 are then linearly warped to obtained corrected interpolated force values G cor , 36 spanning the original range of sensor locations y n from y 1 to y N .

Referring also to Figure 19, an experimental example of tail artefact region removal is shown. The experimental data were obtained from an example of a touch panel 10 including N=8 first sensors 5. It may be observed that the interpolated force values 33, G obtained directly from inverting the zero-inserted frequency spectrum Φzero n provide a poor correspondence to the measured force values F , , ..., F , which is believed to be the result of forced periodicity artefacts. The tail artefact region 34 is defined as the region yint tail to yint Nint = y N in which the interpolated force values G drop below the last force value F , i.e. the region in which G < F , . It may be observed that following removal of the tail artefact region 34 and linear warping to span the original region y, to ys, the corrected interpolated force values G cor , 36 provide improved correspondence to the measured force values F , , ..., F , .

In other examples, the tail artefact region 34 may be defined as the region for which the interpolated force values G drop below a minimum force value min{ F , , ..., F , ..., F , }· Referring again to Figure 13 the listing of the Ky c candidate peaks Ry k = {y k , F k } is retrieved (step S68).

An index k is set to k= 1 to start with consideration of the first of Ky c candidate peaks Ryk (step S69). Using the location y k of the k th candidate peak Ry k as a starting point, the interpolated force values G, or preferably the corrected interpolated force values G cor , are searched for a local maximum (step S70). For example, a gradient ascent method may be used based on numerical gradients calculated for the interpolated force values G or corrected interpolated force values G cor . The location of the maximum found may be denoted yintmax, and the corresponding corrected interpolated force values G cor (yint max ).

It should be checked whether the maximum G cor (yint max ) is unique, or whether it has already been found for a previously processed peak candidate Ry k (Step S71). If two candidate peaks Ry k converge to the same calculated coordinate yint max , then the initial detection as separate candidate peaks Ry k was likely erroneous, and only one corresponding peak Hy k should be assigned.

If the calculated coordinate yint max is unique so far (step S71 I Yes), then the k th peak H y k = { yp k , Fyp k } is set by assigning the peak location yp = yintmax and assigning the peak force value Fyp k = G cor (yint max ) (step S72).

If the calculated coordinate yint max has already been found (step S71INo), then a new peak Hy k is not assigned (skip step S72).

If the index k=Kyc (step S73 I Yes) then all candidate peaks Ry k have been processed.

If the index k < Kyc (step S73 |No), then the index k is incremented to k+i and the next candidate peak Ry k is processed (step S70).

Referring again to Figure 14, examples of calculating transformed force values Fy' n,i corresponding to equi-spaced locations y' n are illustrated. However, any suitable alternative method of calculating transformed force values Fy' n,i may be used instead. The example of calculating transformed force values Fy' n,i corresponding to equi-spaced locations y' n will be explained with reference to the first force values Fy n,i and the corresponding sensor locations y„. However, the example of calculating transformed force values Fy' n,i corresponding to equi-spaced locations y' n are equally applicable to the second force values Fx m, , or any other set of force values F corresponding to sensor locations spaced apart along a direction. A transformed force value Fy' n,i corresponding to an equi-spaced location y' n may simply be calculated based on linear interpolation of the bracketing sensor locations y n and corresponding force values Fy n,i . For example, the second transformed force value Fy may be calculated according to:

Similarly, the third, fourth and fifth transformed force values Fy' 3 ,, Fy' 4, , Fy' 5,i may be respectively calculated according to:

Experimental data

Referring also to Figure 20, a comparison of measured force values Fy n,i to interpolated force values G, 37 obtained (Figure 11) in the form of a cubic polynomial spline h(y) is shown.

As would be expected given the nature of a polynomial spline h(y), the interpolated force values G pass through the measured force values Fy n,i . It may be observed that the peaks of the interpolated force values G, corresponding to peaks Hy k , lie between sensor locations y n .

Referring also to Figure 21, a comparison of measured force values Fy n,i to corrected interpolated force values G cor , 38 obtained using the Fourier transform method (Figure 13) is shown.

In particular, a fast Fourier transform method was used to obtain the corrected interpolated force values G cor , 38. It may be observed that the corrected interpolated force values G cor , 38 generally follow the measured force values Fy n,i , although unlike for the cubic spline h(y), 37, the corrected interpolated force values G cor , 38 are not constrained to pass through the corrected interpolated force values G cor , 38.

Referring also the Figure 22, a comparison of the interpolated force values G, 37 in the form of a cubic polynomial spline h(y) and the corrected interpolated force values G cor , 38 obtained using Fourier transform methods is shown.

The results 37, 38 of the two methods are broadly in agreement, although slight differences in the estimated peak locations yp k and peak force values Fyp k may be observed, which are thought to result from the constraint of the polynomial spline h(y) to pass through the originally measured force values Fy n,i .

In general, the polynomial spline h(y) method (Figures 11, 12) maybe relatively faster than the Fourier transform method (Figure 13), especially when a cubic spline h(y ) is used. However, because the corrected interpolated force values G cor , 38 obtained using Fourier transform methods (Figure 13) are not constrained to pass through the originally measured force values Fy n,i , Fourier transform methods (Figure 13) may be less influenced by any noise in the measured force values Fy n,i . Modifications

It will be appreciated that various modifications may be made to the embodiments hereinbefore described. Such modifications may involve equivalent and other features which are already known in the design, manufacture and use of touch panels and component parts thereof and in the processing of signals from touch panels, which may be used instead of, or in addition to, features already described herein. Features of one embodiment may be replaced or supplemented by features of another embodiment.

Although the measurement front end 14, the force signal processing module 15, and the capacitance signal processing module 16 have been illustrated as separate components, in practice some or all of these elements may be provided by a single integrated device such as, for example, a microcontroller or an application specific integrated circuit.

Although the force channels 26 and location processing module 27 maybe provided as separate components, in some examples the force channels 26 and location processing module 27 may be provided by a single integrated device such as, for example, a microcontroller or an application specific integrated circuit. The functions of the force channels 26 and the location processing module 27 may be integrated in a single device with the functions of the measurement front end 14 and/ or the capacitance signal processing module 16. Although claims have been formulated in this application to particular combinations of features, it should be understood that the scope of the disclosure of the present invention also includes any novel features or any novel combination of features disclosed herein either explicitly or implicitly or any generalization thereof, whether or not it relates to the same invention as presently claimed in any claim and whether or not it mitigates any or all of the same technical problems as does the present invention. The applicants hereby give notice that new claims may be formulated to such features and/ or combinations of such features during the prosecution of the present application or of any further application derived therefrom.