Method and apparatus for adaptive gravity search

Information

  • Patent Grant
  • 9063867
  • Patent Number
    9,063,867
  • Date Filed
    Thursday, December 22, 2011
    13 years ago
  • Date Issued
    Tuesday, June 23, 2015
    9 years ago
Abstract
Provided are a gravity search adaptive apparatus and method. The gravity search adaptive apparatus includes: a system configured to process and output a received signal; a system modeling unit configured to receive the same signal as a signal input to the system, to convert the signal using a system modeling parameter, and to output the converted signal; and an adaptive controller configured to use a gravity search adaptive algorithm to detect the system modeling parameter so that an error signal which is a difference between an output signal of the system and an output signal of the system modeling unit converges on a minimum value when the system modeling parameter is applied to the system modeling unit.
Description
CROSS-REFERENCE TO RELATED APPLICATION

This application claims the benefit under 35 U.S.C. §119(a) of Korean Patent Applications No. 10-2010-0133789, filed on Dec. 23, 2010, and No. 10-2011-0090383, filed on Sep. 6, 2011, the entire disclosures of which are incorporated herein by reference for all purposes.


BACKGROUND

1. Field


The following description relates to system modeling, and more particularly, to an apparatus and method for adaptively modeling a system by estimating system model parameters using statistical characteristics of signals.


2. Description of the Related Art


A signal processing system needs an algorithm for optimizing itself under a predetermined criterion upon signal processing when no information about a certain input signal is given, in order to vary system characteristics as necessary. Such an algorithm is called an adaptive algorithm.


A representative adaptive algorithm is a steepest descent algorithm. However, the steepest descent algorithm has a problem that it is not easy to adjust a convergence speed.


SUMMARY

The following description relates to an apparatus and method for adaptive gravity search, capable of easily adjusting a convergence speed and a convergence pattern.


In one general aspect, there is provided a gravity search adaptive apparatus for modeling a system, including: a system modeling unit configured to receive the same signal as a signal input to the system, to convert the signal using a system modeling parameter, and to output the converted signal; and an adaptive controller configured to use a gravity search adaptive algorithm to detect the system modeling parameter so that an error signal which is a difference between an output signal of the system and an output signal of the system modeling unit converges on a minimum value.


In another general aspect, there is provided a gravity search adaptive method including: calculating a system modeling parameter of a system modeling unit for minimizing an error signal which is a difference between an output signal of a system and an output signal of the system modeling unit when the same signal has been input to the system and the system modeling unit; and applying the system modeling parameter to the system modeling unit.


Other features and aspects will be apparent from the following detailed description, the drawings, and the claims.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a diagram illustrating a configuration example of a system modeling apparatus for implementing a general adaptive algorithm.



FIGS. 2A and 2B are views for explaining a convergence speed when a steepest descent algorithm is applied.



FIG. 3 is a view for explaining a principle of a gravity search adaptive algorithm.



FIG. 4 is a view for explaining a relationship between ε and a parameter when a single parameter is used.



FIG. 5 is a view for explaining power components that act on a ball.



FIGS. 6A through 6C are views for explaining an acceleration according to a change in movement direction of a ball.



FIG. 7A shows a gradient vector custom character[k].



FIG. 7B shows a velocity vector custom character[k].



FIG. 8 shows the curvature of a curve.



FIG. 9 is a view for explaining an acceleration when the movement direction of a ball changes.



FIG. 10 is a diagram illustrating an example of a gravity search adaptive apparatus.



FIG. 11 is a flowchart illustrating an example of a system modeling method using a gravity search adaptive algorithm.





Throughout the drawings and the detailed description, unless otherwise described, the same drawing reference numerals will be understood to refer to the same elements, features, and structures. The relative size and depiction of these elements may be exaggerated for clarity, illustration, and convenience.


DETAILED DESCRIPTION

The following description is provided to assist the reader in gaining a comprehensive understanding of the methods, apparatuses, and/or systems described herein. Accordingly, various changes, modifications, and equivalents of the methods, apparatuses, and/or systems described herein will be suggested to those of ordinary skill in the art. Also, descriptions of well-known functions and constructions may be omitted for increased clarity and conciseness.



FIG. 1 is a diagram illustrating a configuration example of a system modeling apparatus for implementing a general adaptive algorithm.


Referring to FIG. 1, the system modeling apparatus includes a system 110, a system modeling unit 120, and an adaptive controller 130.


The system 110 processes and outputs input signals. The processing characteristics of the system 110 are not known or changes in time depend on environmental factors.


In FIG. 1, x[k] represents an input signal of the system 110, which is a (N×1) vector, and y[k] represents an output signal from the system 110.


The system modeling unit 120 has been modeled as mathematical representation of the system 110. The system modeling unit 120 is used to model a unknown system or a system whose characteristics vary depending on environmental factors. {right arrow over (w)}[k], which is an (N×1) vector, represents a parameter vector of the system modeling unit 120. The system modeling unit 120 receives the input signal x[k] of the system 110 and applies {right arrow over (w)}[k] to the input signal x[k], thus outputting an output signal ŷ[k].


The adaptive controller 130 controls the system 110 and the system modeling unit 120 so that the same signal is applied to the system 110 and the system modeling unit 120, and compares an output signal from the system 110 to an output signal from the system modeling unit 120 to thereby estimate a parameter of the system modeling unit 120. In detail, the adaptive controller 130 includes an error detector 131 and a modeling parameter calculator 132.


The error detector 131 detects a difference between the output signal y[k] of the system 110 and the output signal ŷ[k] of the system modeling unit 120, thus outputting the detected difference as an error signal e[k]. Then, the modeling parameter calculator 132 calculates a modeling parameter vector for reducing power of the error signal e[k] output from the error detector 131, and applies the modeling parameter vector to the system modeling unit 120. Then, the modeling parameter calculator 132 continues to calculate modeling parameters until the error signal e[k] between the output signal y[k] of the system 110 and the output signal ŷ[k] of the system modeling unit 120 obtained when the previously calculated modeling parameter is applied to the system modeling unit 120 converges on a minimum value, and supplies the calculated modeling parameters to the system modeling unit 120 to thereby update the system modeling unit 120.


That is, the adaptive controller 130 estimates a system modeling parameter for approximating the output value of the system modeling unit 120 to the output value y[k] of the system 110, thereby estimating the characteristics of the system 110.


The output signal ŷ[k] of the system modeling unit 120 at time k is expressed by equation 1 below.











y
^



[
k
]


=





n
=
0


N
-
1






w
k
*



[
k
]


·

x


[

k
-
n

]




=




w




[
k
]


H




x




[
k
]








(
1
)







In equation 1, H represents Hermitian Transpose, and (N×1) vectors {right arrow over (w)}[k] and {right arrow over (x)}[k] are defined as follows.









w




[
k
]


=

[





w
0



[
k
]








w
1



[
k
]













w

N
-
1




[
k
]





]


,







x




[
k
]


=

[




x


[
k
]







x


[

k
-
1

]












x


[

k
-
N
+
1

]





]






An adaptive algorithm is aimed at obtaining a modeling parameter vector for minimizing the power of an error signal which is a difference between the output signal of a real system and the output signal of a system modeling unit.


When noise n[k] exists in a measured signal, the error signal e[k] can be expressed by equation 2 below.

e[k]=y[k]−ŷ[k]+n[k]  (2)


Also, the power ε of the error signal e[k] is given as equation 3 below.












ɛ
=




E


{




e


[
k
]




2

}


=

E


{


e


[
k
]





e
*



[
k
]



}









=



E


{





y


[
k
]




2

-


y


[
k
]






x




[
k
]


H




w




[
k
]



-




w




[
k
]


H




x




[
k
]





y
*



[
k
]



+
















w




[
k
]


H




x




[
k
]






x




[
k
]


H




w




[
k
]



+


y


[
k
]





n
*



[
k
]



+


n


[
k
]





y
*



[
k
]



-














w




[
k
]


H




x




[
k
]





n
*



[
k
]



-


n


[
k
]






x




[
k
]


H




w




[
k
]



+



n
*



[
k
]




n


[
k
]




}







=




σ
y
2

-



p


H




w




[
k
]



-




w




[
k
]


H



p



+




w




[
k
]


H


R







w




[
k
]



+

σ
n
2



,







(
3
)







In equation 3, E{•} represents an ensemble average.


Also, R, which is a (N×N) matrix, can be expressed by equation 4 below.

R=E{custom character[k]custom character[k]H}  (4)


In equation 3, {right arrow over (P)}, which is a (N×1) vector, can be defined as equation 5 below.

custom character=E{custom character[k]y*[k]}  (5)


In equation 3, ε is also called a cost function, and since the cost function ε is a quadratic function of {right arrow over (w)}[k], an optimum coefficient vector {right arrow over (w)}opt at which the gradient of ε becomes zero so that c reaches a minimum value can be obtained. If {right arrow over (∇)}[k] is a gradient vector of ε, {right arrow over (∇)}[k] can be expressed by equation 6 below.
















[
k
]


=


2




ɛ






w




[
k
]


*




=



-
2



p



+

2





R







w




[
k
]









(
6
)







If the inverse matrix R−1 of R exists, the optimum coefficient vector {right arrow over (w)}opt and the optimum power εopt of the error signal ε when {right arrow over (w)}[k]={right arrow over (w)}opt are given as equations 7 and 8 below.

custom characteropt=R−1custom character  (7)
εopty2custom characterR−1custom charactern2  (8)


However, since directly calculating the inverse matrix R−1 in equation 7 requires a large amount of calculation, applying a method of directly obtaining the inverse matrix R−1 in implementing a real system is improper in many cases. In those cases, an adaptive algorithm which repeatedly updates {right arrow over (w)}[k] so that {right arrow over (w)}[k] gradually converges on {right arrow over (w)}opt is utilized, instead of directly calculating the inverse matrix R−1. One of adaptive algorithms that has been widely used for the purpose is a steepest descent algorithm, and the steepest descent algorithm is also called a gradient descent algorithm.


The steepest descent algorithm calculates a gradient vector {right arrow over (∇)}[k] of ε with respect to the parameter vector {right arrow over (w)}[k] using the fact that ε is a quadratic function of the parameter vector {right arrow over (w)}[k], and updates the parameter vector {right arrow over (w)}[k] by the magnitude of the calculated gradient vector {right arrow over (∇)}[k] in the opposite direction of the gradient to thereby obtain a next parameter vector Δ{right arrow over (w)}[k+1].


By repeating the process, the parameter vector {right arrow over (w)}[k] finally converges on the optimum coefficient vector {right arrow over (w)}opt for minimizing ε as the k value increases.


The steepest descent algorithm can be expressed by equation 9 below.











w




[

k
+
1

]


=




w




[
k
]


-


μ
2









[
k
]




=



w




[
k
]


-

μ


(


R







w




[
k
]



-

p



)








(
9
)







A convergence speed of the steepest descent algorithm can be adjusted using a μ value. That is, the μ value, which is a proportional coefficient used to update the optimum coefficient vector {right arrow over (w)}opt, decides the convergence speed. If the μ value is large, the convergence speed is fast, and if the μ value is small, the convergence speed is slow.


Meanwhile, if it is defined that Δ{right arrow over (w)}[k]={right arrow over (w)}[k]−{right arrow over (w)}opt, equations 10 and 11 can be induced from equations 7 and 8.

Δcustom character[k+1]=(I−μRcustom character[k]=(I−μR)k+1Δcustom character[0]  (10)
ε=εoptcustom character[k]Hcustom character[k]  (11)


If R=VAV−1 is given as eigen-value decomposition of R, Δ{right arrow over (w)}[k+1] can be rewritten as equation 12 below.

Δcustom character[k+1]=V(I−μΛ)k−1V−1Δcustom character[0]  (12)


As seen from equation 12, in order to make the steepest descent algorithm converge, the value has to satisfy equation 13 below.

0<μ<1/λmax  (13)


In order to implement the steepest descent algorithm written as equation 9, the matrix R and the vector {right arrow over (P)} defined in equations 4 and 5 respectively have to be given. One method is to calculate time averages of samples and use the time averages as estimated values of R and {right arrow over (P)}, instead of directly obtaining R and {right arrow over (P)} using an ensemble average. A well-known Least Mean Squares (LMS) algorithm uses a single sample of each of {right arrow over (x)}[k] and y[k] in order to estimate R and {right arrow over (P)}, as written by equations 14 and 15 below.

{circumflex over (R)}=custom character[k]custom character[k]H  (14)
custom character=custom character[k]y*[k]  (15)


As such, by estimating the instantaneous values of R and {right arrow over (P)}, the steepest descent algorithm is simplified to a LSM algorithm, which is expressed as equation 16 below.

custom character[k+1]=custom character[k]+μcustom character[k]e*[k]  (16)


The convergence speed of the LSM algorithm may be adjusted using the μ value. As seen in equation 13, as the eigen-value is large, a small μ value may be used, and if the eigen-value is small, a large μ value may be used.



FIGS. 2A and 2B are views for explaining a convergence speed when the steepest descent algorithm is applied.



FIGS. 2A and 2B show curves of ε when two signals having different characteristics are input. However, since the μ value has to be smaller than 1max, if the ratio λmaxmin of the maximum eigen-value with respect to the minimum eigen-value is large, the selected μ value may be too small in view of the minimum eigen-value, which may make the convergence speed of the LMS algorithm slow. In addition to such a convergence speed problem, the LMS algorithm may be subject to performance deterioration due to the influence by noise when noise is mixed in a measured signal.


Accordingly, in order to overcome the problem of the steepest descent algorithm, gravity is used. Since a new adaptive algorithm proposed in this specification has been developed based on physical characteristics that occur as a natural phenomenon, it has a stable characteristic by the law of energy conservation. Also, since the proposed adaptive algorithm has degrees of freedom two in adjusting the convergence speed of the adaptive algorithm, the adaptive algorithm can adjust the convergence speed and the convergence pattern more flexibly according to application fields.



FIG. 3 is a view for explaining a principle of a gravity search adaptive algorithm. FIG. 3 shows an example where a ball moves in a parabolic, concave container filled up with liquid, wherein m represents the mass of the ball and g represents the gravitational acceleration.


Since gravity pulls down the ball, the ball moves downward to the bottom of the container along the inner surface of the container. At this time, the potential energy of the ball is converted to kinetic energy to move the ball, the kinetic energy is lost due to friction with the liquid, and resultantly the ball is stopped at the lowest position (that is, the bottom of the container) of the container.


At this time, the behavior of the ball, that is, how fast the ball moves toward the bottom of the container or how quickly the ball is stopped at the bottom depends on the mass m of the ball, the magnitude g of gravitational acceleration g, and the friction force f of the liquid.


As such, a natural phenomenon can be used as a model to obtain an adaptive algorithm for solving a problem of finding a global minimum of a cost function which is in the form of a quadratic function. The adaptive algorithm is called a “gravity search adaptive algorithm”, and the gravity search adaptive algorithm is stable and has a low risk of divergence compared to other adaptive algorithms that use no physical phenomenon associated with the law of energy conservation.


For easy understanding, a procedure of inducing a 1-dimensional gravity search adaptive algorithm whose coefficients are real numbers, a procedure of inducing a N-dimensional gravity search adaptive algorithm whose coefficients are real numbers, and a procedure of inducing a N-dimensional gravity search adaptive algorithm whose coefficients are complex numbers will be described in this order below.


<1-Dimensional Gravity Search Adaptive Algorithm>


In the case of a 1-dimensional gravity search adaptive algorithm, the cost function of equation 3 can be simplified to equation 17 below.

ε=σy2−2pw[k]+σx2w[k]2  (17)

where w[k] is a value resulting from k-th iteration of the coefficient w, p=E{x[k]y[k]}, and σx=E{x2[k]}.


First-order and second-order derivatives of the cost function with respect to w[k] are written as equations 18 and 19 below.












ɛ




w


[
k
]




=




[
k
]


=


2






σ
x
2



w


[
k
]



-

2





p







(
18
)










2


ɛ





w


[
k
]


2



=

2






σ
x
2






(
19
)








FIG. 4 is a view for explaining a relationship between c and a parameter when a single parameter is used. The following description will be given with reference to FIGS. 3 and 4.


In FIG. 4, the w-axis represents the parameter, and the y-axis represents ε. That is, ε is the second-order function of w[k], and the present invention is aimed at obtaining w[k]=wopt for minimizing ε. The w-axis component of movement of a ball, which represents the position of the ball, can be represented as a second-order differential equation written by equation 20 below.

m{umlaut over (w)}+f{dot over (w)}=F  (20)

where F represent a force applied to the ball in the direction of the w-axis, m represents the mass of the ball, f represents a friction force depending on viscosity of liquid, and {dot over (w)} and {umlaut over (w)} are first-order and second-order derivatives with respect to time, respectively. The F value depends on the magnitude g of gravitation acceleration, the shape of the container, and the position and movement of the ball.


If the F value is assumed to be a constant and v={dot over (w)}, equation 20 can be rewritten to equation 21 below.










v
.

=



-

f
m



v

+

F
m






(
21
)







A solution of the differential equation of equation 21 can be expressed as equation 22 below.










v


(
t
)


=



v


(

t
0

)







-

f
m




(

t
-

t
0


)




+


F
m






t
0

t







-

f
m




(

t
-
σ

)






σ









(
22
)







By calculating the second term of the right side of equation 22, equation 22 can be arranged to equation 23 below.










v


(
t
)


=



v


(

t
0

)







-

f
m




(

t
-

t
0


)




+


F
f



(

1
-




-

f
m




(

t
-

t
0


)




)







(
23
)







In equation 23, w(t) can be obtained as equation 24 below. v(t) is a derivative of w(t). So, if we know v(t), w(t) can be calculated by calculating the integral of v(t).













w


(
t
)


=


w


(

t
0

)


+




t
0

t




v


(
τ
)





τ










=


w


(

t
0

)


+


F
f



(

t
-

t
0


)


+


(


v


(

t
0

)


-

F
f


)



m
f



(

1
-




-

f
m




(

t
-

t
0


)




)










(
24
)







If First-order Taylor Series Approximation is used,








x

=


1
+
x
+


x
2


2
!


+


x
3


3
!


+




1
+
x







when |x|<<1, and accordingly, if











f
m



(

t
-

t
0


)





1

,





equations 23 and 24 can be rewritten to equation 25 and 26 below.










v


(
t
)


=




v


(

t
0

)







-

f
m




(

t
-

t
0


)




+


F
f



(

1
-




-

f
m




(

t
-

t
0


)




)







v


(

t
0

)




(

1
-


f
m



(

t
-

t
0


)



)


+


F
m



(

t
-

t
0


)








(
25
)







w


(
t
)


=



w


(

t
0

)


+


F
f



(

t
-

t
0


)


+


(


v


(

t
0

)


-

F
f


)



m
f



(

1
-




-

f
m




(

t
-

t
0


)




)






w


(

t
0

)


+


v


(

t
0

)




(

t
-

t
0


)








(
26
)







In equation 24, if it is assumed that v(τ) is a constant in the integral interval, equation 24 can be rewritten to equation 27 below.

w(t)≈w(t0)+v(t0)(t−t0)≈w(t0)+v(t)(t−t0)  (27)


In this case, equation 27 becomes identical to equation 26. This means that the First-order Taylor Series Approximation has the same effect as the assumption that v(τ) is a constant. Also, since equation 27 has been obtained under the same assumption that v(τ) is a constant, an approximate value having the same accuracy can be obtained. In this specification, equation 27 is used.


Equations 25 and 27 can be arranged and expressed as matrix equation 28 below.










[




w


(
t
)





v


(
t
)





]

=


[




w


(

t
0

)





v


(

t
0

)





]






[



1


0





1
-


f
m



(

t
-

t
0


)






1
-


f
m



(

t
-

t
0


)






]





+







[





F
m



(

t
-

t
0


)







F
m



(

t
-

t
0


)


]















(
28
)







Here, w(t) can be substituted by w[k+1], v(t) can be substituted by v[k+1], w(t0) can be substituted by w[k], v(t0) can be substituted by v[k], and F can be substituted by F[k], and t−t0=Ts.


Ts can be considered as a sampling interval and can be, for convenience of expansion, normalized to Ts=1.


When the substitutions are applied, equation 28 can be rewritten to equation 29 below.









[





w


[

k
+
1

]





v


[

k
+
1

]





=

[






w


[
k
]






v


[
k
]


]






[



1


0




β


β



]


+



F


[
k
]


m



[



1


1



]









(
29
)







Here, since







β
=


1
-


f
m






and






f
m



(

t
-

t
0


)




1


,





β has to satisfy equation 30 below.

1−ε<β<1,ε<<1  (30)


In equation 29, F[k] consists of two components as written in equation 31 below.

F[k]=Fg[k]+Fa[k]  (31)

where Fg[k] is a force applied to the ball by gravity, and Fa[k] is a force generated when the ball changes its direction while moving.



FIG. 5 is a view for explaining power components that act on the ball.


In FIG. 5, a force of gravity that pulls down the ball is denoted by mg, and the component applied in the w direction to the ball, among components of the force mg of gravity, is denoted by Fg[k].


Here, considering the fact that the direction of the force applied to the ball is in the opposite direction of the gradient vector, Fg[k] can be expressed using the characteristics of trigonometric functions of equation 32, as equation 33 below.










sin





θ





cos





θ

=



sin





θ





cos





θ




cos
2


θ

+


sin
2


θ



=



sin






θ
/
cos






θ


1
+


sin
2



θ
/

cos
2



θ



=


tan





θ


1
+


tan
2


θ









(
32
)








F
g



[
k
]


=



-
mg






sin






θ
k


cos






θ
k


=


-
mg




tan






θ
k



1
+


tan
2



θ
k










(
33
)







By applying tan θk=∇[k] to equation 33, equation 33 is rewritten to equation 34.











F
g



[
k
]


=


-
mg






[
k
]



1
+




[
k
]

2









(
34
)







Then, a process of obtaining Fa will be described. When a differentiable function y=f(x) is given, curvature κ can be expressed as equation 35 below.









κ
=




y






(

1
+

y







2



)


3
/
2







(
35
)







Acceleration generated when a certain object has a curvilinear motion at a velocity of v is in a direction perpendicular to the concave part of the curve, and if curvature of the curve is κ, the magnitude of the acceleration a can be expressed as equation 36 below.

a=v2κ  (36)


When a ball goes down or up along the inner inclined surface of a container as illustrated in FIG. 4, the movement velocity v of the ball can be written by the horizontal velocity v[k] (that is, a component of the w[k] axis) of the ball, as equation 37 below.









v
=


v


[
k
]



cos






θ
k







(
37
)








FIGS. 6A through 6C are views for explaining a change in acceleration according to a change in movement direction of a ball.



FIG. 6A shows the relationship between v and v[k]. Accordingly, the acceleration a can be written as equation 38 below.









a
=




v


[
k
]


2



cos
2



θ
k





κ
.






(
38
)







As illustrated in FIG. 6B, acceleration a is in a direction perpendicular to the inner surface of a container, and aw which is a component of the w[k] direction among the acceleration a can be written by equation 39 below.










a
w

=


a





sin






θ
k


=






v


[
k
]


2


sin






θ
k




cos
2



θ
k




κ

=





v


[
k
]


2


tan






θ
k



cos






θ
k




κ







(
39
)







As seen from FIG. 6C, since tan θk=y′ and








cos






θ
k


=

1




tan
2



θ
k


+
1




,





equation 40 is induced, as follows.










a
w

=




v


[
k
]


2



y






y







2


+
1



κ

=




v


[
k
]


2



y






y







2


+
1







y






(

1
+

y







2



)


3
/
2




=



v


[
k
]


2



y







y





1
+

y







2











(
40
)







If y′=∇[k] and







y


=





2


ɛ





w


[
k
]


2



.






are applied to equation 40, equation 41 is induced from |Fa[k]|=maw











F
a



[
k
]


=


-


mv


[
k
]


2






[
k
]







y





1
+




[
k
]

2









(
41
)







Finally, a 1-dimensional gravity search adaptive algorithm induced from equations 29, 34, and 41 is expressed by equation 42 below.











[




w


[

k
+
1

]





v


[

k
+
1

]





]

=



[




w


[
k
]





v


[
k
]





]



[



1


0




β


β



]


+


g


[
k
]




[



1


1



]




,




(
42
)








where







β
=

1
-

f
m



,





m is the mass of the ball, f is the friction coefficient of liquid, and g is the gravitational acceleration. g[k] is defined by equation 43 below.










g


[
k
]


=



-
g






[
k
]



1
+




[
k
]

2





-



v


[
k
]


2





[
k
]







y





1
+




[
k
]

2










(
43
)







By applying equation 18 to equation 43, equation 44 is deduced as follows.










g


[
k
]


=



-
g





2


σ
x
2



w


[
k
]



-

2





p



1
+


(


2






σ
x
2



w


[
k
]



-

2





p


)

2




-


2






σ
x
2




v


[
k
]


2



(


2






σ
x
2



w


[
k
]



-

2





p


)



1
+


(


2






σ
x
2



w


[
k
]



-

2





p


)

2








(
44
)







<N-Dimensional Gravity Search Adaptive Algorithm>


The 1-dimensional gravity search adaptive algorithm can be easily expanded to an N-dimensional gravity search adaptive algorithm. It is assumed that {right arrow over (x)}[k] and {right arrow over (w)}[k] are N-dimensional signal and coefficient vectors, respectively.



FIG. 7A shows an N-dimensional gradient vector {right arrow over (∇)}[k] when N=2.


Since {right arrow over (F)}g[k] indicates the opposite direction of the N-dimensional gradient vector {right arrow over (∇)}[k], equation 45 is deduced from equation 33.












F


g



[
k
]


=


-
mg




tan






θ
k



1
+


tan
2



θ
k













[
k
]












[
k
]

T










[
k
]










(
45
)








At this time, since








Δ





y

=





y




w
1




Δ






w
1


+




y




w
2




Δ






w
2


+

+




y




w
N




Δ






w
N




,





tan θk can be expressed as equation 46 below.










tan






θ
k


=



Δ





y




Δ






w
1
2


+

Δ






w
2
2


+

+

Δ






w
N
2





=



[




Δ






w
1





Δ






w
2








Δ






w
N





]



[






y




w
1










y




w
2















y




w
N






]





[




Δ






w
1





Δ






w
2








Δ






w
N





]



[




Δ






w
1







Δ






w
2












Δ






w
N





]









(
46
)







Referring to FIG. 7A, equation 47 can be deduced for an arbitrary ε when ε<<1, as follows.










[




Δ






w
1







Δ






w
2












Δ






w
N





]

=

ε









[
k
]












[
k
]

T










[
k
]










(
47
)







Here, since














[
k
]


=

[






y




w
1










y




w
2















y




w
N






]


,





tan θk can be expressed as equation 48 below.










tan






θ
k


=



ε











[
k
]

T










[
k
]













[
k
]

T










[
k
]









ε
2












[
k
]

T










[
k
]












[
k
]

T










[
k
]







=










[
k
]

T










[
k
]









(
48
)







Accordingly, in the case of the N-dimensional gravity search adaptive algorithm, {right arrow over (F)}g[k] can be represented by equation 49 below.












F


g



[
k
]


=



-
mg













[
k
]

T










[
k
]





1
+









[
k
]

T










[
k
]














[
k
]












[
k
]

T










[
k
]






=


-
mg



1

1
+









[
k
]

T










[
k
]













[
k
]








(
49
)







In order to calculate custom charactera[k], curvature of the container in the direction of the movement of the ball has to be obtained.



FIG. 7B shows an N-dimensional velocity vector {right arrow over (v)}[k] when N=2.


The direction of the N-dimensional velocity vector {right arrow over (v)}[k] is generally not parallel to the direction of {right arrow over (∇)}[k].


Since








Δ





y

=





y




w
1




Δ






w
1


+




y




w
2




Δ






w
2


+

+




y




w
N




Δ






w
N




,





equation 50 can be obtained.










tan






ϕ
k


=



Δ





y




Δ






w
1
2


+

Δ






w
2
2


+

+

Δ






w
N
2





=



[




Δ






w
1





Δ






w
2








Δ






w
N





]



[






y




w
1










y




w
2















y




w
N






]





[




Δ






w
1





Δ






w
2








Δ






w
N





]



[




Δ






w
1







Δ






w
2












Δ






w
N





]









(
50
)







However, if







[




Δ






w
1







Δ






w
2












Δ






w
N





]

=

ε







v




[
k
]








for an arbitrary ε when ε<<1, tan Φk can be expressed as equation 51 below.










tan






ϕ
k


=



ε








v




[
k
]


T









[
k
]






ε
2





v




[
k
]


T




v




[
k
]





=





v




[
k
]


T









[
k
]








v




[
k
]


T




v




[
k
]










(
51
)







If s is a trajectory of the ball that has moved along the inner surface of the container, curvature is defined as a change rate in movement direction when the ball moves by a unit distance. An example of such curvature is shown in FIG. 8. Referring to FIG. 8, as the ball moves by Δs, the movement direction changes by ΔΦ. Accordingly, by differentiating both sides of equation 51 with respect to s, the curvature is defined by equation 52 below.














s



tan






ϕ
k


=






s




(





v




[
k
]


T









[
k
]








v




[
k
]


T




v




[
k
]





)


=



1





v




[
k
]


T




v




[
k
]










s




(




v




[
k
]


T









[
k
]



)


=


1





v




[
k
]


T




v




[
k
]









v




[
k
]


T












[
k
]





s









(
52
)







Here, equation 52 is arranged to equation 53 below.

















s



tan






ϕ
k


=





s




(


sin






ϕ
k



cos






ϕ
k



)








=





sin
2



ϕ
k


+


cos
2



ϕ
k





cos
2



ϕ
k








ϕ
k




s









=


1


cos
2



ϕ
k








ϕ
k




s









=


1


cos
2



ϕ
k




k








(
53
)







Accordingly, equation 54 can be obtained from equation 53.









κ
=


cos
2



ϕ
k



1





v




[
k
]


T




v




[
k
]









v




[
k
]


T












[
k
]





s







(
54
)







Here,
















[
k
]





s


.





can be represented as a product of R and a vector, as shown in equation 55.






















[
k
]





s


=






w
1




s













[
k
]






w
1




+





w
2




s













[
k
]






w
2




+

+





w
N




s













[
k
]






w
N











=



[













[
k
]






w
1















[
k
]






w
2


















[
k
]






w
N






]



[







w
1




s










w
2




s















w
N




s





]


=

2






R


[







w
1




s










w
2




s















w
N




s





]











(
55
)







Here, since











Δ





s

=





ε
2





v




[
k
]


T




v




[
k
]



+


(

ε




v




[
k
]


T









[
k
]



)

2



=

ε







v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2






,









w
n




s


=



lim

ε
->
0





Δ






w
n



Δ





s



=



lim

ε
->
0





ε







v
n



[
k
]




ε







v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2






=




v
n



[
k
]








v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2




.








(
56
)







Where, vn[k] is the nth element of the vector {right arrow over (v)}[k]. Accordingly, equation 57 is deduced as follows.










[







w
1




s










w
2




s















w
N




s





]

=



1






v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2






[





v
0



[
k
]








v
1



[
k
]













v

N
-
1




[
k
]





]


=


1






v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2







v




[
k
]








(
57
)







Accordingly, equation 58 is deduced from equation 57, as follows.



















[
k
]





s


=


1






v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2





2





R



v




[
k
]







(
58
)







As a result, the curvature is given as equation 59 below.









κ
=


cos
2



ϕ
k



1





v




[
k
]


T




v




[
k
]







1






v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2








v




[
k
]


T


2





R



v




[
k
]







(
59
)







Accordingly, the acceleration a can be obtained by equation 60 below.









a
=



v
2


κ

=







v




[
k
]


T




v




[
k
]





cos
2



ϕ
k




κ

=







v




[
k
]


T




v




[
k
]










v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2








v




[
k
]


T


2





R







v




[
k
]









(
60
)








Since the acceleration a is always in a direction perpendicular to the surface and is not related to the direction of {right arrow over (v)}[k], {right arrow over (a)}[k] can be expressed by equation 61 below. That is, the direction of a is perpendicular to the surface, and the direction of {right arrow over (v)}[k] is tangential to the surface, but can be in any direction.














a




[
k
]


=




-
a





sin






ϕ
k













[
k
]












[
k
]

T










[
k
]












=




-



sin






ϕ
k












v




[
k
]


T




v




[
k
]










v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2








v




[
k
]


T


2





R








v




[
k
]


·


















[
k
]












[
k
]

T










[
k
]












(
61
)







At this time, since equation 62 is satisfied, equation 63 is deduced.












sin






ϕ
k




=





tan






ϕ
k






1
+


tan
2



ϕ
k





=









v




[
k
]


T




v




[
k
]










v




[
k
]


T




v




[
k
]







1
+



(




v




[
k
]


T









[
k
]



)

2





v




[
k
]


T




v




[
k
]







=







v




[
k
]


T









[
k
]











v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2










(
62
)
















a




[
k
]


=



-







v




[
k
]


T









[
k
]











v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2






















v




[
k
]


T




v




[
k
]










v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2




·



v




[
k
]


T



2





R




v




[
k
]


·


















[
k
]







v




[
k
]


T









[
k
]











=




-
2











v




[
k
]


T









[
k
]





·





v




[
k
]


T




v




[
k
]










v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2



·



v




[
k
]


T



R




v




[
k
]


·


















[
k
]












[
k
]

T










[
k
]












(
63
)







Finally, the N-dimensional gravity search adaptive algorithm is arranged to equation 64 below.











[





w




[

k
+
1

]






v




[

k
+
1

]





]

=



[





w




[
k
]






v




[
k
]





]



[



1


0




β


β



]


+



g




[
k
]




[



1


1



]




,




(
64
)








where







β
=

1
-

f
m



,





where m is the mass of the ball, f is the friction coefficient of the liquid, and g is the gravitational acceleration. Also, g[k] is defined as equation 65 below.











g




[
k
]


=




-
g


1
+









[
k
]

T










[
k
]





·







[
k
]



-

2










v




[
k
]


T









[
k
]





·





v




[
k
]


T




v




[
k
]










v




[
k
]


T




v




[
k
]



+


(




v




[
k
]


T









[
k
]



)

2



·



v




[
k
]


T



R








v




[
k
]


·








[
k
]












[
k
]

T










[
k
]












(
65
)







<N-dimensional Gravity Search Adaptive Algorithm Having Complex Coefficients>


If {right arrow over (x)}[k] is an N-dimensional complex signal vector and {right arrow over (w)}[k] is an N-dimensional complex coefficient vector, the cost function given by equation 3 above can be rewritten to equation 66 below.










ɛ
=


σ
y
2

-



p


H




w




[
k
]



-




w




[
k
]


H



p



+




w




[
k
]


H


R







w




[
k
]



+

σ
n
2



,




(
66
)







Real vectors custom characterr; custom characteri; custom characterr[k], custom characteri[k] and real matrices Rr and Ri are defined by equations 67, 68, and 69, respectively, below.

custom character=custom characterr+jcustom characteri  (67)
custom character[k]=custom characterr[k]+jcustom characteri[k]  (68)
R=Rr+jRi  (69)


Here, the real matrices Rr and Ri satisfy equation 70 below.

RrT=RrRiT=−Ri  (70)


Equations 67, 68, and 69 are applied to equation 66, and equation 66 is rearranged to obtain equation 71 below.

ε=σy2−2custom character[k]Tcustom character+custom character[k]TRcustom character[k]+σn2  (71)


Here, {right arrow over (p)}, {right arrow over (w)}[k], and R are defined by equation 72 below.











P


=

[





p


r







p


i




]


;



W




[
k
]


=

[






w


r



[
k
]









w


i



[
k
]





]


;


=

[




R
r




-

R
i







R
i




R
r




]






(
72
)







Equations 71 and 72 represent a problem with 2N-dimensional real coefficients. Accordingly, the gravity search adaptive algorithm using real numbers as coefficients, as obtained in equations 64 and 65, is used to calculate a 2N-dimensional gravity search adaptive algorithm as expressed as equations 73 and 74 below.










[





W




[

k
+
1

]






V




[

k
+
1

]





]

=



[





W




[
k
]






V




[
k
]





]



[



1


0




β


β



]


+



G




[
k
]




[



1


1



]







(
73
)









G




[
k
]


=




-
g


1
+




D




[
k
]


T




D




[
k
]








D




[
k
]



-

2










V




[
k
]


T




D




[
k
]





·





V




[
k
]


T




V




[
k
]










V




[
k
]


T




V




[
k
]



+


(




V




[
k
]


T




D




[
k
]



)

2



·



V




[
k
]


T












V




[
k
]


·



D




[
k
]







D




[
k
]


T




D




[
k
]









,










where











D




[
k
]



=




ɛ





W




[
k
]




=



-
2



P



+

2










W




[
k
]


.









(
74
)







It will be seen from equation 72 that equations 73 and 74 are different expressions of an adaptive algorithm for obtaining {right arrow over (wr)}[k] and {right arrow over (wi)}[k].


Accordingly, after obtaining {right arrow over (wr)}[k] and {right arrow over (wi)}[k] from the adaptive algorithm of equations 73 and 74, equations 67, 68, and 69 are used to obtain an N-dimensional complex gravity search adaptive algorithm, as expressed as equations 75 and 76 below.















[





w




[

k
+
1

]






v




[

k
+
1

]





]

=



[





w




[
k
]






v




[
k
]





]



[



1


0




β


β



]


+



g




[
k
]




[



1


1



]








(
75
)








g




[
k
]


=




-
g


1
+









[
k
]

H










[
k
]













[
k
]



-










v




[
k
]


H









[
k
]



+









[
k
]

H





v




[
k
]






·





v




[
k
]


H




v




[
k
]










v




[
k
]


H




v




[
k
]



+


1
4




(





v




[
k
]


H









[
k
]



+









[
k
]

H





v




[
k
]




)

2




·





v




[
k
]


H


R







v




[
k
]













[
k
]

H










[
k
]





·







[
k
]








(
76
)







<Simplification of N-Dimensional Gravity Search Adaptive Algorithm>


{right arrow over (g)}[k] in equation 76 is composed of two terms; the first term is generated when gravity is applied to the ball, and the second term is generated by acceleration when the ball changes its movement direction while moving along the curved surface of the container.



FIG. 9 is a view for explaining a change in acceleration when the movement direction of a ball changes.


Since a change in acceleration due to a change in movement direction of a ball has a very small magnitude compared to the gravitational acceleration, for simplification of implementation, the acceleration due to the change in movement direction is ignored since it has little influence on performance of the adaptive algorithm. If the second term of {right arrow over (g)}[k] in equation 76 is ignored, a simplified gravity search adaptive algorithm is deduced, which is expressed by equation 77 below.










[





w




[

k
+
1

]






v




[

k
+
1

]





]

=



[





w




[
k
]






v




[
k
]





]



[



1


0




β


β



]


+



g




[
k
]




[



1


1



]







(
77
)








g




[
k
]


=



-
g


1
+









[
k
]

H










[
k
]





·







[
k
]







(
78
)







In equations 77 and 78, β is a parameter associated with inertia. If β is large, that is, if β is close to 1, the velocity of the ball does not change easily since the ball has a strong tendency to maintaining its own velocity, while if β is small, that is, if β is close to 0, the ball has a weak tendency to maintain its own velocity. If β is zero, the velocity of the ball depends only on a force currently applied to the ball regardless of the previous velocity of the ball. That is, when β is zero, the adaptive algorithm of equations 75 and 76 is rewritten to equation 79 below.











w




[

k
+
1

]


=



w




[
k
]


+



-
g


1
+









[
k
]

H










[
k
]





·







[
k
]



-










v




[
k
]


H









[
k
]



+









[
k
]

H





v




[
k
]






·





v




[
k
]


H




v




[
k
]










v




[
k
]


H




v




[
k
]



+


1
4




(





v




[
k
]


H









[
k
]



+









[
k
]

H





v




[
k
]




)

2




·





v




[
k
]


H


R







v




[
k
]













[
k
]

H










[
k
]





·







[
k
]








(
79
)







Also, when β is zero, the adaptive algorithm of equations 77 and 78 is rewritten to equation 81 below.











w




[

k
+
1

]


=



w




[
k
]


+



-
g


1
+









[
k
]

H










[
k
]





·







[
k
]








(
80
)







<Gravity Search LMS (GS-LMS) Algorithm>


Like the steepest descent algorithm, in order to implement a GS-LMS algorithm, R and {right arrow over (p)} have to be given. Like when inducing a LMS algorithm, the case of estimating R and {right arrow over (p)} from instantaneous values of the signal as given in equations 14 and 15 is called a GS-LMS algorithm.


A gradient vector can be deduced from equations 14 and 15, which is expressed as equation 81 below.



















[
k
]


=




-
2







p



+

2





R







w




[
k
]




=


-
2



(




x




[
k
]





y
*



[
k
]



-



x




[
k
]






x




[
k
]


H




w




[
k
]




)









=



-
2








x




[
k
]




(



y
*



[
k
]


-




x




[
k
]


H




w




[
k
]




)


=


-
2








x




[
k
]




(



y
*



[
k
]


-



y
^

*



[
k
]



)









=


-
2




x




[
k
]





e
*



[
k
]










(
81
)







Equation 81 is applied to equation 76, thus deducing equation 82.














g




[
k
]


=






-
g


1
+









[
k
]

H










[
k
]





·







[
k
]



-



















v




[
k
]


H









[
k
]



+









[
k
]

H





v




[
k
]






·





v




[
k
]


H




v




[
k
]










v




[
k
]


H




v




[
k
]



+


1
4




(





v




[
k
]


H









[
k
]



+









[
k
]

H





v




[
k
]




)

2




·















v




[
k
]


H


R







v




[
k
]













[
k
]

H










[
k
]





·







[
k
]









=






2

g


1
+

1






e


[
k
]






x




[
k
]


H




x




[
k
]



e
*

[
k
]







x




[
k
]





e
*



[
k
]



+












2









v




[
k
]


H




x




[
k
]





e
*



[
k
]



+


e


[
k
]






x




[
k
]


H




v




[
k
]






·





v




[
k
]


H




v




[
k
]











v




[
k
]


H




v




[
k
]



+


(





v




[
k
]


H




x




[
k
]





e
*



[
k
]



+


e


[
k
]






x




[
k
]


H




v




[
k
]




)

2



·















v




[
k
]


H




x




[
k
]






x




[
k
]


H




v




[
k
]




2




e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]






·

(

2







x




[
k
]





e
*



[
k
]



)









(
82
)







If it is defined that z[k]=custom character[k]Hcustom character[k] and {right arrow over (g)}[k] is represented in terms of z[k], equation 82 can be rewritten to equation 83 below.














g




[
k
]


=






2

g


1
+

4






e


[
k
]






x




[
k
]


H




x




[
k
]



e
*

[
k
]







x




[
k
]





e
*



[
k
]



+












2







z


[
k
]





e
*



[
k
]



+


e


[
k
]





z
*



[
k
]






·





v




[
k
]


H




v




[
k
]











v




[
k
]


H




v




[
k
]



+


(



z


[
k
]





e
*



[
k
]



+


e


[
k
]





z
*



[
k
]




)

2



·













z


[
k
]





z
*



[
k
]






e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]








x




[
k
]





e
*



[
k
]









=






2

g


1
+

4






e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]








x




[
k
]





e
*



[
k
]



+












4








{


z


[
k
]





e
*



[
k
]



}




·





v




[
k
]


H




v




[
k
]











v




[
k
]


H




v




[
k
]



+

4









{


z


[
k
]





e
*



[
k
]



}

2




·
















z


[
k
]




2




e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]








x




[
k
]





e
*



[
k
]



,








(
83
)







Here, custom character{•} represents the real part of the complex number. Accordingly, from equations 83 and 73, the GS-LMS algorithm is given as equations 84 and 85 below.















[





w




[

k
+
1

]






v




[

k
+
1

]





]

=



[





w




[
k
]






v




[
k
]





]



[



1


0




β


β



]


+



g




[
k
]




[



1


1



]








(
84
)








g




[
k
]


=


(



2

g


1
+

4


e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]





+



4







{


z


[
k
]




e
*


}




·





v




[
k
]


H




v




[
k
]











v




[
k
]


H




v




[
k
]



+

4




{


z


[
k
]





e
*



[
k
]



}

2




·





z


[
k
]




2




e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]







)




x




[
k
]





e
*



[
k
]







(
85
)







Meanwhile, if the acceleration component due to a change in movement direction of the ball is ignored from {right arrow over (g)}[k], equations 75 and 79 are rewritten to a simplified GS-LMS algorithm, which is expressed as equations 86 and 87 below.










[





w




[

k
+
1

]






v




[

k
+
1

]





]

=



[





w




[
k
]






v




[
k
]





]



[



1


0




β


β



]


+



g




[
k
]




[



1


1



]







(
86
)







g


[
k
]


=



2

g


1
+

4


e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]








x




[
k
]





e
*



[
k
]







(
87
)







If β is zero, equation 79 can be rewritten to a simplified GS-LMS algorithm, which is expressed as equation 88 below.











w




[

k
+
1

]


=



w




[
k
]


+


(



2

g


1
+

4


e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]





+



4







{


z


[
k
]





e
*



[
k
]



}




·





v




[
k
]


H




v




[
k
]











v




[
k
]


H




v




[
k
]



+

4




{


z


[
k
]





e
*



[
k
]



}

2




·





z


[
k
]




2




e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]







)




x




[
k
]





e
*



[
k
]








(
88
)







If β is zero, equation 80 can be rewritten to a simplified GS-LMS algorithm, which is expressed as equation 89 below.











w




[

k
+
1

]


=



w




[
k
]


+



2

g


1
+

4


e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]








x




[
k
]





e
*



[
k
]








(
89
)







In equation 87, {right arrow over (g)}[k] has been normalized with respect to both {right arrow over (x)}[k] and {right arrow over (e)}[k]. Accordingly, the convergence speed of the simplified GS-LMS algorithm of equations 86 and 87 may become slow during the early stage of adaptation when the power of e[k] is large. In this case, one method for improving the convergence speed is to vary g over time.


For example, it is possible to make g be in proportion to the power of an error signal e[k], as follows.

g[k]={right arrow over (g)}|e[k]|2  (90)


By applying equation 90 to equation 87, equations 91 and 92 are obtained as follows.










[





w




[

k
+
1

]






v




[

k
+
1

]





]

=



[





w




[
k
]






v




[
k
]





]



[



1


0




β


β



]


+



g




[
k
]




[



1


1



]







(
91
)








g




[
k
]


=



2


g
~






e


[
k
]




2



1
+

4


e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]








x




[
k
]





e
*



[
k
]







(
92
)







Here, a range of the {tilde over (g)} value is given by equation 93 below.









0
<


g
~


(

1
-
β

)


<
2




(
93
)







If β is zero, equations 91 and 92 can be rewritten to equation 94 below.











w




[

k
+
1

]


=



w




[
k
]


+



2


g
~






e


[
k
]




2



1
+

4


e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]








x




[
k
]





e
*



[
k
]








(
94
)







The adaptive algorithm written as equation 94 has a structure that is very similar to the normalized LMS algorithm of equation 95.











w




[

k
+
1

]


=



w




[
k
]


+



μ
~


δ
+




x




[
k
]


H




x




[
k
]








x




[
k
]





e
*



[
k
]








(
95
)







For easy comparison, equation 94 is rearranged to equation 96 below.











w




[

k
+
1

]


=



w




[
k
]


+




g
~

/
2




1
/
4






e


[
k
]




2


+




x




[
k
]


H




x




[
k
]








x




[
k
]





e
*



[
k
]








(
96
)







If equations 97 and 98 below are satisfied, equation 95 becomes identical to equation 96.









δ
=

1

4





e


[
k
]




2







(
97
)







μ
~

=


g
~

2





(
98
)







This means that if there is no memory in the GS-LMS algorithm of equation 94, the GS-LMS algorithm becomes a normalized LMS algorithm. According to a different interpretation, this means that a GS-LMS algorithm is an enhanced version of the normalized LMS by introducing memory or inertia.


The above interpretation about the GS-LMS algorithm has very important significance. The reason is because the characteristics of the GS-LMS algorithm can be understood based on the well-known characteristics of the normalized LMS algorithm.


It is assumed that equations 99 and 100 below are satisfied.

1<<4e[k]custom character[k]Hcustom character[k]e*[k]  (99)
4δ|e[k]|2<<4e[k]custom character[k]Hcustom character[k]e*[k]  (100)


In this case, the GS-LMS algorithm may be further simplified. That is, under the assumption, equation 92 can be rewritten to equation 101 below.











g




[
k
]


=



2


g
~






e


[
k
]




2




4

δ





e


[
k
]




2


+

4


e


[
k
]






x




[
k
]


H




x




[
k
]





e
*



[
k
]








x




[
k
]





e
*



[
k
]







(
101
)







By arranging equation 101, the algorithms of equations 91 and 92 are simplified to equation 102 and 103 below.










[





w




[

k
+
1

]






v




[

k
+
1

]





]

=



[





w




[
k
]






v




[
k
]





]



[



1


0




β


β



]


+



g




[
k
]




[



1


1



]







(
102
)








g




[
k
]


=



μ
~


δ
+




x




[
k
]


H




x




[
k
]








x




[
k
]





e
*



[
k
]







(
103
)







Also, the algorithms of equations 101 and 103 become identical to the normalized LMS algorithm when β is zero.



FIG. 10 is a diagram illustrating an example of a gravity search adaptive apparatus.


The gravity search adaptive apparatus illustrated in FIG. 10 corresponds to an example where the GS-LMS algorithm is used. In FIG. 10, a modeling parameter calculator 1030 uses the gravity search adaptive algorithm described above to update a parameter for making an error signal output from an error detector 1031 converge on a minimum value and to apply the updated parameter to a system modeling unit 1020.



FIG. 11 is a flowchart illustrating an example of a system modeling method using a gravity search adaptive algorithm.


Referring to FIGS. 10 and 11, an adaptive controller 1030 calculates a system modeling parameter using the gravity search adaptive algorithm (1110). The system modeling parameter is a value for minimizing an error signal which is a difference between an output signal of a real system and a modeled signal.


Then, the adaptive controller 1030 applies the system modeling parameter to the system modeling unit 1020 (1120). Then, the adaptive controller 1030 applies the same signal to both the system 1010 and the system modeling unit 1020 (1130). Then, the adaptive controller 1030 calculates an error signal which is a difference between an output signal of the system 1010 and an output signal of the system modeling unit 1020 (1140). Successively, the adaptive controller 1030 compares the error signal to the previously calculated error signal to thereby determine whether the error signal converges on a minimum value (1150).


If it is determined in operation 1150 that the error signal does not converge on a minimum value, the adaptive controller 1030 returns to operation 1110 to update the system modeling parameter using the gravity search adaptive algorithm. That is, the procedure from operation 1110 to operation 1150 is repeated until the error signal converges on the minimum value.


Also, when calculating a system parameter using the gravity search adaptive algorithm, under an assumption that a ball moves along the inner surface of a parabolic, concave container filled up with liquid, the adaptive controller 1030 sets the mass m of the ball, a friction force g of liquid, a sampling interval Ts, and a force Fk applied to the ball, and applies the set values to equation 37 to thereby calculate or update a parameter of the system modeling unit 1020.


Meanwhile, if it is determined in operation 1150 that the error signal converges on the minimum, the adaptive controller 1030 estimates the characteristics of the system 1010 using a final parameter calculated in operation 1160.


Therefore, as described above, the gravity search adaptive apparatus and method can easily adjust a convergence speed and a convergence pattern.


A number of examples have been described above. Nevertheless, it will be understood that various modifications may be made. For example, suitable results may be achieved if the described techniques are performed in a different order and/or if components in a described system, architecture, device, or circuit are combined in a different manner and/or replaced or supplemented by other components or their equivalents. Accordingly, other implementations are within the scope of the following claims.

Claims
  • 1. A gravity search adaptive apparatus for modeling a system, the apparatus comprising: a system modeling circuit configured to receive an input signal input to the system, to convert the input signal using a model parameter vector, and to output the converted signal; andan adaptive controller configured to calculate, using a gravity search adaptive algorithm for solving a problem of finding a global minimum of a cost function which is in the form of a quadratic function, the model parameter vector when an error signal, which is a difference between an output signal of the system and an output signal of the system modeling circuit, converges on a minimum power value, and to apply the calculated model parameter vector to the system modeling circuit,wherein the adaptive controller calculates a power value ε of the error signal, the power value ε being expressed as equation 104 below: ε=σy2−2pw[k]+σx2w[k]2  (104),where w[k] is the model parameter vector resulting from k-th iteration of the calculation of the model parameter vector, p=E{x[k]y[k]}, σx2=E{x2[k]}, x[k] is the input signal, y[k] is the output signal of the system, σy2 is E{y2[k]}, and E{•} represents an ensemble average.
  • 2. The gravity search adaptive apparatus of claim 1, wherein the adaptive controller comprises: an error detector configured to detect and output the error signal; anda modeling parameter calculator configured to calculate the model parameter vector when the error signal converges on the minimum power value and to apply the calculated model parameter vector to the system modeling unit.
  • 3. The gravity search adaptive apparatus of claim 1, wherein the gravity search adaptive algorithm is estimated under an assumption that a ball moves along an inner surface of a parabolic, concave container filled up with liquid.
  • 4. The gravity search adaptive apparatus of claim 3, wherein the gravity search adaptive algorithm uses a second-order differential equation 105 below: m{umlaut over (w)}+f{dot over (w)}=F  (105),where w represents the model parameter vector of the system modeling circuit, F represents a force applied to the ball in a direction of w, m represents a mass of the ball, f represents a friction force depending on viscosity of the liquid, and {dot over (w)} and {umlaut over (w)} represent a first-order derivative and a second-order derivative with respect to time, respectively.
  • 5. The gravity search adaptive apparatus of claim 3, wherein the adaptive controller updates the model parameter vector of the system modeling circuit using a first-order gravity search adaptive algorithm that is expressed as equation 106 below:
  • 6. The gravity search adaptive apparatus of claim 3, wherein the adaptive controller updates the model parameter vector of the system modeling circuit using an N-dimensional gravity search adaptive algorithm that is expressed as equation 108 below:
  • 7. The gravity search adaptive apparatus of claim 3, wherein the adaptive controller updates the model parameter vector of the system modeling circuit using an N-dimensional gravity search adaptive algorithm having complex coefficients that are expressed as equation 110 below:
  • 8. The gravity search adaptive apparatus of claim 7, wherein if a parameter β associated with inertia is zero, algorithms of equations 110 and 111 are expressed as equation 112 below:
  • 9. The gravity search adaptive apparatus of claim 3, wherein the adaptive controller updates the model parameter vector of the system modeling circuit using a gravity search adaptive algorithm that is expressed as equation 113 below:
  • 10. The gravity search adaptive apparatus of claim 9, wherein if a parameter β associated with inertia is zero, algorithms of equations 113 and 114 are expressed as equation 115 below:
  • 11. The gravity search adaptive apparatus of claim 3, wherein the adaptive controller updates the model parameter vector of the system modeling circuit using a gravity search adaptive algorithm that is expressed as equation 116 below:
  • 12. The gravity search adaptive apparatus of claim 11, wherein the adaptive controller applies equation 118 to equation 117, thus obtaining equations 119 and 120 below:
  • 13. The gravity search adaptive apparatus of claim 12, wherein if β is zero, the adaptive controller defines equations 119 and 120 by equation 121 below:
  • 14. The gravity search adaptive apparatus of claim 12, wherein when equations 122 and 123 are satisfied, the adaptive controller defines the equation 120 by equation 124, and obtains an algorithm defined as equations 125 and 126 from the equation 124:
  • 15. A method comprising: calculating, by an adaptive controller using a gravity search adaptive algorithm for solving a problem of finding a global minimum of a cost function which is in the form of a quadratic function, a model parameter vector of a system modeling circuit corresponding to a minimum power value of an error signal which is a difference between an output signal of a system and an output signal of the system modeling circuit when an input signal is input to the system and the system modeling circuit; andapplying, by the adaptive controller, the model parameter vector to the system modeling circuit,wherein the calculating further comprises:calculating a power value ε of the error signal that is expressed as follows: ε=σy2−2pw[k]+σx2w[k]2,where w[k] is the model parameter vector resulting from k-th iteration of the calculation of the model parameter vector, p is E{x[k]y[k]}, σx2 is E{x2[k]}, x[k] is the input signal, y[k] is the output signal of the system, σy2 is E{y2[k]}, and E{•} represents an ensemble average.
  • 16. The method of claim 15, further comprising: comparing, by the adaptive controller, the error signal to a previously calculated error signal to determine whether the error signal converges on the minimum power value; andupdating, by the adaptive controller, if the error signal does not converge on the minimum power value, the model parameter vector using the gravity search adaptive algorithm.
  • 17. The method of claim 15, further comprising: comparing, by the adaptive controller, the error signal to a previously calculated error signal to determine whether the error signal converges on the minimum power value; andestimating, by the adaptive controller, if the error signal converges on the minimum power value, system characteristics of the system using the calculated model parameter vector.
Priority Claims (2)
Number Date Country Kind
10-2010-0133789 Dec 2010 KR national
10-2011-0090383 Sep 2011 KR national
Non-Patent Literature Citations (3)
Entry
Mathews et al., “Adaptive Filters”, Chapter 4, 2003, 48 pages, http://www.ece.utah.edu/˜mathews/ece6550/chapter4.pdf.
Dornean et al., “System Identification with Least Mean Square Adaptive Algorithm” Interdisciplinarity in Engineering Scientific International Conference, Nov. 2007, 4 pages.
S. Haykin et al., “Least-Mean-Square Adaptive Filters”, 2003, John Wiley & Sons Inc.
Related Publications (1)
Number Date Country
20120166159 A1 Jun 2012 US