The invention relates to touch sensitive devices including touch sensitive screens or panels.
U.S. Pat. No. 4,885,565, U.S. Pat. No. 5,638,060, U.S. Pat. No. 5,977,867, US2002/0075135 describe touch-operated apparatus having tactile feedback for a user when touched. In U.S. Pat. No. 4,885,565 an actuator is provided for imparting motion to the CRT when the actuator is energised to provide tactile feedback. In U.S. Pat. No. 5,638,060, a voltage is applied to a piezo-electric element which forms a switch to vibrate the element to apply a reaction force to a user's finger. In U.S. Pat. No. 5,977,867, a tactile feedback unit generates a mechanical vibration sensed by the user when the touch screen is touched with a finger or a pointer. The amplitude, vibration frequency and pulse length of the mechanical vibration are controlled, with the pulse width being long enough to be felt but short enough to terminate before the next key touch. US2002/0075135 describes the use of a second transducer to provide a pulse in the form of transient spike to simulate a button click.
In each of the prior art documents described above, tactile feedback is provided in response to a discrete touch, of a user's finger or pointer.
According to a first aspect of the invention, there is provided a touch sensitive device configured to operate in a use mode or a calibration mode, the device comprising
The vibration generator may be in the form of a vibrating stylus.
According to another aspect of the invention, there is provided a method of calibrating a touch sensitive device comprising a touch-sensitive screen; a plurality of transducers mounted to the screen and a processor, the method comprising
The vibration in the screen may be generated by a vibrating stylus.
In this way, the touch sensitive device may be self-calibrating, i.e. able to teach itself. This alleviates the need to calculate the signals (particularly the transfer functions) to be fed to each transducer to generate the desired haptic sensation. Calculating the transfer functions is systematic and mathematically exact. However, the calculation process may be laborious, particularly for complex systems which provide haptics sensations simultaneously at more than one location on the screen (i.e. multi-region haptics).
The plurality of transducers may be reciprocal transducers. In this way, the device may take advantage of reciprocity. The general principle of reciprocity may be stated as “if a flow response is caused at an observation point by a potential acting at a source point, the relationship between flow and potential is unchanged if the role of the two points is inversed”. The principle is applied to electromagnetism (Lorentz reciprocity), electrostatics (Green's reciprocity), antenna design and acoustics (Rayleigh-Carson reciprocity theorem). In the present application, reciprocity means that the transfer function from voltage at a transducer to velocity at a test point is the same as the transfer function from force at the test point to current at the transducer. Measuring the velocity at the test point is difficult but measuring the current from a transducer is straightforward.
Some transducers may be non reciprocal or may be partly or wholly reciprocal. If the plurality of transducers are not wholly reciprocal, there is still a known relationship between the forward and inverse transfer functions. Accordingly, the detected vibration may still be used to determine the output signal. However, the process is less straightforward.
The detected vibration may be processed to determine (i.e. by measurement) a transfer function of the input signal, i.e. a function which measures the transfer of force applied at the test position to each transducer. The processing may further comprise inferring the inverse of this transfer function, i.e. the transfer function necessary to produce a pure impulse at the test position from each transducer.
The inferring step may be by direct calculation so that measurement of the transfer function H(f) is followed by inversion to obtain H−1(f). Alternatively, the inferring step may be indirect, e.g. using feedback adaptive filter techniques to implicitly invert H(f). Alternatively, the inferring step may be heuristic, e.g. using parametric equalisation processing, and adjusting the parameters to estimate the inverse transfer function.
Alternatively, the inferring step may be approximated by reversing the measured time responses, which in the frequency domain is equivalent to complex conjugation, thus generating the matched filter response
The resulting inverse transfer functions may be stored for later use by the device, for example in a transfer function matrix with the inverse transfer function for each of the plurality of transducers stored at an associated coordinate in the matrix. The spatial resolution of the transfer function matrix may be increased by interpolating between the calibration test points.
The time-reversed responses may be generated by adding a fixed delay which is at least as long as the duration of the detected signal. The fixed delay may be at least 5 ms, at least 7.5 ms or at least 10 ms. The measured time response may be normalised before filtering, e.g. by dividing by the sum of all measured responses in the frequency domain and then transforming into the time domain, to render the response more spectrally white.
Thus, according to another aspect of the invention, there is provided a method of calibrating a touch sensitive device comprising a touch-sensitive screen; a plurality of vibration transducers coupled to the screen, and a signal processor, the arrangement being such that at least some of the plurality of transducers provide haptic feedback to the screen in response to touch, the method comprising
The time inverted copies may include a fixed delay which is at least as long as the duration of the detected signal. The fixed delay may be at least 5 ms, at least 7.5 ms or at least 10 ms. The detected vibration at each transducer may be normalised before filtering, e.g. by dividing by the sum of all measured responses in the frequency domain and then transforming into the time domain, to render the response more spectrally white.
The desired haptic sensation may be a maximum response at a given test point. Thus, the output signals for each transducer may be in-phase with each other, whereby all the displacements generated by the transducers add up to the maximum displacement at the given test point. It is noted, that at other test points, there may be phase cancellation.
Alternatively, the desired haptic sensation may be a minimum response at a given test point. Thus, the output signals for each transducer may be selected so that the displacements provided at the test position (i.e. so that the appropriate transfer functions) sum to zero. With two transducers, this is achieved by inverting one output signal relative to the other.
The desired haptic sensation may be a maximum at a first test point and a minimum at a second test point. Alternatively, the desired haptic sensation may be a response which is between the minimum or maximum at a given test position, for example, where the responses at multiple test positions are to be taken into account.
The desired haptic sensation may provide the sensation of a button click to a user. Alternatively, a complex haptic signal (in terms of produced displacement and/or acceleration) may be generated to provide additional information to the user. The haptic feedback signal may be associated with a user action or gesture etc. Alternatively, or additionally, the haptic signal may be associated with the response of the touch-sensitive surface in terms of display action or reaction.
The output (i.e. carrier wave) signal may be a sine wave at a single frequency. Alternatively, the carrier wave signal may comprise multiple sine waves covering a range of frequencies or may be a swept (chirp), or may be an FM modulated sine wave or a band-limited noise signal, or the carrier may be modulated by band limited noise.
The touch-sensitive screen may be vibrated by applying a signal comprising multiple pulses or a stream of pulses.
The vibration may include any type of vibration, including bending wave vibration, more specifically resonant bending wave vibration.
The vibration exciter may comprise means for applying a bending wave vibration to the screen face. The vibration exciter may be electro-mechanical.
The exciter may be an electromagnetic exciter. Such exciters are well known in the art e.g. from WO97/09859, WO98/34320 and WO99/13684, belonging to the applicant and incorporated herein by reference. Alternatively, the exciter may be a piezoelectric transducer, a magneto-strictive exciter or a bender or torsional transducer (e.g. of the type taught in WO 00/13464). The exciter may be a distributed mode actuator, as described in WO01/54450, incorporated herein by reference. A plurality of exciters (perhaps of different types) may be selected to operate in a co-ordinated fashion. The or each exciter may be inertial.
The touch surface may be a panel-form member which is a bending wave device, for example, a resonant bending wave device. The touch screen may also be a loudspeaker wherein a second vibration exciter excites vibration which produces an acoustic output. Alternatively, one of the exciters used to provide haptic feedback may also be used to provide an audio signal to drive the touch screen as a loudspeaker. For example, the touch screen may be a resonant bending wave mode loudspeaker as described in International Patent Application WO97/09842 which is incorporated by reference.
Contact on the surface may be detected and/or tracked as described in International patent applications WO 01/48684, WO 03/005292 and/or WO 04/053781 to the present applicant. These International patent applications are here incorporated by reference. Alternatively, other known methods may be used to receive and record or sense such contacts.
The invention further provides processor control code to implement the above-described methods, in particular on a data carrier such as a disk, CD- or DVD-ROM, programmed memory such as read-only memory (firmware), or on a data carrier such as an optical or electrical signal carrier. Code (and/or data) to implement embodiments of the invention may comprise source, object or executable code in a conventional programming language (interpreted or compiled) such as C, or assembly code, code for setting up or controlling an ASIC (Application Specific Integrated Circuit) or FPGA (Field Programmable Gate Array), or code for a hardware description language such as Verilog (Trade Mark) or VHDL (Very High speed integrated circuit Hardware Description Language). As the skilled person will appreciate such code and/or data may be distributed between a plurality of coupled components in communication with one another.
The invention is diagrammatically illustrated, by way of example, in the accompanying drawings in which:—
a shows the time reversal filtered impulse responses in the time taken for the responses to travel from dissimilar positions from a test point to a sensor;
b shows the variation in time of the input impulse responses of
c shows the sum and difference combinations for the normalized outputs of
a shows the variation for two input time reversal filtered impulse responses in the time taken for the responses from similar positions to travel from a test point to a sensor;
b shows the variation in time of the input impulse responses of
c shows the sum and difference combinations for the normalized outputs of
a shows a log-log plot of |force| vs frequency for each channel F and the arithmetic sum FA;
b shows a log-lin plot of each channel of
a to 5d show the impulse response as it varies with time for each of the signal of
a shows the time reversal filters for each of
b shows the time reversal filters of
a to 7c show the output signals at the touch point resulting from of using different snapshot lengths (5 ms, 7.5 ms and 10 ms) to create the time reversal filters;
a to 8c show a variation on the output signals of
The touch-sensitive device has two operational modes, normal use and training mode. In normal use, i.e. when a user is using the screen 14 of the touch-sensitive device 10, the transducers 12 produce the required localized haptic force feedback in response to detected touches on the surface. The method of producing the haptic feedback is not critical to the operation of the device and may be as described in any known techniques. The haptic sensation may be a click to simulate the feel of pressing a button or may be more complex to simulate other sensations, i.e. associated with sliding movements, increasing/decreasing intensity of feeling etc. The more complex sensations may be associated with gestures such as sliding, pitching or rotating fingers on the screen.
In training mode, the stylus 16 is used to inject vibrational signals at specified test points; thus the stylus 16 may be considered to be a “force pencil”. The transducers 12 are used as sensors to detect these input signals. The transducers are thus reciprocal transducers able to work as both output devices to generate excitation signals which create vibration in the screen and as input devices to sense vibration in the screen and convert the vibration into signals to be analysed. It is preferable for all the transducer to be reciprocal devices but it is possible to have a device in which not all transducers are reciprocal; such a device is more complicated.
The system processor 20 generates the signals which are sent to the stylus 16 via the two-way amplifier 24 and receives the signals from the transducers 12. The two-way amplifiers 22 are also connected between the system processor 20 and each transducer 12; one amplifier for each channel, i.e. one amplifier for each transducer. The stylus 16 is also arranged to sense haptic feedback signals in the screen originating from the transducers 12 and to feed the sensed signals to the processor 20 via the two-way amplifier 24.
a shows the variation in time of a time reversal filtered impulse response which is input to the system by the stylus 16 at a test point on the touch sensitive screen and measured at two transducers which are differently spaced from the test point. Both signals are have a sinusoidal nature with amplitude increasing, then decreasing, with time. The first signal h1i shows the signal received at the first transducer. The first signal has a negative peak amplitude at approximately 0.0018 s and a positive peak at approximately 0.002 s. The second signal h2i (as received at the second transducer) has negative and positive peaks in amplitude approximately 0.0005 s after the first signal. The signals reach the location of the transducers at approximately 0.003 s.
b plots the output signals for each transducer which are the results of filtering the input responses of
c. plots the results of combined the outputs of the matched filters in-phase or out-of-phase. The sum of the normalized matched filter responses (i.e. in-phase combination) reinforces the signal at the test point and the difference of the normalized matched filter responses (i.e. out-of-phase combination) results in cancellation at 0.003 s, i.e. at the test point.
a to 3c are generally similar to those of
b plots the results of filtering the input responses of
c. plots the results of combining the outputs of the matched filters in-phase or out-of-phase. If the transducers produce the sum of the normalized matched filter responses (i.e. in-phase combination), the resultant output reinforces the maximum amplitude at the test point. Conversely, the difference of the normalized matched filter responses (i.e. out-of-phase combination) results in cancellation at the test point, i.e. no vibration is produced at the test point.
As explained above, in
a to 9 illustrate an alternative method for creating a matched filter response using a time-reversed impulse response. As shown in
The spectrum of the time-reversed signal is the complex conjugate of the original
original: x(t)−>X(f)
filter: y(t)=x(−t); Y(f)=conj(X(f))
This is approximated by adding a fixed delay, so
z(t)=x(T−t) if t<=T, or z(t)=0 if t>T
When the filter is applied to the signal (ignoring the approximation for now), the phase information is removed, but the amplitude information is reinforced.
y(t)*x(t)−>X(f)×Y(f)=|X(f)|̂2
(In fact, the resulting time response is the autocorrelation function).
As shown in step S212, the filter amplitude may adjusted as described with reference to
a is a log-log plot of |force| vs frequency for each channel (F) (i.e. for four haptics-input vibration transducers) and the arithmetic sum (FA) of these four forces.
a to 5d show each of the four normalised responses transformed into the time domain to give the individual impulse responses (GYtime<i>). These impulse responses have also been normalised by dividing by the peak for each response.
The time reversal filters, TR, are formed by taking a finite snapshot of the impulse responses of
where kmax=samples (length)
b shows the results of convolved the filters with the appropriate impulse responses in the time domain (GYtime) to give the filtered response GYresp. The convolution is expressed as:
As shown in
a to 8c show how the filter amplitudes may be adjusted to maximise or minimise the sum of the four signals at the touch location. There are infinitely many ways of obtaining a zero sum because the system is under determined but there are only three linearly independent (orthogonal) normalised response sets. Any linear sum of these three sets will also produce a zero response. The normalised set for maximising the response is unique. Thus, with four signals, there may be three ways (sig. 0, sig. 1, sig. 2) of getting a 0 sum, and one way (sig. 3) of getting a maximum sum. This is reflected in the eigenvalues of the various matrices. It is noted that the eigenvectors are orthonormal, i.e. E(i)·E(j)=1 if i=j, or 0 otherwise.
a and 8a show the results of using a filter formed using a snapshot of 5 ms;
E:=submatrix(rsort(stack(λT·eigenvecs(M),0),1,4,0,3).
For each of the signals of
Where pwrn is a vector of the summed power in each processed signal n.
The following values are then calculated for each variation:
pwrT, Σ[{right arrow over ((10·log(pwr)))}]T and [{right arrow over ((10·log(pwr)))}]T
Where pwrT is the matrix transpose of pwr and the vector 10·log (pwr) is the same information as pwr but in decibel.
For
pwrT=(0.147 0.081 0.26 1)
Σ[{right arrow over ((10·log(pwr)))}]T=−25.075 [{right arrow over ((10·log(pwr)))}]T=(−8.339−10.894−5.842 0)
The maximised channel power is normalised to 1.0, so the other three values represent how much gets through the minimised channels—so a lower value is better.
For
pwrT=(0.164 0.246 0.071 1)
Σ[{right arrow over ((10·log(pwr)))}]T=−25.453 [{right arrow over ((10·log(pwr)))}]T=(−7.84−6.088−11.495 0)
For
pwrT=(0.172 0.11 0.135 1)
Σ[{right arrow over ((10·log(pwr)))}]T=−25.928 [{right arrow over ((10·log(pwr)))}]T=(−7.636−9.602−8.689 0)
a to 8c use a method of principle component analysis (PCA) which focuses on the total energy in each GY resp.
E:=submatrix(rsort(stack(λT·eigenvecs(M),0),1,4,0,3)
For
pwrT=(0.054 0.104 0.281 1)
Σ[{right arrow over ((10·log(pwr)))}]T=−27.981 [{right arrow over ((10·log(pwr)))}]T=(−12.643−9.828−5.51 0)
For
pwrT=(0.05 0.104 0.325 1)
Σ[{right arrow over ((10·log(pwr)))}]T=−27.702 [{right arrow over ((10·log(pwr)))}]T=(−12.991−9.826−4.885 0)
For
pwrT=(0.043 0.103 0.332 1)
Σ[{right arrow over ((10·log(pwr)))}]T=−28.272 [{right arrow over ((10·log(pwr)))}]T=(−13.631−9.858−4.783 0)
These results show that longer filters are better, but even the short ones do a reasonable job.
Principle component analysis is a method which is suitable for obtaining the best amplitudes at which to drive each channel. There are other equivalent methods.
No doubt many other effective alternatives will occur to the skilled person. It will be understood that the invention is not limited to the described embodiments and encompasses modifications apparent to those skilled in the art lying within the spirit and scope of the claims appended hereto.
Number | Date | Country | Kind |
---|---|---|---|
0906138.3 | Apr 2009 | GB | national |
0912740.8 | Jul 2009 | GB | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/GB2010/050540 | 3/30/2010 | WO | 00 | 11/16/2011 |