1. Field of the Invention
The present invention generally relates to the field of control systems of mirrors of a car, and more specifically, to automatic stabilization of mirrors with respect to head position.
2. Description of the Related Art
Conventional mirror positioning systems allow car mirrors to be moved manually or by using electronic controls located on the dashboard or elsewhere in the interior of the car within easy reach of the user. Some conventional mirror positioning systems also offer the feature of saving one or more settings that allow customization to the driver. For example, when one driver positions the mirrors at a comfortable viewing angle, those settings can be saved by the system. Then, if that driver or another driver alters the positions of the mirrors, the mirrors can be returned to the positions corresponding to the saved settings at the touch of a button.
Despite these features, conventional mirror positioning systems remain limited in several ways. For example, the settings that can be saved in conventional mirror positioning systems are static. If the driver changes position in the seat, for example by slouching or shifting to one side or the other, the mirrors may no longer be at a desired angle to view the area behind the vehicle. In other words, as the driver shifts viewing position, what is seen in the reflection shifts as well. Accordingly, the driver's ability to perceive the space behind the vehicle that he set up the mirrors to view is impaired. To maintain the optimal view of the scene reflected in the mirror using conventional systems, the user must either retain precisely the same head position throughout an entire drive or repeatedly readjust mirrors. Maintaining the same head position throughout an entire drive, particularly a lengthy one, is uncomfortable and, in practice, not possible. It unduly restricts a driver's natural inclination to change posture periodically. On the other hand, repeatedly readjusting mirrors manually or by manipulating electronic controls while driving is dangerous because it takes the driver's attention away from the road.
Accordingly, there is a need for a system and process of positioning mirrors that is capable of automatically responding to changes in a driver's viewing position so that the view reflected in the mirror is stabilized over time.
The present invention includes a system and a method for automatically controlling the position of mirrors to stabilize the view in spite of changes in viewing position. Initially, a mirror position is set by a user so that the user can comfortably view a desired area, for example a portion of the area outside of a vehicle. A tracking system estimates the user's viewing position. As a user's viewing position changes, the system reorients the mirrors such that the apparent reflection in the mirror is stabilized.
According to one embodiment of the present invention, a method is used to automatically stabilize the view in a mirror as a user's viewing position changes. The user sets the mirror to a desired orientation to see a desired reflected area. The mirror stabilization is engaged. By tracking the user's head position, the system registers a change in the user's viewing angle. The system adjusts the position of the mirror so that the view of the desired reflected area is maintained. While engaged, the system continues to compensate for changes in the user's head position.
In order to operate effectively, the method above relies on the system being accurately calibrated such that any given change in view position will result in the appropriate corresponding change in the mirror position to keep the user's view in the mirror stabilized. According to one embodiment of the present invention, the tracking system provides three-dimensional coordinates of the user's head, for example by means of a camera. A calibration is performed so that the coordinate transformation between the camera and the mirror is known. An auxiliary mirror, rigidly attached to the camera, is calibrated. Then the camera-mirror system can be calibrated through the calibrated auxiliary mirror. Then the resulting transformation is augmented by reflection of the coordinate system of the mirror through the auxiliary plane. The control surface for the movement of the mirror is found. The solution to the control surface determines how the mirror should be adjusted to maintain a constant reflection in the mirror as the user's viewing position changes.
The features and advantages described in the specification are not all inclusive and, in particular, many additional features and advantages will be apparent to one of ordinary skill in the art in view of the drawings, specification, and claims. Moreover, it should be noted that the language used in the specification has been principally selected for readability and instructional purposes, and may not have been selected to delineate or circumscribe the inventive subject matter.
The invention has other advantages and features which will be more readily apparent from the following detailed description of the invention and the appended claims, when taken in conjunction with the accompanying drawings, in which:
Figure (“FIG.”) 1 illustrates a system used to automatically stabilize the view in a mirror in accordance with one embodiment of the present invention.
The Figures and the following description relate to preferred embodiments of the present invention by way of illustration only. It should be noted that from the following discussion, alternative embodiments of the structures and methods disclosed herein will be readily recognized as viable alternatives that may be employed without departing from the principles of the claimed invention.
Reference will now be made in detail to several embodiments of the present invention(s), examples of which are illustrated in the accompanying figures. It is noted that wherever practicable similar or like reference numbers may be used in the figures and may indicate similar or like functionality. The figures depict embodiments of the present invention for purposes of illustration only. One skilled in the art will readily recognize from the following description that alternative embodiments of the structures and methods illustrated herein may be employed without departing from the principles of the invention described herein.
Calibration
Referring now to
The task of the calibration of the camera-mirror setup can be formulated as follows: Given Tac and TIc, find Tmc, where indices c, a, I, and m stand for the camera coordinate system (c), the auxiliary mirror coordinate system (a), the coordinate system of the Image of the mirror in the auxiliary mirror (I), and the mirror coordinate systems (m), respectively. Notationally, the transformation from coordinate system a to coordinates system b is designated herein by Tab.
At the outset, Tac is unknown. Thus, the first step in calibration is to determine 402 the transformation from auxiliary mirror coordinates 504 to camera frame coordinates 502. For this purpose, in one embodiment, a calibration pattern is placed directly on the auxiliary mirror surface. Using any traditional camera calibration technique, the coordinate transformation matrix, which represents the coordinate transformation from the auxiliary mirror coordinate system 504 to the camera frame coordinates system 502 is found:
Tac=└Rac|tac┘ (1)
Rac is the matrix of rotation and tac is the translation between origins of the coordinate systems. For mathematical clarity, we will proceed in homogeneous 3D coordinates, where the transformation matrix is a 4 by 4 matrix formed as follows:
At the outset, TIc is also unknown. Thus, the next step in the method 400 is to determine 404 the transformation from the coordinates of the image of the mirror in the auxiliary mirror to the camera frame coordinates. Similarly to the calibration of the auxiliary mirror, using the image of the mirror 102 through the auxiliary mirror 302 results in finding the parameters of the transformation from the coordinates of the image of the mirror in the auxiliary mirror to the camera coordinates, TIc.
The next step in method 400 is to determine 406 the transformation from the coordinates of the image of the mirror in the auxiliary mirror 506 to auxiliary mirror coordinates 504. TIa can be determined from TIc and Tac:
TIa=TcaTIc=(Tac)−1TIc (3)
Then, the transformation from the mirror coordinates 508 to the auxiliary mirror coordinates 504 is determined 408. A reflection matrix, Rz 510, is applied to TIa to move from the apparent mirror position coordinates 506 to the true mirror position coordinates 508. The reflection of TIa through the XY plane of the auxiliary frame is found by reversing the Z direction with the reflection matrix Rz 510:
Thus, the transformation from the mirror coordinates 508 to the auxiliary mirror coordinates 504 is found using the following equation:
Lastly, the transformation from the mirror coordinates to the camera coordinates is determined 410. Tmc is found using the following equation.
Tma=RzTIa (5)
Thus, the calibration of the camera-mirror setup is complete. As described in the task formulation, given Tac and TIc, Tmc has been found, using equation 6.
Estimation of Control Surface Parameters
Mirrors 102 are mounted on positioning units (not shown). For example, the positioning unit may be a pan-and-tilt unit. Such a unit is capable of sweeping some control surface that can range in shape from spherical to a more complicated curved surface due in part to misalignment of the axis and lateral displacement of the servo motors.
The control surface 601 can be approximated with a general quadratic surface that is described by a polynomial of a second degree:
z=a1x2+a2y2+a3xy+a4x+a5y+a6 (7)
A least squares approximation to this surface is found by fixing a point on the mirror during the calibration process and measuring its position while changing the mirror orientation. The corresponding coordinate transformation allows the computation of the position of this point in the camera coordinate system.
Let pm denote a position of such point in the mirror coordinate frame and {tilde over (p)}m denote its homogeneous coordinates. Then the point {tilde over (p)}c,i in the camera coordinates is computed with the corresponding transformation:
{tilde over (p)}c,i=Tm,ic{tilde over (p)}m (8)
Denoting the x, y and z components of the i-th point by xi, yi, zi respectively, the parameters of the surface given by equation 7 can be found as a quadratic regression:
Z=aTD (9)
where a is a 6-vector of coefficients and Z and D are formed as follows:
The solution for the coefficients, a, is found in the least squares sense:
aT=ZDT(DDT)−1 (12)
Alternatively, the surface can also be computed in the mirror coordinates by first selecting one of the mirror frames as a basis, Tm*c, and then transforming all collected points to that basis:
This approach may provide a better approximation in some geometrically degenerate cases, such as the case where the real surface is not a valid function of the coordinates.
Additionally, estimations can be made of the set of functions that allow the actual control signals for pan and tilt of the mirror drive mechanism to be derived:
The inverses of these functions are used to find the initial conditions:
In experiments conducted by the inventors, the last three functions have been found to be well approximated by the quadratic expansion similar to that of equation 11. However, the pan signal is sometimes more problematic. Thus, a 3rd degree full polynomial expansion can be used:
This equation represents a general polynomial where ap,q,r are the unknown coefficients of the terms xpyqzr. These terms can be determined by taking a pseudo-inverse, similar to the solution of equation 12 above.
Iterative Solution for Mirror Position
Referring now to
Given the normal, {right arrow over (n)}, and the position of the mirror center, {right arrow over (P)}, the reference vector can be determined as follows:
{right arrow over (r)}=2({right arrow over (V)}·{right arrow over (n)}){right arrow over (n)}−{right arrow over (V)} (17)
The mirror position necessary to maintain the pre-set reflection direction, {right arrow over (r)}, can be found by specifying the head position {right arrow over (F)}, and solving the system of equations for the intersection of a ray through the point {right arrow over (F)} with the control surface such that the reflected ray is parallel with {right arrow over (r)}.
The normal to the surface z=f(x,y) is given by:
The point of intersection {right arrow over (P)} of the viewing ray with the control surface can be found from a joint solution to the parametric line equation, {right arrow over (P)}={right arrow over (F)}+{right arrow over (V)}t, where {right arrow over (V)} is a vector in the direction from {right arrow over (F)} to {right arrow over (P)} and the surface equation is given by equation 7. This is a system of 7 equations with 10 unknowns ({right arrow over (P)}, {right arrow over (V)}, t, and {right arrow over (n)}). Additionally, vector {right arrow over (V)} is constrained to be of unit length and {right arrow over (r)} is constrained to be a reflection of {right arrow over (V)} through the surface normal {right arrow over (n)}. The resulting system of equations is:
This is a system of 10 equations (lines 2 and 3 provide three constraints each) with 10 unknowns. The direct solution is difficult due to the presence of the quadratic terms in lines 1, 3, and 4. However, this system can be iteratively solved using the Newton-Raphson method, for example.
The Newton-Raphson solution to the system of equations given in 19 involves first transforming the system of equations to the homogeneous form,
f(x)=0 (20)
Then starting with the initial guess, x0, the solution is iteratively obtained as:
xn+1=xn−J−1f(xn+1) (21)
Where the matrix J is the Jacobian of equation 20.
Equation 19 can be solved iteratively by means of recurrence of equation 21 setting x0 to the known values initially set by the user:
A set of solutions resulting from the initial set up and then changing the head position is shown in
Having found the required position {right arrow over (P)} of the mirror center on the control surface, the values for pan and tilt controls of the mirror drive are determined via the approximation of equation 14. Thus, the mirror can be positioned appropriately to maintain the constant reflection direction.
Referring now to
The method 1000 describes the steps of the system after the user has adjusted the mirror to a comfortable viewing angle. The method 1000 begins with initialization 1002 of the system. The starting viewing position is determined 1004. This point corresponds to where the user's viewpoint is, and is referred to in earlier figures as {right arrow over (F)}. Preferably, this reference point is obtained from a properly calibrated camera positioned to view the user's face. Then the initial pan and tilt values from the mirror drive are determined 1006. These values identify the starting position of the mirror after it has been comfortably adjusted for the user. In the next step, the values of x and y correspond to the starting position of the mirror on the control surface, are determined 1008, preferably by plugging the pan and tilt values taken from the mirror drive into the system of equations given in 15. Then z, the last coordinate corresponding to the starting position of the mirror on the control surface is determined 1010, preferably by plugging in the determined values of x and y into equation 7 which approximates the control surface. After the initial position of the mirror (x, y, and z) is determined, the viewing vector {right arrow over (V)}, the normal to the control surface {right arrow over (n)}, and t are determined 1012, preferably using lines 2 and 3 of the system of equations given in 19. In the next step, the reflection vector {right arrow over (r)} is determined 1014, preferably using equation 17. Note that in equation 17, all the unknowns ({right arrow over (V)} and {right arrow over (n)}) have already been determined. At this point, all of the components of the initial conditions x0 from equation 23 have been determined and thus x0 can be determined 1016. Thus concludes the initialization 1002 of the system.
Upon the completion of the initialization 1002, each of the steps of the method 1000 shown inside of box 1018 are completed for each new video frame. The new viewing position is determined 1020. Preferably, the new viewing position is determined in a similar manner as was used to determine the reference viewing position described above with reference to step 1004. If the new viewing position is the same as the previous viewing position, then no alterations are necessary to the mirror position and the method is complete for that video frame. However, if the new viewing position for a video frame is a change in position from the previous viewing position, then the method proceeds with the next steps in box 1018. The iterative solution to the system of equations 19 is obtained 1022, preferably by iterating equation 21, beginning with x0, until convergence is achieved. Then, the pan and tilt values for the mirror drive to reposition the mirror is determined 1024. These pan and tilt values are preferably determined using the system of equations given in equation 14. These pan and tilt values position the mirror according to the iterative solution obtained. This compensates for the change to the new viewing position determined in step 1020 such that the reflected view is stabilized.
Upon reading this disclosure, those of skill in the art will appreciate still additional alternative structural and functional designs for a system and a process for automatically controlling the position of mirrors to stabilize the view in spite of changes in viewing position through the disclosed principles of the present invention. Thus, while particular embodiments and applications of the present invention have been illustrated and described, it is to be understood that the invention is not limited to the precise construction and components disclosed herein and that various modifications, changes and variations which will be apparent to those skilled in the art may be made in the arrangement, operation and details of the method and apparatus of the present invention disclosed herein without departing from the spirit and scope of the invention as defined in the appended claims.
This application claims priority under 35 USC § 119(e) to U.S. Provisional Patent Application No. 60/624,768 titled “Automatic Rear-View Mirror Stabilization” filed on Nov. 2, 2004, which is incorporated by reference herein in its entirety.
Number | Date | Country | |
---|---|---|---|
60624768 | Nov 2004 | US |