This application claims priority of Chinese Application No. 201410535884.0 filed on Oct. 11, 2014, the entire contents of which are hereby incorporated by reference.
The present disclosure generally relates to the field of stereo display technologies and, more particularly, relates to methods and apparatuses for object tracking and 3D display based on such object tracking.
In most of current object tracking and prediction methods based on real-time videos, a possible area in which an object may appear in a next frame is predicted using a Kalman filter based on an object tracking result of a current frame. When the next frame is played, the object is searched in the predicted area of the next frame. By using the prediction result of a previous frame, the searching area of the current frame is reduced. Therefore, the amount of calculation is significantly reduced, and the tracking speed is accelerated, improving real-time object tracking.
The head tracker 102 may be configured to track a position of a user's head. The tracking module 104 may be configured to perform calculation and control the display module 106 and the controllable optical system 108 based on the position of the user's head obtained by the head tracker 102, such that a correct image can be displayed to the user. The display module 106 may be configured to display the image under the control of the control module 104-4. The controllable optical system 108 may be configured to perform adjustment under the control of the control module 104-4, such that the correct display can be provided to the user.
However, in the object tracking process based on a real-time video, an infrared detection device, a depth camera, or a wearable device, etc., due to irresistible factors (e.g., the calculation time), when the user is moving fast, a position tracking result of the tracked object obtained by a current tracking algorithm may have a certain spatial delay.
In fact, because the user may continue moving in the time period Δt, an actual position of the tracked object is changed at time t0+Δt. Therefore, the actual position of the tracked object is not at the position coordinates (x0, y0, z0), whereas the actual position of the tracked object moves to position coordinates (x′, y′, z′) at time t0+Δt. Due to the irresistible factors (e.g., the calculation time), the position calculated by using the current tracking algorithm has a time delay Δt. The difference between the calculated position and the actual position is determined by Δt and the moving speed of the tracked object. In this case, if no compensation for the spatial delay of the tracked object is performed during an image arrangement of the 3D display, reverse visual phenomena may happen. That is, the left eye of the user is actually located at the right eye viewing area of the 3D stereo display, and the right eye of the user is actually located at the left eye viewing area of the 3D stereo display, thereby presenting an erroneous display effect.
The disclosed methods and apparatuses are directed to solve one or more problems set forth above and other problems. For example, the disclosed methods and apparatuses can provide technical solutions for tracking a moving object in both a two-dimensional (2D) plane and a three-dimensional (3D) space, improving data accuracy of object tracking.
One aspect of the present disclosure includes an object tracking method. The method includes obtaining current position coordinates of a tracked object for a first time using a tracking algorithm and initializing a filter acting on a time-varying system based on the obtained current position coordinates. The method further includes updating a system state through the filter acting on the time-varying system when the tracking algorithm outputs new current position coordinates of the tracked object with a spatial delay, and comparing speed of the tracked object to a compensation determination threshold. Further, the method includes when the speed of the tracked object is greater than the compensation determination threshold, compensating the new current position coordinates of the tracked object with the spatial delay through the filter acting on the time-varying system, and outputting the compensated current position coordinates.
Another aspect of the present disclosure includes an object tracking apparatus. The apparatus includes an object tracking unit configured to track a position of an object to obtain current position coordinates of the tracked object. The apparatus also includes an updating and compensation unit, including a filter acting on a time-varying system, configured to initialize the filter acting on the time-varying system when the object tracking unit outputs the position coordinates of the tracked object for a first time, update a system state through the filter acting on the time-varying system when the object tracking unit outputs new current position coordinates with a spatial delay of the tracked object, and when speed of the tracked object is greater than a compensation determination threshold, provide delay compensation for the current position coordinates of the tracked object through the filter acting on the time-varying system and output the compensated current position coordinates of the tracked object.
Another aspect of the present disclosure includes a 3D display apparatus. The apparatus includes an object tracking apparatus, including an object tracking unit and an updating and compensation unit, configured to obtain current position coordinates of a tracked object, where the object tracking unit is configured to track a position of an object to obtain current position coordinates of the tracked object; and the updating and compensation unit, including a filter acting on a time-varying system, is configured to initialize the filter acting on the time-varying system when the object tracking unit outputs the position coordinates of the tracked object for a first time, update a system state through the filter acting on the time-varying system when the object tracking unit outputs new current position coordinates with a spatial delay of the tracked object, and when speed of the tracked object is greater than a compensation determination threshold, provide delay compensation for the current position coordinates of the tracked object through the filter acting on the time-varying system and output the compensated current position coordinates of the tracked object. The apparatus also includes a control module configured to control an image arrangement based on the current position coordinates and a display module configured to display an image corresponding to the image arrangement. Further, the apparatus includes a light-splitting device configured to send the image displayed by the display module to the left eye and right eye of a user, such that a 3D image is displayed.
Other aspects of the present disclosure can be understood by those skilled in the art in light of the description, the claims, and the drawings of the present disclosure.
The following drawings are merely examples for illustrative purposes according to various disclosed embodiments and are not intended to limit the scope of the present disclosure.
Reference will now be made in detail to exemplary embodiments of the disclosure, which are illustrated in the accompanying drawings. Wherever possible, the same reference numbers will be used throughout the drawings to refer to the same or like parts.
An object tracking apparatus may be implemented on any appropriate computing circuitry platform.
Processor 1102 may include any appropriate processor or processors. Further, processor 1102 can include multiple cores for multi-thread or parallel processing. Storage medium 1104 may include memory modules, such as ROM, RAM, flash memory modules, and mass storages, such as CD-ROM and hard disk, etc. Storage medium 1104 may store computer programs for implementing various processes, when the computer programs are executed by processor 1102.
Further, peripherals 1112 may include various sensors and other I/O devices, such as keyboard and mouse, and communication module 1108 may include certain network interface devices for establishing connections through communication networks. Database 1110 may include one or more databases for storing certain data and for performing certain operations on the stored data, such as visual-based obstacle detection.
Step S502: a tracking algorithm outputs position coordinates of a tracked object for the first time, and a filter acting on a time-varying system is initialized based on the position coordinates of the tracked object.
The filter acting on the time-varying system may be a Kalman filter, a smooth filter, a Butterworth filter, a binomial coefficient filter, or a Wiener filter.
In certain embodiments, the filter acting on the time-varying system may be the Kalman filter. The Kalman filter keeps tracks of the estimated system state and the variance or uncertainty of the estimate. The Kalman filter produces estimates of actual values of measurements and their associated calculated values by predicting a value, estimating the uncertainty of the predicted value, and computing a weighted average of the predicted value and the measured value. The most weight is given to the value with the least uncertainty.
The initialization of the Kalman filter may include: initialization of a counter, a coefficient matrix of delay compensation, a sampling interval of a sensor, a posteriori estimation of system state variables, a coefficient matrix of system state transition, a noise gain matrix of the system state, a noise covariance matrix of the system state, a measurement coefficient matrix, a measurement noise covariance matrix, and an error covariance matrix of the posteriori estimation of the system state variables.
Step S504: when the tracking algorithm outputs new current position coordinates of the tracked object with a spatial delay, the system state is updated through the filter acting on the time-varying system.
For example, the Kalman filter, in combination with a strong tracking filter, can update the system state and provide delay compensation for the current position coordinates of the tracked object. The strong tracking filter may be a strong tracking filter with multiple suboptimal fading factors. The strong tracking filter needs to be initialized before the strong tracking filter is used. Specifically, the initialization of the strong tracking filter includes: initialization of a proportional coefficient of the multiple suboptimal fading factors, a forgetting factor of the strong tracking filter, and a weakening factor of the strong tracking filter.
Further, in Step S504, the system state can be updated through the Kalman filter and the strong tracking filter.
Step S504-2: new current position coordinates of a tracked object are obtained.
In Step S504-2, multiple predetermined object tracking methods can be used to obtain the current position coordinates of the tracked object.
Step S504-4: based on the current position coordinates, a priori estimation {circumflex over (X)}_ of the system state at a sampling time point is calculated by a state prediction equation.
Step S504-6: a residual error γ of a measurement equation is calculated using the priori estimation {circumflex over (X)}_.
Step 504-8: an intermediate variable V of the strong tracking filter is calculated using the residual error γ.
Step S504-10: an intermediate variable N of the strong tracking filter is calculated using the intermediate variable V.
Step S504-12: an intermediate variable M of the strong tracking filter is calculated using the intermediate variable N.
Step S504-14 a coefficient c of the multiple suboptimal fading factors is calculated using the intermediate variable M.
Step S504-16: the multiple suboptimal fading factors λi of the strong tracking filter is calculated using the coefficient c of the multiple suboptimal fading factors.
Step S504-18: an error covariance matrix P_ of a priori estimation of the system state of the Kalman filter is calculated using the multiple suboptimal fading factors λi of the strong tracking filter.
Step S504-20: a Kalman gain Kg of the Kalman filter is calculated using the error covariance matrix P— of a priori estimation of the system state.
Step S504-22: using Kalman gain Kg, a posteriori estimation {circumflex over (X)} of the system state at a sampling time point is calculated by a measurement updating equation.
Step S504-24: an error covariance matrix P of the posteriori estimation of the system state of the Kalman filter is calculated using the posteriori estimation {circumflex over (X)}.
Returning to
Step S506: the speed of the tracked object is compared to a compensation determination threshold, and whether the current position coordinates need to be compensated is determined.
Step S508: when the speed of the tracked object is greater than the compensation determination threshold, the current position coordinates of the tracked object with the spatial delay are provided delay compensation through the filter acting on the time-varying system, and the compensated current position coordinates are outputted.
The compensation for the current position coordinates of the tracked object with the spatial delay performed by the Kalman filter and the strong tracking filter may include the following.
Based on the above calculated parameters, the compensated current position coordinates of the tracked object are calculated by:
wherein (xreal, yreal, zreal) are the compensated current position coordinates of the tracked object; (x, y, z) are the position coordinates in the posteriori estimation {circumflex over (X)} of the Kalman filter; ∥(vx, vy, vz)∥ is 2-norm of a speed value (vx, vy, vz); S is a coefficient matrix of the delay compensation; and r is a compensation determination threshold, and τ>0.
The current position coordinates of the tracked object may be three-dimensional (3D) coordinates or two-dimensional (2D) coordinates. The above current position coordinates are the 3D coordinates. When the 2D coordinates are used, the 3D coordinates can be converted to the 2D coordinates.
In certain embodiments, the filter acting on the time-varying system may be used to filter noise for the current position coordinates, greatly reducing calculation error and system noise of the tracking algorithm, and removing data jilter in the current position coordinates of the tracked object. The usage of the multiple suboptimal fading factors of the strong tracking filter improves the tracking performance of the filter acting on the time-varying system for a moving object. Therefore, the system state variables of an actual motion state at a time point which is the closest time point for obtaining the current position of the tracked object can be obtained.
The object tracking unit 602 may be configured to track a position of an object to obtain current position coordinates of the tracked object.
The updating and compensation unit 604 includes a filter acting on a time-varying system. When the object tracking unit 602 outputs the position coordinates of the tracked object for the first time, the updating and compensation unit 604 may be configured to initialize the filter acting on the time-varying system. When the object tracking unit 602 outputs new current position coordinates with a spatial delay of the tracked object, the updating and compensation unit 604 may be configured to update the system state through the filter acting on the time-varying system. When the speed of the tracked object is greater than a compensation determination threshold, the updating and compensation unit 604 may be configured to compensate the current position coordinates of the tracked object through the filter acting on the time-varying system and output the compensated current position coordinates of the tracked object.
The filter acting on the time-varying system may be a Kalman filter, a smooth filter, a Butterworth filter, a binomial coefficient filter, or a Wiener filter.
When the filter acting on the time-varying system used herein is the Kalman filter, the Kalman filter may be initialized based on the current position coordinates obtained by the object tracking unit 602 for the first time. The initialization of the Kalman filter includes: initialization of a counter, a coefficient matrix of delay compensation, a sampling interval of a sensor, a posteriori estimation of system state variables, a coefficient matrix of system state transition, a noise gain matrix of the system state, a noise covariance matrix of the system state, a measurement coefficient matrix, a measurement noise covariance matrix, and an error covariance matrix of the posteriori estimation of the system state variables.
The updating and compensation unit 604 updates the system state through the Kalman filter and a strong tracking filter and provides delay compensation for the current position coordinates of the tracked object. The strong tracking filter may be a strong tracking filter with multiple suboptimal fading factors. The strong tracking filter needs to be initialized before used. Specifically, the initialization of the strong tracking filter includes: initialization of a proportional coefficient of the multiple suboptimal fading factors, a forgetting factor of the strong tracking filter, and a weakening factor of the strong tracking filter.
The current position coordinates are updated by the updating and compensation unit 604 using the Kalman filter and the strong tracking filter, details of which are described in the followings.
The current position coordinates are obtained from the object tracking unit. Based on the current position coordinates, a priori estimation {circumflex over (X)}_ of the system state at a sampling time point is calculated by a state prediction equation. A residual error γ of a measurement equation is calculated using the priori estimation {circumflex over (X)}_. An intermediate variable V of the strong tracking filter is calculated using the residual error γ. An intermediate variable N of the strong tracking filter is calculated using the intermediate variable V. An intermediate variable M of the strong tracking filter is calculated using the intermediate variable N. A coefficient c of the multiple suboptimal fading factors is calculated using the intermediate variable M. The multiple suboptimal fading factors λi of the strong tracking filter is calculated using the coefficient c of the multiple suboptimal fading factors. An error covariance matrix P_ of a priori estimation of the system state of the Kalman filter is calculated using the multiple suboptimal fading factors λi of the strong tracking filter. A Kalman gain Kg of the Kalman filter is calculated using the error covariance matrix P_ of the priori estimation of the system state. Using Kalman gain Kg, a posteriori estimation {circumflex over (X)} of the system state at a sampling time point is calculated by a measurement updating equation. An error covariance matrix P of the posteriori estimation of the system state of the Kalman filter is calculated using the posteriori estimation {circumflex over (X)}.
The current position coordinates of the tracked object are provided delay compensation by the updating and compensation unit 604 using the Kalman filter and the strong tracking filter, details of which are described in the followings.
Based on the above calculated parameters, the compensated current position coordinates of the tracked object are calculated by:
wherein (xreal, yreal, zreal) are the compensated current position coordinates of the tracked object; (x, y, z) are the position coordinates in the posteriori estimation {circumflex over (X)} of the Kalman filter; ∥(vx, vy, vz)∥ is 2-norm of speed values (vx, vy, vz); S is a coefficient matrix of the delay compensation; and r is a compensation determination threshold, and τ>0.
In certain embodiments, the updating and compensation unit 604 uses the filter acting on the time-varying system to filter noise for the current position coordinates, greatly reducing calculation error and system noise of a tracking algorithm, and removing data jilter in the current position coordinates of the tracked object. The usage of the multiple suboptimal fading factors of the strong tracking filter improves the tracking performance of the filter acting on the time-varying system for a moving object. Therefore, the system state variables of an actual motion state at a time point which are the closest time point for obtaining the current position of the tracked object can be obtained.
Step S702: current position coordinates of a tracked object are obtained. Specifically, the current position coordinates of the tracked object may be obtained by using the object tracking process 500 shown in
Step S704: an image arrangement is obtained based on the current position coordinates of the tracked object, and a corresponding 3D image is displayed to a user on a display apparatus. The display apparatus may include a display module and a light-splitting device. The image displayed by the display module is sent to the left eye and right eye of the user through the light-splitting device, thereby displaying the 3D image.
The object tracking apparatus 600 may be configured to obtain current position coordinates of a tracked object. The structure of the object tracking apparatus 600 may include those described with respect to
The control module 802 may be configured to control an image arrangement based on the current position coordinates. The display module 804 may be configured to display an image corresponding to the image arrangement. The light-splitting device 806 may be configured to send the image displayed by the display module 804 to the left eye and right eye of a user, such that a 3D image is displayed. The light-splitting device 806 may be a liquid crystal lens, a liquid crystal microlens, a microlens array, or a slit grating.
Further, more specifically, in certain embodiments, the compensation algorithm in the object tracking process for delay compensation may include the following steps.
At the beginning, in the object tracking process based on real-time videos, an infrared detection device, a depth camera, or a wearable device, a sensor continuously samples signals at a same time interval, and a series of image/data frames are formed. Assuming that the time needed for calculating each image/data frame using a tracking algorithm is the same, the position of the tracked object obtained by calculating each frame has a same time delay Δt.
1. Initialization of the Compensation Algorithm.
Original sampling data at time point t0 is calculated using the current tracking algorithm to obtain position coordinates (x0, y0, z0) of a tracked object. The initialization is performed after the tracking algorithm completes the processing of the first image/data frame and outputs the first group position coordinates (x0, y0, z0) of the tracked object. The initialization process may include the initialization of the following values.
1.1 Initialization of a Kalman Filter.
K=0, a counter is initialized.
A coefficient matrix S of delay compensation is represented by:
wherein O1*3=(0 0 0); S′=(1 Δt (Δt)2/2); and Δt is a time delay caused by irresistible factors (e.g., calculation time).
When k=0, a posteriori estimation {circumflex over (X)} of the system state (x, vx, ax, y, vy, ay, z, vz, az) is initialized as an initial state and represented by:
{circumflex over (X)}=(x0,0,0,y0,0,0,z0,0,0)T, (3)
wherein (x0, y0, z0) is the position coordinates of the tracked object outputted by the tracking algorithm for the first time; vx, vy and vz are speeds on directions x, y and z, respectively; ax, ay and az are accelerations on the directions x, y and z, respectively; and x, vx, ax, y, vy, ay, z, vz, and az are initialized to 0.
A coefficient matrix A of the system state transition is represented by:
wherein
and T is a sample interval of a sensor (for example, if the sampling rate of the sensor is 30 FPS, T=( 1/30)s).
A noise gain matrix G of the system state is represented by:
wherein
and T is a sample interval of a sensor.
A noise covariance matrix Q of the system state is a covariance matrix of acceleration noise (i.e., a diagonal matrix). The noise covariance matrix Q of the system state is represented by:
wherein q11, q22 and q33>0; and q11, q22 and q33 correspond to noise variance of the acceleration ax, ay, and az, respectively. It should be noted that q11, q22 and q33 may be selected correspondingly based on the intensity of changes in the accelerations.
A measurement coefficient matrix H is represented by:
R is a measurement noise covariance matrix, that is, an error covariance matrix (a diagonal matrix) of the position of the tracked object outputted by the tracking algorithm. The measurement noise covariance matrix is represented by:
wherein r11, r22, and r33>0; and r11, r22, and r33 correspond respectively to the error covariance of the object position x, y, z calculated by the tracking algorithm. It should be noted that r11, r22, and r33 may be selected correspondingly based on actual error of the tracking algorithm.
P is an error covariance matrix of the posteriori estimation of the system state of the Kalman filter. The error covariance matrix of the posteriori estimation of the system state of the Kalman filter is represented by:
P=diag(p11,p12, . . . ,p99) (9)
wherein p11, p12, . . . p99>0 and correspond respectively to the error covariance of a priori estimation of the system state variables (x, vx, ax, y, vy, ay, z, vz, az); and when P is initialized, the values of p11, p44 and p77 can be selected as smaller values (corresponding respectively to x, y, z), whereas other pii values can be selected as bigger values.
1.2 Initialization of a Strong Tracking Filter with Multiple Suboptimal Fading Factors as Follows.
α=(α1, α2, . . . , α9) is a proportional coefficient of the multiple suboptimal fading factors, wherein αi≧1 and correspond respectively to the rate of change of the system state variables (x, vx, ax, y, vy, ay, z, vz, az); if it is known from experience that the jth state variable among this group of state variables may have a sudden change, the value of αj may be increased accordingly; if there is no experience to follow, the value of a, may be set as αi=1, i=1, 2, . . . , 9; at this time, the multiple suboptimal fading factors are degenerated into a single suboptimal fading factor.
ρ: 0<p≦1, and ρ is a forgetting factor of the strong tracking filter. In general, ρ=0.95.
β: β≧1, and β is a weakening factor of the strong tracking filter, and the purpose of the weakening factor is to make a filtering result smoother. β is selected based on actual needs.
1.3 Setting a Compensation Determination Threshold as Follows.
τ: τ>0, and τ is a compensation determination threshold. When the moving speed of the object is greater than or equal to the compensation determination threshold, it indicates that the object moves too fast and the compensation algorithm needs to be performed for the tracking result of the object. When the speed of the object is less than the compensation determination threshold, it indicates that the object does not move or moves slowly, and the tracking result of the object is not compensated.
2. Compensating for a Tracking Delay Using the Kalman Filter and the Strong Tracking Filter.
When the tracking algorithm outputs the data of the second frame and the data of the following frames, the tracking algorithm performs compensation for the tracking delay using the Kalman filter and the strong tracking filter.
Step S900-1: a tracking algorithm re-outputs a group of position coordinates (x1, y1, z1) of the tracked object, Z=(x1, y1, z1). Z is a measurement value of the current tracked object.
Step S900-2: based on the obtained position coordinates (x1, y1, z1), a priori estimation {circumflex over (X)}— of the system state variables (x, vx, ax, y, vy, ay, z, vz, az) at a sampling time point is calculated by a state prediction equation {circumflex over (X)}_=A*{circumflex over (X)}, wherein A is a coefficient matrix of the system state transition, and {circumflex over (X)} is a posteriori estimation of the system state (x, vx, ax, y, vy, ay, z, vz, az).
Step S900-3: a residual error γ of a measurement equation is calculated by γ=Z−H*{circumflex over (X)}_, wherein Z is a measurement value of the current tracked object; {circumflex over (X)}_ is a priori estimation of the system state variables (x, vx, ax, y, vy, ay, z, vz, az) at a sampling time point; and H is a measurement coefficient matrix.
Step S900-4: an intermediate variable V of the strong tracking filter is calculated by
wherein γ is a residual error of the measurement equation; ρ is a forgetting factor of the strong tracking filter, and V— is a V value of a previous strong filtering-Kalman filtering cycle.
Step S900-5: an intermediate variable N of the strong tracking filter is calculated by N=V−H*G*Q*GT*HT−β*R, wherein V is an intermediate variable of the strong tracking filter; H is a measurement coefficient matrix; R is a measurement noise covariance matrix; G is a noise gain matrix of the system state; Q is a noise covariance matrix of the system state; and β is a weakening factor of the strong tracking filter.
Step S900-6: an intermediate variable M of the strong tracking filter is calculated by M=A*P*AT*HT*H, wherein H is a measurement coefficient matrix; A is a coefficient matrix of the system state transition; and P is an error covariance matrix of the posteriori estimation of the system state of the Kalman filter.
Step S900-7: a coefficient c of the multiple suboptimal fading factors is calculated by
wherein N is an intermediate variable of the strong tracking filter; tr(N) is to calculate a trace of the matrix N, that is, a sum of diagonal elements of the matrix N; α=(α1, α2, . . . , α9) is a proportional coefficient of the multiple suboptimal fading factors; αi is each element of α; M is an intermediate variable of the strong tracking filter; and Mii is each diagonal element of the matrix M, and i=1, 2, . . . , 9.
Step S900-8: the multiple suboptimal fading factors λi of the strong tracking filter are calculated by λi=max(αi*c,1), wherein c is a coefficient c of the multiple suboptimal fading factors; and i=1, 2, . . . , 9, and (λ1, λ2, . . . , λ9) are multiple suboptimal fading factors of the strong tracking filter.
Step S900-9: an error covariance matrix P— of a priori estimation of the system state of the Kalman filter is calculated by P_=diag(λ1, λ2, . . . λ9)*A*P*AT+G*Q*GT, wherein
A is a coefficient matrix of the system state transition; P is an error covariance matrix of the posteriori estimation of the system state of the Kalman filter; G is a noise gain matrix of the system state; Q is a noise covariance matrix of the system state; and a diag(λ1, λ2, . . . , λ9) represents to generate a 9*9 diagonal matrix (i.e., the diagonal elements are λ1, λ2, . . . , λ9, respectively, and other elements are 0).
Step S900-10: a Kalman gain Kg of the Kalman filter is calculated by Kg=P*HT*(H*P_*HT+R)−, wherein P— is an error covariance matrix of a priori estimation of the system state; H is a measurement coefficient matrix; R is a measurement noise covariance matrix; and “−”represents to calculate inverse of a matrix.
Step S900-11: a posteriori estimation {circumflex over (X)} of the system state variables (x, vx, ax, y, vy, ay, z, vz, az) at a sampling time point is calculated by {right arrow over (X)}={circumflex over (X)}_+Kg*γ, wherein {circumflex over (X)}_ is a priori estimation of the system state variables (x, vx, ax, y, vy, ay, z, vz, az) at a sampling time point; Kg is a Kalman gain of the Kalman filter; and γ is a residual error of a measurement equation.
Step S900-12: an error covariance matrix P of the posteriori estimation of the system state of the Kalman filter is calculated by P=(I−Kg*H)*P_, wherein P— is an error covariance matrix of a priori estimation of the system state; H is a measurement coefficient matrix; and Kg is a Kalman gain of the Kalman filter.
Step S900-13: actual position coordinates (xreal, yreal, zreal) of the tracked object are obtained after the position coordinates (x1, y1, z1) outputted by the tracking algorithm are filtered and compensated.
The actual position coordinates (xreal, yreal, zreal) of the tracked object are calculated by
wherein S is a coefficient matrix of the delay compensation; {circumflex over (X)} is a posteriori estimation; (x, y, z) are position coordinates in the posteriori estimation {circumflex over (X)} of the Kalman filter; and ∥(vx, vy, vz)∥ is 2-norm of speed values (vx, vy, vz), that is, the moving speed of the object; r is a compensation determination threshold, and τ>0.
When the moving speed is greater than and equal to a preset compensation determination threshold τ, the tracking result is compensated; otherwise, the position value (x, y, z) in the posteriori estimation {circumflex over (X)} of the Kalman filter is obtained. Alternatively, based on the position, speed and acceleration information in {circumflex over (X)}, in combination with a time delay Δt, the actual position of the object at t0+Δt can be calculated by
Step S900-14: the value of V— is updated by V_=V. V_ is a V value of the previous strong filtering-Kalman filtering cycle.
Step S900-15: k=k+1. That is, k is increased by 1. Afterwards, the process returns to Step S900-1.
The representations of all the variables are simplified above, so that those skilled in the art can have a clear understanding about the disclosure. It should be noted that, in practical algorithms, k value needs to be set according to the cycle.
The above algorithm may be applied to a 3D tracking compensation process of the tracked object. If only the 2D position of the tracked object needs to calculated, the parameters are shown in the following.
A coefficient matrix of delay compensation is represented by:
When k=0, a posteriori estimation {circumflex over (X)} of the system state (x, vx, ax, y, vy, ay) is initialized as an initial state and represented by:
{circumflex over (X)}=(x0,0,0,y0,0,0)T,
wherein (x0, y0) is the position coordinates of the tracked object outputted by the tracking algorithm for the first time; vx, and vy are speeds on directions x, and y, respectively; ax, and ay are accelerations on the directions x, and y, respectively; and x, vx, ax, y, vy, and ay are initialized to 0.
A coefficient matrix of the system state transition is represented by:
A noise gain matrix of the system state is represented by:
A noise covariance matrix of the system state is a covariance matrix of acceleration noise (i.e., a diagonal matrix). The noise covariance matrix of the system state is represented by:
wherein q11 and q22>0; and q11 and q22 correspond to noise variance of the acceleration ax and ay, respectively. It should be noted that q11 and q22 may be selected correspondingly based on the intensity of changes in the accelerations.
A measurement coefficient matrix is represented by:
R is a measurement noise covariance matrix, that is, an error covariance matrix (a diagonal matrix) of the position of the tracked object outputted by the tracking algorithm. The measurement noise covariance matrix is represented by:
wherein r11 and r22>0; and r11 and r22 correspond respectively to the error covariance of the object position x, y calculated by the tracking algorithm. It should be noted that r11, and r22 may be selected correspondingly based on actual error of the tracking algorithm.
P is an error covariance matrix of the posteriori estimation of the system state of the Kalman filter. The error covariance matrix of the posteriori estimation of the system state of the Kalman filter is represented by:
P=diag(p11,p22, . . . ,p66),
wherein p11, p12, p66>0 and correspond respectively to the error covariance of a priori estimation of the system state variables (x, vx, ax, y, vy, ay); and when P is initialized, the values of p11 and p44 can be selected as smaller values (corresponding respectively to x, y), whereas other values can be selected as bigger values.
α=(α1, α2, . . . , α9) is a proportional coefficient of the multiple suboptimal fading factors, wherein αi≧1 and correspond respectively to the rate of change of the system state variables (x, vx, ax, y, vy, ay).
During object tracking described in various embodiments, the tracked object may be a head, a face or other parts of human body.
As shown in
The display apparatus may include a display module and a light-splitting device. The light-splitting device sends the image displayed by the display module to the left eye and the right eye of a user, such that the 3D image is displayed to the user.
On the basis of the tracking result obtained by using the current tracking method, the spatial delay during Δt is compensated. Therefore, the data accuracy of the object tracking is improved, and the quality of glasses-free 3D display is ultimately improved.
Further, although the methods and apparatuses are disclosed for illustrative purposes, similar concept and approach can be applied to other display apparatus. Other applications, advantages, alternations, modifications, or equivalents to the disclosed embodiments are obvious to those skilled in the art.
Without limiting the scope of any claim and/or the specification, examples of industrial applicability and certain advantageous effects of the disclosed embodiments are listed for illustrative purposes. Various alternations, modifications, or equivalents to the technical solutions of the disclosed embodiments can be obvious to those skilled in the art and can be included in this disclosure.
In certain embodiments, current position coordinates of a moving object with a spatial delay are compensated through a filter acting on a time-varying system. The filter acting on the time-varying system may be used to filter noise for the current position coordinates, greatly reducing calculation error and system noise of the tracking algorithm, and removing data jilter in the current position coordinates of the tracked object. Therefore, the data accuracy of the object tracking is improved.
Number | Date | Country | Kind |
---|---|---|---|
2014-10535884.0 | Oct 2014 | CN | national |