Pointer acceleration system modeling

Information

  • Patent Grant
  • 10579166
  • Patent Number
    10,579,166
  • Date Filed
    Thursday, April 5, 2018
    6 years ago
  • Date Issued
    Tuesday, March 3, 2020
    4 years ago
Abstract
The present disclosure describes systems, methods, and apparatuses utilizing pointer acceleration system modeling. In one exemplary method, among others, such a method obtains, a closed loop pointer acceleration system model, in which the closed loop pointer acceleration system model is based on (1) a model describing user pointing motions integrated with (2) a model of pointer acceleration motions under operational conditions; obtains values for system parameters that include pointer acceleration profile parameters and operational condition parameters; and determines a set of pointer trajectories for a given acceleration profile having the pointer acceleration profile parameters and operational condition parameters.
Description
TECHNICAL FIELD

The present disclosure is generally related to implementation of pointer acceleration techniques by pointer input devices.


BACKGROUND

Pointer acceleration is often used in computer mice and other interfaces to increase the range and speed of pointing motions without sacrificing precision during slow movements. However, the effects of pointer acceleration are not yet well understood.





BRIEF DESCRIPTION OF THE DRAWINGS

Many aspects of the present disclosure can be better understood with reference to the following drawings. The components in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the present disclosure. Moreover, in the drawings, like reference numerals designate corresponding parts throughout the several views.



FIG. 1 is a flow chart diagram of an exemplary method for evaluating a pointer acceleration profile in accordance with embodiments of the present disclosure.



FIG. 2 is a block diagram of an exemplary computer that can implement one or more operations specified by the method of FIG. 1.



FIG. 3 depicts a table summarizing scaling function G (acceleration pointer profiles) that can be evaluated by embodiments of the present disclosure.



FIG. 4 is a block diagram representing the integration of a VITE model (representing human pointing dynamics) with a pointing acceleration model of a pointer device in accordance with embodiments of the present disclosure.



FIG. 5 is a plot of a robustly forwarding invariant set of trajectories in accordance with one example of the present disclosure.



FIG. 6a is a plot of a robustly forwarding invariant set of trajectories in accordance with an additional example of the present disclosure.



FIG. 6b is a plot of a perturbation set in accordance with the example of FIG. 6a.



FIG. 7a is a simulation plot of trajectories without delays or perturbations in accordance with one example of the present disclosure,



FIG. 7b is a simulation plot of trajectories with delays or perturbations in accordance with one example of the present disclosure.





DETAILED DESCRIPTION

Aspects of the present disclosure are relevant to designing pointing interfaces. Methods, systems, and apparatuses of the present disclosure use a system perspective and feedback control to analyze the effects of pointer acceleration and optimize the performance of pointer acceleration of pointer devices under varying operational and user conditions, in various embodiments.


Pointing devices such as computer mice, joysticks, and touchpads are commonplace in today's computing and communication systems. Most of these devices use pointer acceleration techniques, which increases the sensitivity of the pointer as the speed of the pointer increases, to improve and speed up basic user interactions. Pointer acceleration helps by adjusting the device's sensitivity based on the user's movement speed, which allows the user to control the pointer with a wider range of speeds and makes the device feel more responsive. However, there has previously been a lack of systematic research in how to design and implement pointer acceleration so it is best for a particular task, interface, and user. Consequently, designers and users must manually tweak pointer acceleration settings in an attempt to reach desired levels of performance and comfort.


Embodiments of the present disclosure can characterize which acceleration profiles will provide a desired level of performance and stability properties under different operating conditions and/or user attributes. For example, by taking a systems perspective of an overall pointing system that includes the pointing device, pointer acceleration, and human user, as opposed to only considering the pointer device itself. The results show how acceleration profiles can affect the robustness of the overall pointing system to delays and disturbances, which can limit performance in many applications. Correspondingly, embodiments of the present disclosure can enable selection of selection of pointer acceleration system parameters that can enhance the performance of pointing devices under realistic operational conditions and/or user attributes, whereas current pointer acceleration methods are limited by heuristic designs that lack of consideration of feedback and robustness. For example, even though pointer acceleration is used widely, there is not yet a consensus on how much or what type of pointer acceleration should be used for a given task or interface. In practice, real implementations of pointer acceleration are usually designed by experimenting with different acceleration profiles without using specific design principles. There are also some disadvantages to pointer acceleration that are not yet completely understood. For instance, pointer acceleration may make it more difficult for the user to predict the motion of the pointer and to reproduce desired motions. This can decrease pointing accuracy and speed and can worsen the user's subjective rating of a device's feel.


However, by better understanding the effects of pointer acceleration and human pointing motion, embodiments of the present disclosure can be an important tool in the design of improved pointer interfaces having enhanced performance characteristics. Such performance enhancements may include improving the speed and precision of various pointing devices, which can lead to the development of improved interfaces and interactions for applications ranging from everyday computer use, to video games, virtual reality, remote control of unmanned underwater or space vehicles, etc.


Some example embodiments are directed to apparatuses and methods for evaluating pointer acceleration parameters within a pointer acceleration system model, in which the closed pointer acceleration model is based on a first model describing user pointing motions integrated with a second model of pointer acceleration motions. Accordingly, exemplary apparatuses and methods of the present disclosure can develop performance constraints for the pointer acceleration system model having the pointer acceleration parameters to converge to a defined stable state.


In the sections that follow, it is shown how a closed loop pointing system is affected by delays and perturbations. Correspondingly, in some embodiments, apparatuses and methods may define a relationship between maximum delay, maximum perturbation set, and a set of pointer trajectories for a given acceleration profile (or scaling function) that describes a defined stable state for the stated operational conditions (e.g., delay and perturbation parameters). Therefore, based on parameters for a given acceleration profile, maximum delay, and maximum perturbation set, the set of pointer trajectories (trajectory set S) for a given acceleration profile can be determined that will not exceed the stated operational conditions. Accordingly, different pointer acceleration profiles and their respective trajectory sets can be determined and evaluated under the same operational conditions.


Next, the flow chart of FIG. 1 shows an exemplary method for evaluating a pointer acceleration profile in accordance with embodiments of the present disclosure. The method 100 of FIG. 1 comprises a computing device 200 (FIG. 2) (or an acquisition module 220 of the same or a different computing device) obtaining (110) a closed loop pointer acceleration system model, in which the closed loop pointer acceleration system model is based on (1) a model describing user pointing motions integrated with (2) a model of pointer acceleration motions under operational conditions. Such operational conditions may be represented as delay and perturbation functions. Further, the computing device 200 (or the acquisition module 220) may obtain (120) values for system parameters that include pointer acceleration profile parameters or values, maximal delay parameters/values, and maximal perturbation parameters/values from a computing data store 290 and/or memory 250 and/or user input 280. The computing device (or a calculation module 230 of the same or a different computing device) may then determine (130) a set of pointer trajectories (trajectory set S) for a given acceleration profile (having the specified pointer acceleration profile parameters) and operational conditions. Then, the computing device, can repeat (140) the above-recited steps for a different set of system parameters defining a different pointer acceleration profile. Further, the computing device can output or present a side-by-side comparison of the resulting trajectory sets for the different pointer acceleration profiles on a display. Also, the computing device (or a simulation module 240) can plot (150) one or more trajectories of the different pointer acceleration profiles on the display.


The acquisition module 220, the calculation module 230, and/or the simulation module 240 can be implemented in software (e.g., firmware), hardware, or a combination thereof. For example, in an exemplary mode, the calculation module 230, among others, is implemented in software, as an executable program, and is executed by a special or general purpose digital computer. An example of a computer that can implement the calculation module 230 of the present disclosure is shown in FIG. 2.


Generally, in terms of hardware architecture, as shown in FIG. 2, the computer 200 includes a processor 210, memory 250, and one or more input and/or output (I/O) devices 230 (or peripherals) that are communicatively coupled via a local interface 240. The local interface 260 can be, for example but not limited to, one or more buses or other wired or wireless connections, as is known in the art. The local interface 260 may have additional elements, which are omitted for simplicity, such as controllers, buffers (caches), drivers, repeaters, and receivers, to enable communications. Further, the local interface may include address, control, and/or data connections to enable appropriate communications among the aforementioned components.


The processor 210 is a hardware device for executing software, particularly that stored in memory 250. The processor 210 can be any custom made or commercially available processor, a central processing unit (CPU), an auxiliary processor among several processors associated with the computer 200, a semiconductor based microprocessor (in the form of a microchip or chip set), a macroprocessor, or generally any device for executing software instructions.


The memory 250 can include any one or combination of volatile memory elements and nonvolatile memory elements. Moreover, the memory 250 may incorporate electronic, magnetic, optical, and/or other types of storage media. Note that the memory 250 can have a distributed architecture, where various components are situated remote from one another, but can be accessed by the processor 210.


The software in memory 250 may include one or more separate programs, each of which comprises an ordered listing of executable instructions for implementing logical functions. In the example of FIG. 2, the software in the memory 250 includes the calculation module 130 in accordance with an exemplary embodiment, among other modules 120, 140, and a suitable operating system (O/S) 270. The operating system 270 essentially controls the execution of other computer programs, such as the calculation module 130, and provides scheduling, input-output control, file and data management, memory management, and communication control and related services.


The I/O devices 280 may include input devices, for example but not limited to, a keyboard, mouse, scanner, microphone, etc. Furthermore, the I/O devices 280 may also include output devices, for example but not limited to, a printer, display, etc. Finally, the I/O devices 280 may further include devices that communicate both inputs and outputs, for instance but not limited to, a modulator/demodulator (modem; for accessing another device, system, or network), a radio frequency (RF) or other transceiver, a telephonic interface, a bridge, a router, etc.


When the computer 200 is in operation, the processor 210 is configured to execute software stored within the memory 250, to communicate data to and from the memory 250, and to generally control operations of the computer 200 pursuant to the software. The calculation module 130 and the O/S 270, in whole or in part, but typically the latter, are read by the processor 210, perhaps buffered within the processor 210, and then executed.


In the following description, various specific details are set forth to describe specific examples presented herein. It should be apparent to one skilled in the art, however, that one or more other examples and/or variations of these examples may be practiced without all the specific details given below. In other instances, well known features have not been described in detail so as not to obscure the description of the examples herein.


As discussed, embodiments of the present disclosure utilize a systems perspective to evaluate pointer acceleration. In one embodiment, such a system model captures most existing implementations of pointer acceleration along with a model representation of human pointing dynamics with feedback delays or perturbations. To represent human pointing dynamics, a vector integration to endpoint (VITE) model is used in various embodiments. This approach is novel in that prior approaches have not represented a closed pointer system (for pointer device and the user) under realistic operational conditions. For example, perturbations can arise from discretization errors and inaccuracies in human perception and control. Embodiments of the present disclosure may also develop state performance bounds for the closed loop system, as related to Fitts Law, in order to find bounds on the allowable perturbations and/or delays that will allow for performance of a pointer device at a desired level. In the sections that follow, methodology of the embodiments of the present disclosure are discussed.


Section 1. Pointer Acceleration Background and Dynamics

Considerable research has shown that humans generate similar motions when reaching and pointing with their arms, laser pointers, mouse pointers, and other devices. The VITE model for pointing can be written as









{





v
.

=

γ


(


-
v

+
ρ
-
u

)









y
.

=



g


(
t
)




[
v
]


d
+









(
1
)








where the gain g(t) is called the go signal, y>0 is an internal system parameter, ρ is the target position of the pointer, u is the feedback of the perceived position of the pointer, y is the true position of the pointer that is specified by the user, and the state ν is called the difference vector. The operator [⋅]d+ is used to switch the pointer motion off when the pointer overshoots its target, and is defined by











[
v
]

d
+

=

{




v
,





if
<
v

,

d
>

0







0
,



otherwise








(
2
)








where d is typically defined as the direction from the pointer to the target at the initial time, so d=ρ(0)−u(0). The notation [ν]d+ extends the original VITE model to allow arbitrary target locations.


One can use the VITE model to describe motion by a person trying to drive the true position y to the target position ρ for the pointer. If there is an overshoot and y passes over the target pointer position, then the human quickly stops, but does not take corrective action to move back closer to the target. The model parameters are adjusted by the human to fit different types of performance objectives, and these parameters can be viewed as being very slowly time varying. In Section 4, we show how a relationship between y and the pointer acceleration scaling function (also referred as a pointer acceleration profile) can ensure that key state performance bounds are met.


Pointer acceleration aims to make the pointer more sensitive at higher speeds than lower speeds. This enables quick and long pointer motions, as well as slow and precise pointer motions. As we will see below, pointer acceleration can make pointer motion less stable in the presence of feedback delays, in addition to making it more difficult for a user to predict pointer motion. Whether or not pointer acceleration improves a user's subjective feel for the pointing interface appears to be a very personal choice. Although many operating systems have some type of pointer acceleration as their default settings, many modem video games that require exact pointer movement do not use any pointer acceleration.


While there are many different pointer acceleration implementations, most can be described by the following model. We view pointer acceleration as a transformation of the user's pointer position output. If ν∈custom charactern is the pointer position specified by the user, then the pointer acceleration output ω satisfies

{dot over (ω)}=G(|{dot over (ν)}|){dot over (ν)}  (3)

where G:custom charactercustom character is a suitable scaling function and |⋅| is the usual Euclidean norm (see Section 2 for notation used in this disclosure). A few popular choices for the scaling function G are summarized in Table I (shown in FIG. 3), including the Linear and Threshold scaling functions. The form of pointer acceleration (3) is in fact pointer velocity scaling, although we use the term pointer acceleration as this language is commonly used in the literature. We can typically approximate the profiles in such a way that G is positive definite and continuously differentiable, which can help us apply Theorem 3 later. A notable exception to the pointer acceleration model (3) involving actual acceleration is the polynomial scaling function Gpolynomial(|{dot over (ν)}|, |{umlaut over (ν)}|)=k1+k2|{dot over (ν)}||{umlaut over (ν)}|, which adjusts sensitivity using both pointer input acceleration and velocity. While we do not consider scaling functions that are a function of pointer input acceleration, we believe that it may be possible to extend our work to them. In practice, most pointing interfaces do not measure pointer velocity directly. Instead, the pointer velocity is computed via discretization for use in the acceleration system. While this is typically not a major issue, the resulting accelerated pointer output can be very irregular when the pointer moves very quickly, or when the scaling is very large. One typically mitigates this by limiting the maximum pointer speed output, but we do not consider this here; however, see Remark 3 for additive uncertainties on ν that can represent discretization errors.


To connect the VITE model (1) with the pointing acceleration model (3), as in FIG. 4, we choose the input u=ω and the output ν=y. In later sections, we consider feedback connections that have delays and perturbations, which may be present in real systems because of limitations in the human operator and computer interface. Choosing the overall state as x=(ω,ν)T=(x1,x2)T, the closed loop pointing dynamics become










x
.

=



[




ω
.






γ
.




]







=



[





G


(



v
.



)




v
.







γ


(


-
v

+
ρ
-
u

)





]







=



[





G


(



y
.



)




y
.







γ


(


-
v

+
ρ
-
ω

)





]







=



[





G


(





g


(
t
)




[
v
]


d
+



)






g


(
t
)




[
v
]


d
+







γ


(


-
v

+
ρ
-
ω

)





]







=




[





G


(





g


(
t
)




[

x
2

]


d
+



)






g


(
t
)




[

x
2

]


d
+







γ


(


-

x
2


+
ρ
-

x
1


)





]

.








For simplicity, we take g to be a constant, which is the most commonly considered case in the literature, and only consider one dimensional pointing dynamics, as most pointing motions are largely constrained to the line between the start and goal pointer position, even when there are additional degrees of freedom. We assume without loss of generality that ρ=0 and x1(0)=ω(0)<0, so d=ρ(0)−u(0)>0, which can always be achieved by a coordinate transformation. The closed loop dynamics are then











x
.

=

[






G
~



(

x
2
+

)




x
2
+







-

γ


(


x
1

+

x
2


)






]


,




(
4
)








where x=(x1,x2)T=(ω,ν)T as defined previously, {tilde over (G)}(⋅)=gG (g⋅), and x2+ denotes the positive part, that is p+=p when p≥0, and p=0 when p<0. The desired equilibrium set is

custom character={x∈custom character2:x1≥0,x2=−x1},  (5)

but see below for more general pointing models with delays, perturbations, and state constraints.


Section 2: Definitions and Notations

In this section, all dimensions are arbitrary, unless indicated. We use the standard classes of comparison function custom character and custom character. Let custom charactercustom charactern. A function α defined on some set custom charactercustom charactern is positive definite with respect to custom character provided that it is zero at all points in custom charactercustom character and positive at all points in custom character\custom character. We use C1 to mean continuously differentiable, and we understand the derivative ƒ′(0) of any function ƒ that is defined on [0,∞) as the right derivative at 0. By piecewise continuity of a function defined on [0,∞), we mean that it is continuous except at finitely many points on each bounded interval. Let custom charactercustom characterm and custom character denote the set of all piecewise continuous locally bounded functions δ: [0,∞)→custom character. For all δ∈custom character and any interval custom character⊆[0,∞), let custom character be the supremum of the restriction of δ to custom character. Set |x|custom character=inf{|x−r|:r∈custom character} for all x∈custom charactern.


Given a constant τ≥0 (representing an input delay) and a set custom charactercustom charactern, let Cin(custom character) be set of all continuous functions x1: [−τ,0]→custom character, which we write as Cin when custom character=custom charactern. We define the operators xt(s)=x(t+s) for all s∈[−τ, 0] and t≥0 and all functions x: [−τ,∞)→custom charactern. Given a function custom character: Cin×custom charactercustom charactern, we call the system {dot over (x)}(t)=custom character(x1,δ(t)) forward complete provided for each xI∈Cin and each δ∈custom character, the corresponding solution x(t, xI, δ) of the system is uniquely defined for all t∈[0,∞). Given a subset custom charactercustom charactern and a forward complete system, we say that custom character is robustly forwardly invariant for the system with perturbations valued in custom character provided x(t, xI, δ)∈custom character for all t≥0, xI∈Cin(custom character), and δ ∈ custom character. We say that custom character is robustly forwardly invariant for the system with the maximal perturbation set custom character provided these two conditions hold: (a) custom character is robustly forwardly invariant for the system with perturbations valued in custom character and (b) for each point δcustom characterm\closure(custom character), there exists an initial function xI∈Cin(custom character) such that the trajectory x(t,xI,δ) of the system for the constant perturbation δ(t)=δ admits a time t>0 such that x(t,xI,δ)∈custom charactern\custom character. Maximality of custom character therefore roughly means that enlarging custom character would allow trajectories to leave custom character. The special case of robust forward invariance where there are no perturbations δ is the standard strong invariance property.


The system is ISS with respect to custom character and custom character on custom character provided (a) custom character contains custom character and is robustly forwardly invariant for the system with perturbations valued in custom character, and (b) there are functions β∈custom character and α∈custom character such that for all solutions x(⋅,xI,δ) of the system for all xI∈Cin(custom character) and for all δ∈custom character, we have |x(t,xI,δ)custom charactercustom character:−τ≤r≤0}, t)+α(|δ|[0,t]) for all t≥0. The special case of ISS where the α(|δ|[0,t]) term is not present in the ISS estimate and custom character has no perturbations δ (i.e., {dot over (x)}(t)=custom character(xt)) is global asymptotic stability (or GAS) to custom character on custom character.


If custom character is robustly forwardly invariant for a system with perturbations valued in custom character and custom charactercustom character, then a function V: Cincustom charactern is an ISS Lyapunov function for the system with respect to custom character and custom character on custom character provided (a) V(xt) is differentiable as a function of t on [0,∞) for all solutions x(⋅) of the system with initial functions xI∈Cin(custom character) and (b) there are class custom character functions α, α, α0, and α1 such that along all trajectories x(t) of the system for all initial functions xI∈Cin(custom character) and for all choices of δ∈custom character, the following hold for all t≥0:custom character≤V(xt)≤custom character:custom character∈[t−τ,t]}) and








d
dt



V


(

x
t

)






-


α
0



(


V
.



(

x
t

)


)



+



α
1



(



δ



[

0
,
t

]


)


.







Standard arguments show that the existence of an ISS Lyapunov function with respect to custom character and custom character on custom character implies the ISS property with respect to custom character and custom character on custom character when no delays are present:and the same can be shown under time delays, by similar: arguments that we omit here.


The special case of an ISS Lyapunov function for systems {dot over (x)}(t)=custom character(xt) without perturbations is a strict Lyapunov function with respect to custom character on custom character. This is a slightly more restrictive definition of strict Lyapunov functions, because α0 is normally allowed to be positive definite with respect to {0}. without necessarily being of class of custom character, but there are techniques for transforming strict Lyapunov functions for cases where α0 is only positive definite into new Lyapunov functions that satisfy our requirements with α0custom character: The existence of a strict Lyapunov function implies GAS to custom character on custom character. Unless indicated, we assume for simplicity in all of what follows that the initial functions xI∈Cin(custom character) are constant.


Section 3. Strict Lyapunov Function

To analyze the effects of time delays and perturbations on the closed loop pointing system with acceleration, we will examine its ISS properties using a strict Lyapunov function that we construct next. See Proposition 1 for ways to construct the function custom character in the following theorem, and see the sections below where we use the ideas from this section to prove results under state constraints and delays to get state performance bounds and robustness results.


Theorem 1


Let γ>0 be a constant, and G: [0,∞)→[0,∞) be locally Lipschitz and positive valued on (0,∞) and satisfy lim infr→∞G(r)>0. Let custom character:custom charactercustom character be a C1 function satisfying:









(
1
)










(
r
)



=


0





for





all





r


0


,


and









(
r
)



>

0





for





all





r

>
0

,







(
2
)









0
r





G
~



(

)









d












(

2
/
γ

)





2



(
r
)







for





all





r


0

,







(
3
)






r



G
~



(
r
)









(
r
)







for





all





r


0

,



and




(
4
)













(
0
)



=
0

,


and





0

<







(
r
)





γ
4






for





all





r

>
0.






Then the function











V
new



(
x
)


=




0

x
2






G
~



(

ζ
+

)




ζ
+


d





ζ


+


γ
2




(


x
1

+

x
2


)

2


-





(

x
2

)




(


x
1

+

x
2


)







(
6
)








satisfies the estimates












1
10





0

x
2






G
~



(

ζ
+

)




ζ
+


d





ζ



+


γ
4




(


x
1

+

x
2


)

2






V
new



(
x
)







0

x
2






G
~



(

ζ
+

)




ζ
+


d





ζ


+




2



(

x
2

)


2

+



γ
+
1

2




(


x
1

+

x
2


)

2







(
7
)








for all x∈custom character2 and












V
.

new



(
x
)






-


γ
2

4





(


x
1

+

x
2


)

2


-


1
2






(

x
2

)





G
~



(

x
2
+

)




x
2
+







(
8
)








along all trajectories of (4), and so is a strict Lyapunov function for (4) with respect to custom character={x∈custom character2: x1≥0,x2=−x1} on custom character=custom character2. Therefore, (4) satisfies GAS with respect to (5) on custom character=custom character2.


Proof


We can expand the first term of (6) and apply Condition (2) as








V
new



(
x
)


=




1
10





0

x
2






G
~



(

ζ
+

)




ζ
+


d





ζ



+


9
10





0

x
2






G
~



(

ζ
+

)




ζ
+


d





ζ



+


γ
2




(


x
1

+

x
2


)

2


-





(

x
2

)




(


x
1

+

x
2


)







1
10





0

x
2






G
~



(

ζ
+

)




ζ
+


d





ζ



+


9

5

γ






2



(

x
2

)



+


γ
2




(


x
1

+

x
2


)

2


-







(

x
2

)




(


x
1

+

x
2


)











where we applied Condition (2) with the choice r=x2 and also need the fact that custom character=0 on (−∞,0) and the lower bound −custom character(x2)(x1+x2)≥−|custom character(x2)(x1+x2)|. By Young's inequality, we also have













(

x
2

)




(


x
1

+

x
2


)








1
γ





2



(

x
2

)



+


γ
4




(


x
1

+

x
2


)

2








for all x∈custom character2. Combining the preceding two inequalities gives the lower bound in (7). The upper bound in (7) follows by using the triangle inequality −custom character(x2)(x1+x2)≤½custom character(x2)+½(x1+x2)2 to upper bound the term −custom character(x2)(x1+x2) in the formula (6).


To prove the decay condition (8), notice that along all trajectories of (4), we can use the triangle inequality to get











V
.

new

=




-
γ








G
~



(

x
2
+

)





x
2
+



(


x
1

+

x
2


)



+



γℋ




(

x
2

)





(


x
1

+

x
2


)

2


+


(


γ


(


x
1

+

x
2


)


-




(

x
2

)



)



(




G
~



(

x
2
+

)




x
2
+


-

γ


(


x
1

+

x
2


)



)






-



γ
2



(


x
1

+

x
2


)


2


-





(

x
2

)





G
~



(

x
2
+

)




x
2
+


+


(



(



γ
2

2

+


γℋ




(

x
2

)



)




(


x
1

+

x
2


)

2


+


1
2





2



(

x
2

)




}

.







(
9
)








Also, by Conditions (3)-(4), we have










γ






(

x
2

)






γ
2

4






and






1
2



2



(

x
2

)





1
2






(

x
2

)




x
2
+




G
~



(

x
2
+

)







(
10
)








when x2≥0; furthermore, (10) holds when x2<0 as well, because in this case custom character(x2)=custom character′(x2)=0 by Conditions (1) and (4). Using (10) to upper bound the terms in curly braces in (9) gives (8). Letting Vl(x) and Vu(x) denote the lower and upper bounding functions for Vnew(x) in (7), respectively, we then choose









α
_



(
s
)


=


s

1
+
s




inf
(




V
l



(
x
)




:





x


ɛ



s

}



,





α(s)=s+sup{Vu(x):|x|custom character≤s}, and the composition α01α−1 to satisfy the requirements in our strict Lyapunov function definition with τ=0, where








α
1



(
s
)


=


s

1
+
s



inf



{






γ
2



(


x
1

+

x
2


)


2

/
4

+





(

x
2

)





G
~



(

x
2
+

)





x
2
+

/
2



:





x


ɛ




s

}

.






An important motivation for having an explicit construction for custom character from Theorem 1 comes from the possibility of redesigning the output of the pointer acceleration system to make the closed loop system ISS when there is a perturbation. Given custom character, it is possible to construct a redesigned pointer acceleration output custom character such that when there are perturbations δ in the feedback connection u=custom character+δ, the dynamics:










x
.

=

[






G
~



(

x
2
+

)




x
2
+







-

γ


(



ω




(
x
)


+

x
2

+
δ

)






]





(
11
)








is ISS with respect to custom character and custom character=custom character on custom character=custom character2. This is because we can take custom character(x)=x1+γ(∂Vnew(x)/∂x2), which can be expressed in terms of G and custom character from the strict Lyapunov function Vnew in (6), and use α0custom character from our proof of Theorem 1 and the triangle inequality to get −|γ(∂Vnew(x)/∂x2)|2−γ(∂Vnew(x)/∂x2)δ≤−0.5|γ(∂Vnew(x)/∂x2)|2+0.5|δ|2 and so also {dot over (V)}new≤−α0(Vnew(x))+0.5|δ|2 along all trajectories of (11), so Vnew an ISS Lyapunov function, which implies the ISS property. This motivates finding a formula for custom character, and under standard conditions on G (which hold for many examples of interest from Section 1), we can readily find a function custom character satisfying the requirements from Theorem 1. For instance, we prove the following:


Proposition 1


Let γ>0 be a positive constant, and G:[0,∞)→[0,∞) satisfy the requirements from Theorem 1 and admit a constant ca>0 such that G(r)≥car for all r≥0. Set










κ
_

=

min



{


c
a

,



γ
6



c
a



,

γ
8


}

.






(
12
)








Then for any constant κ0∈(0,κ], the function













(

)


=


κ
o





(


+

)

2


1
+


(


+

)

2








(
13
)








satisfies Conditions (1)(4) from Theorem 1, so (6) with the choice (13) is a strict Lyapunov function for (4) with respect to (5) on custom character=custom character2.


Proof


Condition (2) holds because our lower bound on G gives













0
r





G
~



(

)









d












0
r




c
a




2


d









=




c
a

3



r
3






c
a

3




r
4



(

1
+

r
2


)

2






2
γ





2



(
r
)








(
14
)









    • for all r≥0, where the second inequality followed by separately considering the cases r≥1 and r<1, and where the last inequality used the fact that κ0≤√{square root over (γca/6)}. To check Condition (3), note that
















(
r
)





c
a




r
2


1
+

r
2







c
a



r
2




r



G
~



(
r
)







(
15
)







holds for all r≥0. Condition (4) holds because κ0≤γ/8, so













(
r
)


=



κ
o




2

r



(

1
+

r
2


)

2






γ
4



r


(

1
+

r
2


)

2





γ
4






for all r≥0, which proves the proposition.


Although (11) is ISS, it is useful to find conditions under which the original closed loop system (4) is ISS with respect to additive uncertainties on the original output custom character(x)=x1 on suitable robustly forwardly invariant sets with maximal perturbation sets. The ISS and invariance properties of the original system characterizes its robustness under different choices of scaling functions and other parameters. We begin this analysis with our next section on robust forward invariance.


Section 4. Robust Forward Invariance

The preceding analysis motivates the problem of finding maximal allowable perturbation sets for robustly forwardly invariant sets, because the perturbation bounds one can obtain from ISS Lyapunov functions may be conservative.


In this section, we first provide an analogous result for the undelayed pointing dynamics










x
.

=

[






G
~



(

x
2
+

)




x
2
+







-

γ


(


x
1

+

x
2

+

δ


(
t
)



)






]





(
16
)








with uncertainties δ under suitable conditions on G. Later, we use the δ's to represent control uncertainty, or the effects of input delays. For what follows, we set custom character(r)=rG(r), and we use the sets

Sa,b,c={x∈custom character2:|x1|≤a,−b≤x1+x2≤c}  (17)

for suitable constants a>0, b>0, and c>0; see FIG. 5.


Proposition 2


Let G:[0,∞)→[0,∞) be locally Lipschitz and positive valued on (0,∞). Let γ, a, b, and c be any positive constants such that c>|custom character|[0,a+c]/γ and α>max{b, c}. Then Sa,b,c is robustly forwardly invariant for (16) with the maximal perturbation set custom charactera,b,c=((1/γ)|custom character|[0,a+c−c,b).


Proof


To prove robust forward invariance of Sa,b,c, it suffices to consider continuous δ's, because if x(t,x1,δ) was a trajectory for (16) that starts in Sa,b,c for a piecewise continuous δ but exits Sa,b,c, then we could approximate δ by a continuous custom charactera,b,c valued perturbation δc (in the L1 norm) such that x(t,x1c) also exited Sa,b,c. Set cp=c−|custom character|[0,a+c]/γ, and note that x2+∈[0,a+c] for all x∈Sa,b,c. If δ:[0,∞)→custom charactera,b,c is continuous and t≥0 were such that a corresponding trajectory x(⋅) of (16) for δ starts in Sa,b,c and x(t) is on the top leg of Sa,b,c, then x1(t)+x2(t)=c, so













x
.

1



(
t
)


+



x
.

2



(
t
)



=



-

γ
(

c
+

δ


(
t
)


-


1
γ




G
~



(


x
2
+



(
t
)


)





x
2
+



(
t
)




)


<


-

γ


(

c
-






G
~






[

0
,

a
+
c


]


/
γ


)



+

γ






c
p




=
0.





(
18
)








This prevents x(t) from exiting Sa,b,c, through the top leg of Sa,b,c, except possibly at times t when x1(t)=±a, by continuity of {dot over (x)}1(custom character)+{dot over (x)}2(custom character), which implies that x1(custom character)+x2(custom character) is decreasing in an interval of custom character values of the form [t, t+custom character*] for some custom character*>0. (The strictness of the inequality in (18) is needed to ensure that x1(custom character)+x2(custom character) is decreasing in such an interval of custom character values.) Similarly, if x(t) is on the bottom leg of Sa,b,c, then x1(t)+x2(t)=−b, so we instead get {dot over (x)}1(t)+{dot over (x)}2(t)=G(x2+(t)x2+(t)−γ(−b+δ(t))≥γ(b−δt))>0, which prevents x(t) from leaving Sa,b,c through the bottom leg of Sa,b,c, except possibly if xt(t)=±a. As a>b, we get x2>0 and so also {dot over (x)}1>0 on the left leg of Sa,b,c. Also, {dot over (x)}1=0 on the right leg of Sa,b,c, as a>c ensures that x2+=0 on the right leg of Sa,b,c. (Without the condition a>c, we could have {dot over (x)}1>0 on the right leg of Sa,b,c, which would allow trajectories to exit through the right leg.) This proves the robust forward invariance property.


To prove the maximality of custom charactera,b,c, first note that for each constant d>b, the trajectory of (constant perturbation δ(t)=d starting at the initial state (−b, 0) on the bottom leg of Sa,b,c satisfies {dot over (x)}1(0)+{dot over (x)}2(0)=G(x2+(0))x2+(0)−γ(−b+d)<0, so the trajectory leaves Sa,b,c, through (−b,0). Also, if d<−cp is any constant, and if we choose υ∈[0,a+c] such that custom character(υ)=|custom character|[0,a+c], then the trajectory for the constant perturbation δ(t)=d starting at the point (c−υ,υ) on the top leg of Sa,b,c satisfies
















x
.

1



(
0
)


+



x
.

2



(
0
)



=






G
~



(
v
)



v

-

γ


(

c
+
d

)










=




-

γ


(

c
-






G
~






[

0
,

a
+
c


]


/
γ

+
d

)



>
0


,







(
19
)








so x(⋅) exits Sa,b,c. This proves the maximality of custom charactera,b,c.


Remark 1


We can replace the bounds −a≤x1≤a in the definition of Sa,b,c by −a≤x1≤d for any constant d>c; the proof of the robust forward invariance with this change is as before. The requirement c>|custom character|[0,a+c]/γ from Proposition 2 holds if γ>0 is large enough. While robust forward invariance does not imply convergence to custom character, it can be used with our Lyapunov analysis to prove asymptotic convergence to custom characterwhile maintaining suitable state performance bounds; see below. We can choose (a, b, c)∈(0, ∞)3 such that the robustly forwardly invariant set Sa,b,c is arbitrary large. Also, even though each set Sa,b,c is a proper subset of custom character2, we can build a nested sequence S1⊆S2⊆ . . . of such sets whose union ∪tSt=custom character2. This allows us to make statements about global system behavior.


Two pertinent features of Proposition 2: are (a) the compactness of the robustly forwardly invariant sets Sa,b,c; and (b) the fact that the maximum perturbation sets custom charactera,b,c are intervals. If we relax the conditions that the robustly forwardly invariant sets and maximum perturbation sets must be bounded, then for each constant μ>1, we can prove robust forward invariance results for the more general system











x
.

=

[







G
~



(

x
2
+

)




x
2
+


+


δ
1



(
t
)








-

γ


(


x
1

+

x
2

+


δ
2



(
t
)



)






]


,




(
20
)








with perturbations δi in both equations, by replacing Sa,b,c by










S

a
,
b
,
c

μ

=

{





x






2



:


-
b




x
1

+

x
2



c


,


x
1



-
a


,
and







x
2




μ






x
1


+


(

μ
+
1

)


a

-
b





}





(
21
)








for any constant a>max{b,c}; see FIG. 6a-b. To see how, let custom characterμ denote the upper left kg of Sa,b,cμ, having the slope μ. Then custom characterμ⊆(−∞,0)×(0,∞), because x1≤−a+(b+c)/(1+μ)<0 for all x1 such that x∈custom characterμ. Let









σ
_

μ

=

max


{



-



G
~





(

x
2

)



-


γ
μ



(


x
1

+

x
2


)



:


x





μ


}



,






c
p


=

c
-


1
γ


max


{





G
~





(
s
)




:


s



[

0
,

a
+
c
-


c
+
b


1
+
μ




]


}




,


and






𝒟

a
,
b
,
c

μ


=


{

d





2



:


max


{




d
1

γ

-

c
p



,


μ
γ



(



σ
_

μ

-

d
1


)



}


<

d
2

<



d
1

γ

+
b



}

.







We then prove Proposition 3.


Proposition 3


If μ>1 is a constant and γ, G, a, b, and c satisfy the assumptions from Proposition 2, then Sa,b,cμ is a robustly forwardly invariant set for (20) with the maximum perturbation set custom charactera,b,cμ.


Proof


We indicate the changes needed in the proof of Proposition 2. We replace Sa,b,c, custom charactera,b,c, and cp by Sa,b,cμ, custom charactera,b,cμ, and custom character, respectively. For each d∈custom charactera,b,cμ, we have −custom character<d2−d1/γ<b. Hence, our treatment of the slope −1 legs of Sa,b,c in the proof of Proposition 2 (with δ replaced by δ2−δ1/γ), combined with the fact that x2≤a+c−(c+b)/(1+μ) for all x∈Sa,b,cμ, imply that no trajectory of (20) starting in Sa,b,cμ for any custom charactera,b,cμ-valued continuous perturbation can exit through either of the slope −1 legs of Sa,b,cμ, except possibly though an endpoint of custom characterμ. On the other hand, for any trajectory x(⋅) of (20) for any custom charactera,b,cμ-valued continuous perturbation δ(⋅) and any time t≥0 such that x(t)∈custom characterμ, our definition of custom charactera,b,cμ gives {dot over (x)}2(t)−μ{dot over (x)}1(t)=−γ(x1(t)+x2(t)+δ2(t))−μcustom character(x2(t))−μδ1(t)≤μ(σμ−((γ/μ)δ2(t)+δ1(t)))<0. Because x2−μx1 is the x2 axis intercept of the line through any point x having slope μ, this implies that x(⋅) cannot exit Sa,b,cμ through custom characterμ. Finally, the maximality of custom charactera,b,cμ follows from the maximality part of the proof of Proposition 2 (with |custom character|[0,a+c] and δ replaced by |custom character|[0,a+c−(c+b)/(1+μ)]and δ2−δ1/γ, respectively), combined with the fact that the maximum in the definition of σμ occurs at some point xcustom characterμ. Hence, for any d=(d1,d2)∈custom character2 such that (μ/γ)(−d1+σμ)>d2 and the trajectory x(⋅) of (20) starting at the maximizing pair x for the constant perturbation δ(t)=d, we get {dot over (x)}2(0)−μ{dot over (x)}1(0)=μ((ρμ−((γ/μ)d2+d1))>0, so the trajectory through a Sa,b,c,μ through xcustom characterμ.


Remark 2


The maximum perturbation sets custom charactera,b,cμ are complicated because they are not product sets. However, if the assumptions of Proposition 3 hold, then we can choose μ large enough such that σμ<0, because x2>0 for all x∈custom characterμ. Then for all constants r0∈(0,1), the set custom charactera,b,cμ the open product set neighborhood

custom charactera,b,cb,μ=(−(1−r0custom character0,(1−r0custom character0)×(−r0custom character0,r0custom character0)  (22)

of 0, where custom character0=min{b,custom character,−σμ/γ}>0. In fact, for each d=(d1,d2) in the set (22), we get (d1/γ)−custom character<(1−r0)custom character0custom character>d2custom character0custom character≤d2, (μ/γ)(σμ−d1)<(μ/γ)(σμ+(1−r0custom character0)<(μ/γ)(σμcustom character0)−r0custom character0<d2, and (d1/γ)+b>−(1−r0)custom character0+b≥r0custom character0>d2, which shows that d∈custom charactera,b,cμ.


Remark 3


We can use the sets (22) to cover more general pointer acceleration models that could have additive uncertainties on the pointer position measurements, that is, υ=y+Δ, where we assume that Δ is a C1 perturbation. To see how, note that by a slight variant of the argument that led to the interconnected dynamics (4), we can show that replacing y by y+Δ produces the new x1 dynamics {dot over (x)}1=G(|gx2+1|), where δ1=Δ. If x(⋅) is valued in Sa,b,cμ and the continuous perturbation δ is valued in (22) for some choice of the constant r0∈(0,1), and if G is C1, then we can use the Mean Value Theorem to rewrite our new x1 subsystem as














x
.

1

=






G
~



(

x
2
+

)




x
2
+


+


G


(

gx
2
+

)




δ
1


+


(


G


(




gx
2
+

+

δ
1




)


-

G


(

gx
2
+

)



)



(


gx
2
+

+

δ
1


)










=






G
~



(

x
2
+

)




x
2
+


+


d
*



δ
1




,







(
23
)








where |d*| is bounded by Δ=|custom character(g(a+c)+(1−r0)custom character0γ)+|G|[0,g(a+c), and where we used the fact that x2≤a+c if x∈Sa,b,cμ. This produces a perturbed system that is covered by Proposition 3 (with δ1 in the proposition replaced by the scaled perturbation d*δ1). Therefore, for each constant r0∈(0, 1), each set Sa,b,cμ is robustly forwardly invariant for the perturbed dynamics










x
.

=


[





G


(




gx
2
+

+


δ
1



(
t
)





)




(


gx
2
+

+


δ
1



(
t
)



)







-

γ


(


x
1

+

x
2

+


δ
2



(
t
)



)






]

.





(
24
)








when we restrict the perturbations δ to be piecewise continuous locally bounded functions that are valued in











a
,
b
,
c


b
,
s
,
μ


=


(


-



(

1
-

r
0


)


γ







0



max


{

1
,

Δ
_


)




-



(

1
-

r
0


)


γ







0



max


{

1
,

Δ
_


)




)

×

(



-

r
0





0


,


r
0




0



)






(
25
)








which is a scaled version of the product set (22) from Remark 2.


Section 5. Robustness to Delays and Perturbations

We have so far shown how the closed loop pointing system is effected by perturbations when there are no delays. We next prove stability properties on robustly forward invariant sets under delays but without perturbations; see Theorem 3 for robustness under both delays and perturbations, under a slightly more restrictive delay bound. In what follows, the delay only occurs in x1, which corresponds to delays between the output of the pointer acceleration system and the user's perception of the pointer location. See Section 7 for an example showing how the delay bound in the following theorem cannot be removed. Our strategy for handling delay is to add together: (i) a Lyapunov type function for the corresponding non-delayed system; and (ii) a double integral term whose bounds involve the delay. This so-called Lyapunov-Krasovskii method.


Theorem 2


(A) For all positive constants b, c, and a>max{b, c}, nondecreasing locally Lipschitz functions G: [0,∞)→[0,∞) that are positive on (0,∞), and constants










γ
>



G
~



(

a
+
c

)





(

a
+
c

)

/
c








and




(
26
)







τ


[

0
,


1


(

a
+
c

)




G
~



(

a
+
c

)





min


{

b
,

c
-


1
γ




G
~



(

a
+
c

)




(

a
+
c

)




}



)


,




(
27
)








we have the following: for all initial functions valued in Sa,b,c, all solutions of











x
.



(
t
)


=

[






G
~



(


x
2
+



(
t
)


)





x
2
+



(
t
)








-

γ


(



x
1



(

t
-
τ

)


+


x
2



(
t
)



)






]





(
28
)








asymptotically converge to custom character. (B) For each bounded nondecreasing locally Lipschitz function G:[0,∞)→[0,∞) that is positive on (0,∞), each constant γ>0, and each constant τ∈[0,1/|G|[(0,∞)), we have all solutions of (28) asymptotically converge to custom character.


Proof


We first prove part (A). We first show that each trajectory x(⋅) of (28) for any initial value in Sa,b,c remains in Sa,b,c for all t≥0. We argue by contradiction. Let τ>0 be a constant satisfying (27), and pick constants ā>a, b>b, and c>c such that












a
~

>

max


{


b
~

,

c
~


}



,

γ
>




G
~



(


a
~

+

c
~


)




(


a
~

+

c
~


)



c
~



,




and








τ
<


min


{

b
,

c
p


}





G
~



(


a
~

+

c
~


)




(


a
~

+

c
~


)




,





(
29
)








where cp=c−|custom character|[,a+c]/γ as before. We can always find such values ā, b, and c because of the strictness of the inequalities in our assumptions and the continuity of G. If x(custom character) did not remain in Sa,b,c, then set t1=sup{s≥0:x(custom character)∈Sa,b,c for all custom character∈[0,s]}, and let t2>t1 be such that x(custom character)∈Sā,b,c for all custom character∈[0,t2]. Such a t2 exists because Sa,b,c⊆interior(Sā,b,c). Then the restriction of x(⋅) to [0,t2] is a solution for the perturbed dynamics (16) starting in Sa,b,c, for δ(custom character)=x1(custom character−τ)−x1(custom character), which satisfies















δ


(

)












-
τ







G
~



(


x
2
+



(
r
)


)





x
2
+



(
r
)



dr












τ







G
~



(


a
~

+

c
~


)




(


a
~

+

c
~


)


<

min



{

b
,

c
p


}

.









(
30
)








Because δ(custom character) remains in custom charactera,b,c on [0,t2], it follows from Proposition 2 that x(⋅) stays in Sa,b,c on [0,t2], contradicting the definition of t1.


Because τ<1/G(a+c), there is a constants custom character∈(0,1) such that









τ
<




1
-
ɛ




G
~



(

a
+
c

)




(




G
~



(

a
+
c

)



1
-
ɛ


+

γ





ɛ


)



,






(
31
)








because the right side of (31) converges to 1/G(a+c) as custom character→0 from the right. Fix such a constant custom character>0. We now use the function











V
n



(
x
)


=




0

x
2






G
~



(

ζ
+

)




ζ
+


d





ζ


+


γ
2




{


x
1
2

+

ɛ






x
2
2


+

2

ɛ






x
1



x
2



}

.







(
32
)








Note that Vn is not a Lvanunov function with respect to custom character on custom character2, because it is not identically zero on custom character. For instance,








V
n



(

(

1
,

-
1


)

)


=


γ
2




(

1
-
ɛ

)

.







Nevertheless, we use Vn and Barbalat's Lemma to prove our stabilization result under our delay bound (27), as follows.


Along all trajectories of (28) starting in Sa,b,c, we have














d
dt




V
n



(

x


(
t
)


)



=





-

γ


[




G
~





(


x
2
+



(
t
)


)


+


γ
2



(


2

ɛ







x
1



(
t
)



+

2

ɛ







x
2



(
t
)




)



]





(



x
1



(

t
-
τ

)


+


x
2



(
t
)



)


+











γ
2



(


2



x
1



(
t
)



+

2

ɛ







x
2



(
t
)




)





G
~





(


x
2
+



(
t
)


)









=



-

γ


[




G
~





(


x
2
+



(
t
)


)


+

ɛγ


(



x
1



(
t
)


+






x
2



(
t
)



)



]













(



x
1



(
t
)


-




t
-
τ

t






G
~





(


x
2
+



(

)


)



d








+


x
2



(
t
)



)

+











γ


(



x
1



(
t
)


+


x
2



(
t
)



)





G
~





(


x
2
+



(
t
)


)



+


γ


(

ɛ
-
1

)





G
~



(


x
2
+



(
t
)


)





(


x
2
+



(
t
)


)

2










=




-

W


(

x


(
t
)


)



+



(

x
t

)




,







(
33
)








where custom character(r)=G(r)r as before, and

W(x)=γ(1−custom character)G(x2+)(x2+)22custom character(x1+x2)2,
custom character(x1)=γ[G(x2+(t))x2+(t)+custom characterγ(x1(t)+x2(t))]custom charactert,
and
custom charactert=∫t−τtG(x2+(custom character))x2+(custom character)dcustom character.


Because x2≤a+c for all x∈Sa,b,c and G is nondecreasing, we get G(x2+)≤(G(a+c)G(x2+)1/2 for all x∈Sa,b,c. Hence, because x(custom character)∈Sa,b,c for all custom character≥0, the Jensen inequality gives

custom charactert2≤τ∫t−τtG(x2+(custom character))(x2+(custom character))2dcustom characterG(a+c)  (34)

so two applications of Young's inequality give
















(

x
1

)








1
2



γ


(

1
-
ɛ

)





G
~



(


x
2
+



(
t
)


)





(


x
2
+



(
t
)


)

2


+



γ







G
~



(

a
+
c

)




2


(

1
-
ɛ

)






t
2


+












1
2



γ
2




ɛ


(



x
1



(
t
)


+


x
2



(
t
)



)


2


+



ɛ






γ
2


2




t
2















1
2



W


(

x


(
t
)


)



+






t
-
τ

t





G
~



(


x
2
+



(

)


)





(


x
2
+



(

)


)

2


d



















where




(
35
)






=



τ





γ







G
~



(

a
+
c

)



2




(




G
~



(

a
+
c

)



1
-
ɛ


+

γ





ɛ


)

.






(
36
)







Using (35) to upper bound custom character(xt) in (33), we get











d
dt




V
n



(

x


(
t
)


)







-

1
2




W


(

x


(
t
)


)



+






t
-
τ

τ





G
~



(


x
2
+



(

)


)





(


x
2
+



(

)


)

2


d







.









(
37
)








Also, (31) gives






<


γ

2





τ





(

1
-
ɛ

)

.







Fix any onstant custom character>0 such that









<

<


γ

2

τ





(

1
-
ɛ

)

.






(
38
)








Notice that for all t≥0, we have








d
dt






t
-
τ

t





s
t





G
~



(


x
2
+



(

)


)





(


x
1
+



(

)


)

2


d











ds




=


τ







G
~



(


x
2
+



(
t
)


)





(


x
2
+



(
t
)


)

2


-




t
-
τ

t





G
~



(


x
2
+



(

)


)





(


x
2
+



(

)


)

2


d







.









Hence, (37) and our bounds on custom character give a constant c0>0 such that the time derivative of

custom character(xt)=Vn(x(t))+custom charactert−τtstG(x2+(custom character))(x2+(custom character)2dcustom characterds  (39)

along all trajectories of (28) starting in Sa,b,c satisfies














d
dt




V




(

x
t

)









-

1
2




W


(

x


(
t
)


)



+







τ







G
~



(


x
2
+



(
t
)


)





(


x
2
+



(
t
)


)

2


+











(

-


)






t
-
τ

t





G
~



(


x
2
+



(

)


)





(


x
2
+



(

)


)

2


d




















-

c
0





W


(

x


(
t
)


)


.









(
40
)







The forward invariance of the compact set Sa,b,c ensures boundedness of x(t), and so also absolute continuity of W(x(t). Because W is positive definite with respect to custom character, and because (40) implies that ∫0W(x(custom character))dcustom character<∞, Barbalat's Lemma gives limt→∞W(x(t))=0, and therefore also convergence of x(t) to custom character. This proves part (A). To prove part (B), we replace G(a+c) in the preceding argument by |G|0,∞), and omit the portion of the argument about bounding δ(t), because no robust forward invariance is needed when proving a result on custom character2 when G is bounded. This proves the theorem.


Theorem 2 provides a simple bound on the allowable constant delay τ that ensures attractivity properties of the input delayed model (28). It can be applied when one knows a suitable upper bound on τ, even if the exact value of τ is uncertain. However, because Theorem 2 is based on Barbalat's Lemma instead of a strict Lyapunov function, it does not lend itself to proving ISS properties for











x
.



(
t
)


=

[






G
~



(


x
2
+



(
t
)


)





x
2
+



(
t
)








-

γ


(



x
1



(

t
-
τ

)


+


x
2



(
t
)


+

δ


(
t
)



)






]





(
41
)








with uncertainty δ(t) and constant delay τ. Therefore, we prove the next result on (41), under a slightly more restrictive bound on τ than the one in Theorem 2 (but see Remark 4 for a further generalization with perturbations in both equations). We use a different custom character from the one in Proposition 1. Our new choice of custom character will not satisfy the requirements (1)-(4) from Theorem 1 for all r≥0, but it will satisfy the requirements (1)-(4) for all r≤a+c and so is a valid choice when we restrict x to any of our robustly forwardly invariant sets Sa,b,c.


Theorem 3


Let G: [0,∞)→[0,∞) be C1, positive definite with respect to {0}, and nondecreasing. Let b>0, c>0, and a>max{b,c} be constants. Set

custom character(r)=r+G(r+),  (42)

and let the constant γ>0 be such that c>|custom character|[0,a+c]/γ and

γ>supr∈(0,a+c]max{4custom character′(r),2custom character2(r)/∫0rG(custom character)custom characterdcustom character}.  (43)

Set cp=c−G(a+c)(a+c)/γ. Then for all constants τ such that









0

τ
<

min


{


1

2

γ


,


min


{

b
,

c
p


}




(

a
+
c

)




G
~



(

a
+
c

)





}






(
44
)








the system (41) is ISS with respect to custom character and custom character=(−δ,δ) on custom character=Sa,b,c, where δ=min(b, cp)−τG(a+c)(a+c).


Proof


Because (44) implies that the bound τ<min{b, cp}/((a+c)G(a+c)) from Theorem 2 holds, we can use our bound on |δ| to argue as in the first part of the proof of Theorem 2 (with δ from the earlier proof replaced by the combined disturbance custom character(custom character)=x1(custom character−τ)−x1(custom character)+δ(custom character)) to prove that Sa,b,c is robustly forwardly invariant for (41) with perturbations valued in custom character=(−δ,δ), when (44) holds.


In particular, Sa,b,c is strongly invariant for (41) when τ=0 and δ=0. Therefore, because x2+≤a+c for all x∈Sa,b,c, and because (43) implies that (42) satisfies Conditions (1)-(4) from Theorem 1 when we restrict to values r≤a+c, the decay estimate (8) from Theorem 1 holds along all trajectories of (41) starting in Sa,b,c when τ=0 and δ=0. Hence, along all trajectories of (41) starting in Sa,b,c for all τ≥0 satisfying (44) and δ=0, our choice (42) of custom character gives














d
dt




V
new



(
x
)









-


γ
2

4





(


x
1

+

x
2


)

2


-


1
2






(

x
2

)





G
~



(

x
2
+

)




x
2
+


+










γ


[



-







(

x
2

)





(


x
1

+

x
2


)


+

γ


(


x
1

+

x
2


)



]














t
-
τ

t





G
~





(


x
2
+



(

)


)




x
2
+



(

)



d




















-


γ
2

4





(


x
1

+

x
2


)

2


-


1
2






(


x
2



(
t
)


)





G
~



(

x
2
+

)




x
2
+


+










{



5


γ
2


4






x
1

+

x
2









t
-
τ

t





G
~



(


x
2
+



(

)


)





x
2
+



(

)







d









}








(
45
)








where we used (8), (42), and (43). Using Jensen's inequality, we get













5


γ
2


4







x
1



(
t
)


+


x
2



(
t
)










t
-
τ

t





G
~



(


x
2
+



(

)


)





x
2
+



(

)







d













1
5





γ
2



(



x
1



(
t
)


+


x
2



(
t
)



)


2


+

2





τ






γ
2






t
-
τ

t






2



(


x
2
+



(

)


)







d











,




(
46
)








by our choice (42) of custom character, because the triangle inequality gives

5/4pq≤5/4((½)( 8/25)p2+(½)(25/8)q2)

for all p≥0 and q≥0.


By our delay bound (44), we can find a constant J>0 such that










τ
<



1
-

2

J





τ




2

γ



,




(
47
)








so 1−4τ2γ2−2Jτ>0. Also, our choice (42) of custom character implies that as α0custom character from the proof of Theorem 1 satisfies











α

0








(


V
new



(
x
)


)







γ
2

4




(


x
1

+

x
2


)

2


+


1
2




2



(

x
2

)








(
48
)








for all x∈Sa,b,c. Hence, we can use (46) to upper bound the quantity in curly braces in (45) and the relation











d
dt






t
-
τ

t





s
t






2



(


x
2
+



(

)


)







d










=


τ








2



(


x
2
+



(
t
)


)



-




t
-
τ

t






2



(


x
2
+



(

)


)







d













(
49
)








to conclude that along all trajectories of (41) for δ=0 starting in Sa,b,c for any constant τ>0 satisfying (44), the function

custom character(xt)=Vnew(x(t)°(2τγ2+J)∫t−τtstcustom character2(x2+(custom character))dcustom characterds

satisfies














d
dt




V
new




(

x
t

)









-


γ
2

20





(



x
1



(
t
)


+


x
2



(
t
)



)

2


-

J





t
-
τ

t






2



(


x
2
+



(

)


)



d









-











(


1
2

-

2


τ
2



γ
2


-

J





τ


)





2



(


x
2
+



(
t
)


)















-
min



{


1
5

,

1
-

4


τ
2



γ
2


-

2

J





τ



}




α
0



(


V
new



(

x


(
t
)


)


)



-











J
τ






t
-
τ

t





s
t






2



(


x
2
+



(

)


)







d











d





s















-


0




{



α
0



(


V
new



(

x


(
t
)


)


)


+













(


2

τ






γ
2


+
J

)






t
-
τ

t





s
t






2



(


x
2
+



(

)


)







d











ds




}











-


α
0
b

(


V
new




(

x
t

)


)



,







(
50
)






where








0

=

min


{


1
5

,

1
-

4


τ
2



γ
2


-

2

J





τ


,

J

τ


(


2






τγ
2


+
J

)




}
















and








α
0
b



(
r
)


=



0


min


{



α
0



(

r
2

)


,

r
2


}







is of the class custom character, and where we used the fact that for the class custom character function α(custom character)=min(α0(custom character),custom character), we have α((a+b)/2)≤α(a)+α(b) for all a≥0 and b≥0. Using the fact that |∇Vnew| is bounded by some constant V*a,b,c on the compact set Sa,b,c, it follows that along all trajectories of (41) starting in Sa,b,c, and for all constant delays τ satisfying (44) and all perturbations δ∈custom character(custom character), we have











d
dt




V
new




(

x
t

)






-


α
0
b

(


V
new




(

x
t

)


)


+

γ






V

a
,
b
,
c

*






δ



[

0
,
t

]


.







(
51
)








Therefore, custom character is an ISS Lyapunov function for (41) with respect to custom character and custom character on custom character=Sa,b,c, which implies the ISS property.


Remark


We can generalize Theorem 3 to provide ISS results for











x
.



(
t
)


=

[







G
~



(


x
2
+



(
t
)


)





x
2
+



(
t
)



+


δ
1



(
t
)








-

γ


(



x
1



(

t
-
τ

)


+


x
2



(
t
)


+


δ
2



(
t
)



)






]





(
52
)








having locally bounded piecewise continuous perturbations δ1 in both equations and constant input delays τ≥0, as follows. We assume that G, a, b, c, γ, and τ satisfy the requirements from Theorem 3, and we let μ>1 be any positive constant. Fix any constant d1>0 such that τ<min(b,cp)/(custom character(a+c)+d1), which always exists, by (44). Then (52) is ISS with respect to custom character and custom character on Sa,b,cμ, where









=


{





d





2



:









d
1







d
_

1



,


max


{




d
1

γ

-

c
p



,


μ
γ



(



σ
_

μ

-

d
1


)



}


+








τ


(




G
~





(

a
+
c

)


+


d
_

1


)


<

d
2

<



d
1

γ

+
b
-

τ


(




G
~





(

a
+
c

)


+


d
_

1


)







}

.






and Sa,b,cμ, custom character, and σμ are as defined in Section 4. This follows from Proposition 3, the use of the augmented perturbation custom character(custom character)=x1(custom character−τ)−x1(custom character)+δ2(custom character), and the fact that the gradient ∇Vnew(x) is bounded on the unbounded set Sa,b,cμ, where the terms τ(custom character(a+c)+d1) were used to bound the terms x1(custom character−τ)−x1(custom character) from custom character. This lets us cover the dynamics (24) with perturbed pointer position measurements. Because of page limitations, we leave the details to the reader.


With this final result, we have shown how the closed loop pointing system is affected by delays and perturbations. These results provide a relationship between the maximum delay, maximal perturbation set, and size of invariant sets, and this relationship depends on the scaling function G and other system parameters. In the future, this relationship can be used to compare the properties of different scaling functions and better design pointing interfaces using acceleration.


Section 6. Simulations

We use computational simulations to illustrate the results of this paper, including the invariance and stability properties of the closed loop pointing system with perturbations. FIG. 7a-b shows several trajectories of (41) with and without delays and perturbations, with initial conditions selected in Sa,b,c. For this simulation, we chose the linear scaling function G(s)=1+0.1 s, g=1, and the parameter values a=1.5, b=c=1, and γ=7, which satisfy our requirements






1
=

c
>






G
~






[

0
,

a
+
c


]


γ



0.4





and








7
=


γ
>


sup

r


(

0
,

a
+
c


)




max


{


4








(
r
)



,

2





2



(
r
)


/



0
r





G
~



(

)









d











}



=
6






from Theorem 3. Using the notation from Theorem 3, we get cp=c−G(a+c)(a+c)/γγ≈0.6, so our delay condition (44) becomes









0

τ
<

min


{


1

2

γ


,


min


{

b
,

c
p


}




(

a
+
c

)




G
~



(

a
+
c

)





}



0.1




(
53
)








and the delay bound from Theorem 3 is δ=min{b,cp}−τG(a+c)(a+c)≈0.3. For our simulation, we chose τ=0.1 and δ(t)=0.3 sin(10πt). Without perturbations, the trajectories with initial states in Sa,b,c converge asymptotically to the equilibrium set custom character. When we add perturbations, the trajectories do not always converge to custom character, but do remain within Sa,b,c. These figures show that, at least for these choices of parameters, Sa,b,c is invariant and custom character is attractive.


It is tempting to surmise that our delay conditions such as (27) can be eliminated, so that our robust forwardly invariant conclusions would remain true without the delay bounds. However, we cannot drop our delay conditions, even if there are no perturbations. For instance, if we take G(s)=1+0.1s, g=1, and the values a=1.5, and b=c=1 as in our simulation, then the corresponding set Sa,b,c has the upper left vertex (−1.5,2.5). However, the solution of (28) for the initial state (−1.5, 2.5)∈Sa,b,c and the delay τ=0.5 passes through (0,1.52)∉Sa,b,c, so Sa,b,c would no longer be forwardly invariant for (28), if we were to allow a larger delay such as τ=0.5. Hence, our delay bound (27) from Theorem 2 cannot be removed.


Certain embodiments of the present disclosure can be implemented in hardware, software, firmware, or a combination thereof. For example, a module in software is a part of a software program, whereas a module in hardware is a self-contained component. Various embodiments of the present disclosure are implemented in software or firmware that is stored in a memory and that is executed by a suitable instruction execution system. If implemented in hardware, various embodiments can be implemented with any or a combination of the following technologies, which are all well known in the art: a discrete logic circuit(s) having logic gates for implementing logic functions upon data signals, an application specific integrated circuit (ASIC) having appropriate combinational logic gates, a programmable gate array(s) (PGA), a field programmable gate array (FPGA), etc.


In one embodiment, the flowchart of FIG. 1 and other disclosed processes comprise an ordered listing of executable instructions for implementing logical functions, and can be embodied in any computer-readable medium for use by or in connection with an instruction execution system, apparatus, or device, such as a computer-based system, processor-containing system, or other system that can fetch the instructions from the instruction execution system, apparatus, or device and execute the instructions. In the context of this document, a “computer-readable medium” can be any means that can contain, store, communicate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device. The computer readable medium can be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a nonexhaustive list) of the computer-readable medium would include the following: an electrical connection (electronic) having one or more wires, a portable computer diskette (magnetic), a random access memory (RAM) (electronic), a read-only memory (ROM) (electronic), an erasable programmable read-only memory (EPROM or Flash memory) (electronic), an optical fiber (optical), and a portable compact disc read-only memory (CDROM) (optical).


It should be emphasized that the above-described embodiments of the present disclosure are merely possible examples of implementations, merely set forth for a clear understanding of the principles of the disclosure. Many variations and modifications may be made to the above-described embodiment(s) without departing substantially from the spirit and principles of the disclosure. All such modifications and variations are intended to be included herein within the scope of this disclosure and protected by the following claims.

Claims
  • 1. A method comprising: obtaining, by a computing device, a closed loop pointer acceleration system model, in which the closed loop pointer acceleration system model is based on (1) a model describing user pointing motions integrated with (2) a model of pointer acceleration motions under operational conditions;obtaining, by the computing device, values for system parameters that include pointer acceleration profile parameters and operational condition parameters;determining, by the computing device, a set of pointer trajectories for a given acceleration profile having the pointer acceleration profile parameters and operational condition parameters;repeating the obtaining and determining operations for a new set of system and operational condition parameters; andoutputting a side-by-side comparison of determined sets of pointer trajectories for different pointer acceleration profiles on a display.
  • 2. The method of claim 1, further comprising plotting a trajectory of the pointer acceleration profile based on the determined set of pointer trajectories.
  • 3. The method of claim 1, further comprising plotting one or more trajectories of different pointer acceleration profiles based on the determined sets of pointer trajectories.
  • 4. The method of claim 1, wherein the operational conditions are represented as at least a delay function and a perturbation function.
  • 5. The method of claim 4, wherein the delay function is a constant.
  • 6. The method of claim 1, wherein the pointer acceleration profile parameters include a gain parameter.
  • 7. An apparatus comprising: a processor and memory,the processor configured to obtain a closed loop pointer acceleration system model, in which the closed loop pointer acceleration system model is based on (1) a model describing user pointing motions integrated with (2) a model of pointer acceleration motions under operational conditions; obtain values for system parameters that include pointer acceleration profile parameters and operational condition parameters; and determine & output a set of pointer trajectories for a given acceleration profile having the pointer acceleration profile parameters and operational condition parameters,wherein the processor is further configured to repeat the obtaining and determining operations for a new set of system and operational condition parameters,wherein the processor is further configured to output a side-by-side comparison of determined sets of pointer trajectories for different pointer acceleration profiles on a display.
  • 8. The apparatus of claim 7, wherein the processor is further configured to plot a trajectory of the pointer acceleration profile based on the determined set of pointer trajectories.
  • 9. The apparatus of claim 7, wherein the processor is further configured to plot one or more trajectories of different pointer acceleration profiles based on the determined sets of pointer trajectories.
  • 10. The apparatus of claim 7, wherein the operational conditions are represented as at least a delay function and a perturbation function.
  • 11. The apparatus of claim 7, wherein the pointer acceleration profile parameters include a gain parameter.
  • 12. A non-transitory computer readable medium storing a plurality of computer instructions that, when executed by at least one computing device, cause the at least one computing device to at least: obtain a closed loop pointer acceleration system model, in which the closed loop pointer acceleration system model is based on (1) a model describing user pointing motions integrated with (2) a model of pointer acceleration motions under operational conditions;obtain values for system parameters that include pointer acceleration profile parameters and operational condition parameters; anddetermine and output a set of pointer trajectories for a given acceleration profile having the pointer acceleration profile parameters and operational condition parameters;repeat the obtaining and determining operations for a new set of system and operational condition parameters, andoutput a side-by-side comparison of determined sets of pointer trajectories for different pointer acceleration profiles on a display.
  • 13. The non-transitory computer readable medium of claim 12, wherein the plurality of instructions further cause the at least one computing device to plot a trajectory of the pointer acceleration profile based on the determined set of pointer trajectories.
  • 14. The non-transitory computer readable medium of claim 12, wherein the operational conditions are represented as at least a delay function and a perturbation function.
  • 15. The non-transitory computer readable medium of claim 14, wherein the plurality of instructions further cause the at least one computing device to plot one or more trajectories of different pointer acceleration profiles based on the determined sets of pointer trajectories.
CROSS-REFERENCE TO RELATED APPLICATION

This application claims priority to U.S. provisional application entitled, “Control Method for Pointer Acceleration for Computer Mice or Other Interfaces,” having Ser. No. 62/481,783, filed Apr. 5, 2017, which is entirely incorporated herein by reference.

STATEMENT REGARDING FEDERALLY SPONSORED RESEARCH OR DEVELOPMENT

This invention was made with government support under contract N00014-14-1-0635 awarded by the Office of Naval Research, contract ECCS-1102348 awarded by the Office of Naval Research, and contract CMMI-1436284 awarded by the National Science Foundation. The government has certain rights in the invention.

US Referenced Citations (23)
Number Name Date Kind
5587558 Matsushima Dec 1996 A
6995748 Gordon Feb 2006 B2
8050886 Moussavi Nov 2011 B2
9367148 Lee Jun 2016 B2
9454297 Wolff-Petersen Sep 2016 B2
9713767 Mahlmeister Jul 2017 B2
9927883 Lin Mar 2018 B1
9931565 Mahlmeister Apr 2018 B2
10097541 Ashiya Oct 2018 B2
10220306 Mahlmeister Mar 2019 B2
20060224898 Ahmed Oct 2006 A1
20090153482 Weinberg Jun 2009 A1
20100042358 Moussavi Feb 2010 A1
20100315340 Wolff-Peterson Dec 2010 A1
20140078061 Simons Mar 2014 A1
20150193023 Odgers Jul 2015 A1
20150297991 Mahlmeister Oct 2015 A1
20150301630 Lee Oct 2015 A1
20170282059 Mahlmeister Oct 2017 A1
20170324734 Ashiya Nov 2017 A1
20180178115 Mahlmeister Jun 2018 A1
20180373352 Tan Dec 2018 A1
20190143203 Mahlmeister May 2019 A1
Related Publications (1)
Number Date Country
20180292912 A1 Oct 2018 US
Provisional Applications (1)
Number Date Country
62481783 Apr 2017 US