An image system which captures, along with the images, information defining both the position and the orientation of the camera along with the distance to the subject. A video camera is attached to three accelerometers, two gyroscopes, and a rangefinder. data gathered from these devices and defining the pitch, yaw, and roll of the camera, the camera's acceleration, and the distance to the subject is captured and recorded along with video images. The video images are later stored within a computer's data base along with data defining the position and orientation of the camera and the distance to the subject for each image, this latter data being computed from the captured data. The images may then be presented to the user in a three-dimensional display in which the user can navigate through the images using a joystick device, with the images located in positions corresponding to the positions in space of the objects that were imaged.
| 
 | 0. 15. A spatially referenced photographic apparatus comprising:
 a data base containing images of objects and information corresponding to the images, the information defining a position at which a respective image was captured and at least a yaw orientation of the respective image with respect to the position, wherein the information is derived from a camera position and orientation information automatically recorded substantially simultaneously with recording of the respective image; a computing device in communication with the data base, the computing device configured to receive spatial movement commands and provide images for display in response to receiving the spatial movement commands via an interface; wherein the computing device is configured to provide an overlay item projected onto a displayed image based on at least one of the respective images from the data base, the overlay item comprising an indication of a point or area of interest for the displayed image with respect to which one or more associated images are available in response to receiving signals indicating selection of the overlay item; and wherein the displayed image with the overlay item projected onto the displayed image includes designations indicating left and right possible rotations corresponding to a general location of a viewpoint of an image captured at generally left-rotated or right-rotated camera positions. 0. 21. A spatially referenced photographic apparatus comprising:
 a data base containing plural images of objects and also containing information corresponding to said images defining the position at which each image was originally captured and at least the yaw orientation of the image with respect to that position, wherein recorded information from which said position and yaw orientation information may be determined was automatically recorded substantially simultaneously with the recording of the image; image presentation and navigation means for displaying the images to a user and for facilitating the user in navigating among said images by receiving spatial movement commands from the user, as indicated by said spatial movement commands; said image presentation and navigation means providing to the user, for display in combination with the images and an overlay item, navigation controls, in response to the actuation of which controls said presentation and navigation means selects an image captured at a position generally shifted from that of an image the user is currently viewing, as indicated by the user actuation of said controls; and said image presentation and navigation means providing the user an overlay item projected onto the image the user is currently viewing, the overlay item comprising an indication of a point or area of interest for the image with respect to which one or more associated images are available in response to receiving signals indicating selection of the overlay item. 0. 13. A spatially referenced photographic apparatus comprising:
 a data base containing images of objects and information corresponding to the images, the information defining a position at which a respective image was captured and at least a yaw orientation of the respective image with respect to the position, wherein the information is derived from a camera position and orientation information automatically recorded substantially simultaneously with recording of the respective image; a computing device in communication with the data base, the computing device configured to receive spatial movement commands and provide images for display in response to receiving the spatial movement commands via an interface; wherein the computing device is configured to provide an overlay item projected onto a displayed image based on at least one of the respective images from the data base, the overlay item comprising an indication of a point or area of interest for the displayed image with respect to which one or more associated images are available in response to receiving signals indicating selection of the overlay item; and wherein the computing device is configured to provide, along with the displayed image and the overlay item projected onto the displayed image, navigation controls for moving backward, the computing device configured to provide in response to actuation of the navigation controls a selected image captured at a generally backward camera position having an orientation similar to that of the displayed image. 0. 17. A spatially referenced photographic apparatus comprising:
 a data base containing images of objects and information corresponding to the images, the information defining a position at which a respective image was captured and at least a yaw orientation of the respective image with respect to the position, wherein the information is derived from a camera position and orientation information automatically recorded substantially simultaneously with recording of the respective image; a computing device in communication with the data base, the computing device configured to receive spatial movement commands and provide images for display in response to receiving the spatial movement commands via an interface; wherein the computing device is configured to provide an overlay item projected onto a displayed image based on at least one of the respective images from the data base, the overlay item comprising an indication of a point or area of interest for the displayed image with respect to which one or more associated images are available in response to receiving signals indicating selection of the overlay item; and wherein the computing device is configured to provide, along with the displayed image and the overlay item projected onto the displayed image, navigation controls for moving forward and simultaneously rotating to the left or to the right, the computing device configured to provide in response to the actuation of the navigation controls an image captured at a generally forward camera position having an angular orientation rotated to the left or to the right of the displayed image. 0. 14. A spatially referenced photographic apparatus comprising:
 a data base containing images of objects and information corresponding to the images, the information defining a position at which a respective image was captured and at least a yaw orientation of the respective image with respect to the position, wherein the information is derived from a camera position and orientation information automatically recorded substantially simultaneously with recording of the respective image; a computing device in communication with the data base, the computing device configured to receive spatial movement commands and provide images for display in response to receiving the spatial movement commands via an interface; wherein the computing device is configured to provide an overlay item projected onto a displayed image based on at least one of the respective images from the data base, the overlay item comprising an indication of a point or area of interest for the displayed image with respect to which one or more associated images are available in response to receiving signals indicating selection of the overlay item; and wherein the computing device is configured to provide, along with the displayed image and the overlay item projected onto the displayed image, navigation controls for rotating left or right, the computing device configured to provide in response to actuation of the navigation controls for rotating left or right an image captured at a generally left-rotated or right-rotated camera position having a position forward, backward, and side-to-side similar to that of the displayed image. 0. 12. A spatially referenced photographic apparatus comprising:
 a data base containing images of objects and information corresponding to the images, the information defining a position at which a respective image was captured and at least a yaw orientation of the respective image with respect to the position, wherein the information is derived from a camera position and orientation information automatically recorded substantially simultaneously with recording of the respective image; a computing device in communication with the data base, the computing device configured to receive spatial movement commands and provide images for display in response to receiving the spatial movement commands via an interface; wherein the computing device is configured to provide an overlay item projected onto a displayed image based on at least one of the respective images from the data base, the overlay item comprising an indication of a point or area of interest for the displayed image with respect to which one or more associated images are available in response to receiving signals indicating selection of the overlay item; and wherein the computing device is configured to provide, along with the displayed image and the overlay item projected onto the displayed image, navigation controls for moving forward and simultaneously rotating to the left or to the right, the computing device configured to provide in response to actuation of the navigation controls a selected image captured at a generally forward camera position having an angular orientation rotated to the left or to the right of that of the displayed image. 0. 1. A spatially referenced photographic system comprising:
 a data base containing plural images of objects and also containing information corresponding to said images defining the position at which each image was originally viewed and the orientation of the image with respect to that position; image presentation and navigation means for displaying the images to a user and for facilitating the user in navigating among said images by receiving spatial movement commands from the user, as indicated by said spatial movement commands; wherein said image presentation and navigation means includes means for displaying, along with an image, a view of the camera path and an indication of the camera position and orientation when the image was recorded; wherein camera position and orientation is indicated by a mark on the path oriented as the camera is oriented to point where the camera was pointing; and wherein the view is a plan view and wherein the mark bears an indication thereon of the yaw angle of the camera. 0. 2. A spatially referenced photographic system comprising:
 a data base containing plural images of objects and also containing information corresponding to said images defining the position at which each image was originally viewed and the orientation of the image with respect to that position; image presentation and navigation means for displaying the images to a user and for facilitating the user in navigating among said images by receiving spatial movement commands from the user, as indicated by said spatial movement commands; wherein said image presentation and navigation means includes means for displaying, along with an image, a view of the camera path and an indication of the camera position and orientation when the image was recorded; and wherein a mark appears in said image of a location associated with another image such that the user may signal a desire to navigate forward to view said another image in a simple manner. 0. 3. A spatially referenced photographic system in accordance with  0. 4. A spatially referenced photographic system comprising:
 a data base containing plural images of objects and also containing information corresponding to said images defining the position at which each image was originally viewed and the orientation of the image with respect to that position; image presentation and navigation means for displaying the images to a user and for facilitating the user in navigating among said images by receiving spatial movement commands from the user, as indicated by said spatial movement commands; and wherein said image presentation and navigation means provides the user with navigation controls for moving backward, in response to the actuation of which controls said means selects an image captured at a generally backward camera position having an orientation similar to that of an image the user is currently viewing. 0. 5. A spatially referenced photographic system comprising:
 a data base containing plural images of objects and also containing information corresponding to said images defining the position at which each image was originally viewed and the orientation of the image with respect to that positions; image presentation and navigation means for displaying the images to a user and for facilitating the user in navigating among said images by receiving spatial movement commands from the user, as indicated by said spatial movement commands; and wherein said image presentation and navigation means provides the user with navigation controls for rotating left or right, in response to the actuation of which controls said means selects an image captured at a generally left-rotated or right-rotated camera position having a position fore-, aft-, and side-to-side similar to that of an image the user is currently viewing. 0. 6. A spatially referenced photographic system in accordance with  0. 7. A spatially referenced photographic system in accordance with  0. 8. A spatially referenced photographic system comprising:
 a data base containing plural images of objects and also containing information corresponding to said images defining the position at which each image was originally viewed and the orientation of the image with respect to that position; image presentation and navigation means for displaying the images to a user and for facilitating the user in navigating among said images by receiving spatial movement commands from the user, as indicated by said spatial movement commands; and wherein said image presentation and navigation means provides the user with navigation controls for moving forward and simultaneously rotating to the left or to the right, in response to the actuation of which controls said means selects an image captured at a generally forward camera position having an angular orientation rotated to the left or to the right of that of an image the user is currently viewing. 0. 9. A spatially referenced photographic system comprising:
 a data base containing plural images of objects and also containing information corresponding to said images defining the position at which each image was originally viewed and the orientation of the image with respect to that position; image presentation and navigation means for displaying the images to a user and for facilitating the user in navigating among said images by receiving spatial movement commands from the user, as indicated by said spatial movement commands; said image presentation and navigation means providing the user with navigation controls, in response to the actuation of which controls said presentation and navigation means selects an image captured at a position generally shifted from that of an image the user is currently viewing, as indicated by the user actuation of said controls. 0. 10. The spatially referenced photographic apparatus of claim 17 wherein the overlay item comprises a frame, wherein the computing device is configured to provide a new image corresponding to the overlay item in response to receiving signals indicating selection of the frame. 0. 11. The spatially referenced photographic apparatus of claim 17 wherein the computing device is configured to provide a designation on at least one of the displayed image and a plan view of a position at which the displayed image was captured and a yaw orientation of the displayed image with respect to that position. 0. 16. The spatially referenced photographic apparatus of claim 15 wherein the computing device is configured to provide the image captured at generally left-rotated or right-rotated camera positions in response to receiving signals indicating selection of one of the designations. 0. 18. The spatially referenced photographic apparatus of claim 17 wherein the computing device is configured to provide multiple images aligned in a panorama to provide a wider field of view. 0. 19. The spatially referenced photographic apparatus of claim 17 wherein the computing device is configured to provide a plan view overlay item projected as a region onto the displayed image, the plan view overlay item comprising an indication of a point or area of interest on the plan view with respect to which one or more associated images are available, wherein the computing device is configured to provide a new image corresponding to the plan view overlay item in response to receiving signals indicating selection of the region. 0. 20. The spatially referenced photographic apparatus of claim 17 wherein the computing device is configured to provide a new image corresponding to the overlay item in response to receiving signals indicating selection of the overlay item. | |||||||||||||||||||||||||||
This application is a continuation reissue application of reissue application Ser. No. 12/126,664, filed May 23, 2008, to be issued as U.S. Pat. No. Re. 42,289, which is a reissue application of application Ser. No. 09/723,767, filed Nov. 28, 2000, issued on May 23, 2006 as U.S. Pat. No. 7,050,102, which is a continuation application of application Ser. No. 08/894,206, filed Jul. 30, 1997, now U.S. Pat. No. 6,195,122, which is a 35 U.S.C. § 371 national stage U.S. application corresponding to Patent Cooperation Treaty application PCT/US96/01434, filed on Jan. 31, 1996, which is a continuation-in-part of U.S. patent application Ser. No. 08/383,471, filed on Jan. 31, 1995, which is hereby incorporated by reference. In particular, the '471 application contains a more detailed description of the tracking data acquisition unit control circuit 470 (in '471 application FIGS. 16 to 23 and the accompanying text) and exemplary program listings (presented in the Appendices of the '471 application) which may be of interest to those seeking a more detailed understanding of the present invention.
This invention relates to referencing, sorting, and displaying images in a three-dimensional system. More particularly, it relates to a system having an image capturing device that captures images of objects together with spatial reference information defining the absolute position of the image capturing device and the relative position of the object relative to that device. It also relates to image retrieval and display, where the spatial reference information associated with each image facilitates browsing through the images in an organized manner.
The editing of films and video images, i.e., to rearrange action sequences, is well known. However, the movie and video cameras used to capture the images that are later edited do not store with those images any machine-understandable record of image and camera position. Accordingly, the edited films and videos permit one to view the images in only one predetermined order, determined by the editor. If some other ordering of the image presentation is desired, it must be achieved through a difficult manual editing process.
A computerized, interactive editing process is described in a doctoral thesis “Cognitive Space in the Interactive Movie Map: An Investigation of Spatial Learning in Virtual Environments”, by Robert Mohl, 1981, submitted at MIT. In a demonstration carried out using images recorded at Aspen, Colo., the viewer is permitted to select film clips taken by a camera that is arranged to simulate driving down a street. At each intersection, the viewer chooses to turn left, turn right, or to proceed straight ahead. The viewer thereby simulates driving around streets in Aspen, Colo.
In other fields, it is known to gather, along with images, information concerning the position of the camera. Governmental and private agencies use satellites and airplanes to record images of positionally referenced data, such as land features or clouds. Each image frame contains positional references to the image tilt or plane of the camera. Present methods commonly either constrain the orientation of the camera to a fixed position, i.e. up and down, or use features captured in the image frames to derive relative positions and orientations of successive images when combining the image frames to form a map or the like.
Devices are known which combine images by matching features common to each of two or more images, i.e. superimposing.
One aspect of the present invention is recording positional data along with images. A number of methods are known whereby one may locate an object and describe the position of an object relative to a positional reference. For example, a magnetic device is known which can determine its position and orientation within a known magnetic field. Satellite systems and radio signal triangulation can also be used to determine position precisely. Inertial position determination systems are also known and are widely used in inertial navigational systems.
An object of this invention is providing an image data gathering device which encodes positional and/or spatial information by capturing both camera position and camera orientation information along with image data. This information permits images to be joined or sequenced for viewing without the distortions that can result from attempting to match the edges of adjoining images together.
A further object of this invention is providing three-dimensional image reconstruction of objects using frames shot from different viewpoints and perspectives through the provision of a triangulation reference.
Still another object of this invention is providing a camera path map which allows images to be selected based upon the position and orientation of the camera from the map. For example, an operator cam learn the location of an object in a film clip, such as an escalator. Images of the escalator may then be quickly and automatically located by selecting other frames which point to that same escalator from different camera positions.
Another object of the invention is providing a compact and practical image and positional data recording system which uses commonly available equipment. A system having accelerometers mounted directly upon the recorder, eliminating the need for a restrained or gimballed platform, permits greater freedom of motion for the recording device as well as reduced cost and complexity.
Briefly described, the invention resides in a video camera that is integrated with a tracking data acquisition unit containing accelerometers and gimbal-mounted gyroscopes, and optionally a rangefinder. As the operator of the video camera moves about taking a motion picture of the environment, a microprocessor and logic associated with the accelerometers and gyroscopes senses all rotational motions of the camera by means of sensors associated with the gimbals and senses all translational motions of the camera by means of sensors associated with the accelerometers. And the rangefinder provides information to the microprocessor and logic concerning the distance from the camera to the subject being photographed.
From data presented by these sensors, the microprocessor and logic compute and generate a modulated audio signal that is encoded with a continuous record of acceleration in the X, Y and Z directions as well as with a continuous record of the pitch, roll, and yaw of the camera and of the distance to the subject. This audio tracking information data signal is recorded on the audio track of the same video tape upon which the video images are being recorded by the camera. In this manner, the video tape recording captures, along with the sequence of images, the tracking data from which the precise position of the camera, its precise orientation, and the position of the subject may later be computed.
Later on, the recorded audio tracking information data and video data is played back into a computer. Images are selected from the sequence of images and are retained, in compressed form, in a database. Each image is then linked to computed positional information that defines, for each image, the location and orientation of the camera and, optionally, the distance to the subject and the subject location. This positional information is derived through computation from the tracking information retrieved from the video tape audio track, as will be explained below.
Next, special computer programs can aid an individual using the computer in navigating through the images, using the positional information to organize the images in ways that make it easy for the user to browse through the images presented on the graphics screen. Several such programs are described below, and a complete description is presented of a movie mapper program which presents the user with a plan view and elevational views of the camera path plotted as a graph alongside views of selected images, with the path marked to show the position and orientation of the camera. The user, by clicking at any point on this path with a computer mouse, may instantly retrieve and view an image captured at the chosen point. Additionally, by clicking upon diamonds and arrows and the like displayed as overlays superimposed upon an image, the user may command the program to search for and find the nearest image which gives a view rotated slightly to the left or right or which maintains the same view but advances forward in the direction of the view or backward. One may also jump forward and turn simultaneously. A wider field of view may be assembled by assembling automatically chosen images and aligning them into a panorama. The user is thus enabled to navigate through the images in the manner of navigating a boat to the extent permitted by the nature and variety of the images in the data base.
Further objects and advantages are apparent in the drawings and in the detailed description which follows.
Referring to the drawings and especially to 
With reference to 
Once safely stored within the personal computer 185, the tracking database 324 is reprocessed into a positional database 322 by a tracking database to positional database conversion program 310. Now the image retrieval programs 325, 330, and 335 may be called upon to search through the positional database 322, to retrieve images from the video database 323 based upon camera location, camera orientation, and even object location, and to display the images upon the face of the computer 185.
Tracing the data flow through the system components at a more detailed level will explain the functionality of the preferred embodiment of the spatially referenced camera.
First, the video camera 120 (
Second, the completed recording, stored on the video cassette, is played back to the personal computer 185 on any standard video cassette player or directly from the camera 120 (
Third, the set of three display programs 325, 330, and 335 allow a user to view and select video frames based on the relative position or absolute orientation of the camera.
Tracing the data flow through the individual parts of the spatially referenced video camera 100 at the most detailed level discloses how to build the preferred embodiment of the invention.
Referring to 
Two gyroscopes, such as GYRATION Model GE9100A, a vertical gyroscope 400 and a directional gyroscope 410 are also orthogonally mounted on the stable inertial platform 415 relative to each other. The vertical gyroscope 400, aligned along the X or Y axis, measures yaw (rotation about the Z axis), while the directional gyroscope 410, aligned along the Z axis, measures both roll (rotation about the Y axis) and pitch (rotation about the X axis). (The Y axis is assumed to point in the direction of the camera.) The gyroscopes are dual gimballed electronic components that generate a pair of square wave signals which are locked out of phase with respect to each other. The sequence of the rising and falling edges of the square waves relative to each other indicates the angular rotation about the gyroscope's measurement axis experienced by the spatially referenced camera 100. Quadrature decoders 450, 455, 460, such as HEWLETT PACKARD Model HCTL2020, receive the three paired square wave signal outputs of the gyroscopes 400, 410; and for each signal pair, they count the relative sequence of rising and falling edges between the two square wave signals to generate a 16-bit numerical representation of the rotation experienced about each axis. An interrupt is generated following any change in these signals. This interrupt causes a central processing unit 480 (
The inertial platform 415 (
In addition to the accelerometers and the gyroscopes there is a control circuit 470 (
The spatially referenced camera 100 can be configured and used with a laser rangefinder 485 (
The rangefinder 485 (
Referring to 
The format of a complete data frame 535 (without range information) is composed of a frame identification pattern 530, which is formed from three repetitions of the 16 bit value 017F hex (at 525). This is followed by data: a 24-bit acceleration value in the X direction 500A, a 16-bit pitch value 505A, a 24-bit acceleration value in the v direction 500B, a 16-bit roll value 505B, a 24-bit acceleration value in the Z direction 500C, and a 16-bit yaw value 505C. The tracking data frame format with range information included 540 starts with a frame identification pattern 550 composed of three repetitions of the value 037F hex (at 545), followed by a 24-bit acceleration value in the X direction 500A, an 8-bit delta (or incremental change) pitch value 505A, a 24-bit acceleration value in the Y direction 500B, an 8-bit delta roll value 505B, a 24-bit acceleration value in the Z direction 500C, an 8-bit delta yaw value 505C, and finally the range data 555 and a gray scale reflectivity value 560. The records 540 containing range information are generated whenever an interrupt from the decoders 450, 455, and 460 indicates that the camera orientation has changed.
Once the video tape is filled with modulated tracking and video data, it is played back. The video output is directly connected to a conventional video digitizer input 180, such as the INTEL SMART VIDEO RECORDER, that is inserted into the ISA, EISA, VESA, PCI, or other accessory port or slot of the personal computer 185. As the video cassette is played back on the video cassette player 130, the video digitizer input 180 captures the video frames of the recorded images and passes digitized video frame data on to the tracking and video data entry and storage program 305 shown in 
Simultaneously, the video signal 150 from the video output 140 of the video cassette recorder 130 is captured (step 680), and video frames are selected (step 685). Frame numbers are assigned to the selected video frames (step 690), and at step 665 these frame numbers are concatenated to the lines of tracking data to form tracking data lines. Finally, at step 675 a database of numbered tracking data lines is created and is stored on the disk in a database file called the tracking database 324.
At step 695, the video frame is fed into a video compression program, and the outputted compressed video frame is concatenated or otherwise linked to the same video frame number at 695. Finally, at step 700, a database of numbered and compressed video frames is created and is stored on the disk in a file that is called the video database 323.
The tracking and video data entry and storage program 305, residing on the personal computer 185, essentially builds two related databases. The first is a tracking database 324 composed of enumerated records containing the orientation, the translational acceleration, and optionally the range data originally generated by the tracking data acquisition unit 105. The second is a video database 323 composed of enumerated records containing digitized and compressed images of video frames captured from the video tape originally generated by the video camera 120.
Once all of the recorded tracking and video data are stored, the personal computer 185 converts the tracking database 324 into a positional database 322 via a software module called the tracking database to positional database conversion program 310 (
In the preferred embodiment, an existing image capture computer program is adapted for use to capture, compress, and store selected images in the video database 323, as indicated in steps 680, 685, 690, 695, and 700 of 
To implement the step 655, the computer 185 is equipped with a conventional, serial port interrupt driven program that is called upon automatically, whenever the serial input port 176 receives a serial byte of the tracking data signal 170, to retrieve the byte from the serial port UART and to store the byte in some form of circular buffer in RAM from which the bytes may be readily retrieved.
Each time the step 660 is performed (every 1/10th or 1/20th of a second or so), all the bytes currently in this circular buffer are retrieved, combined with historical data, and separated from any partial data frame that is retained as historical data. In this manner, several data frames in the format illustrated at 535 or 540 in 
The details of the tracking database to positional database conversion programs 310 are shown in 
The program 310 begins at 1002 by initializing the variables. Then at 1004, it opens the input tracking data file 324 (
The data processing steps 1006 are described in 
The program steps 1006 control the reading of the input file and enforce the formatting of the output file. In particular, these steps buffer the position records in such a manner that each record processed is complete even though the input records may have been broken up, as described above. In this manner, the program generates one and only one output position record for each frame.
The program begins at 1110 by reading in a data frame. At 1114, if there are no more frames, then at 1130 the files are closed and we are done. If a frame is found, a data record is retrieved from the frame at 1112. At 1118, if a record is found, it is processed at 1120 and written out to the positional database 322 at step 1122. Whether or not a record is found, program control continues at step 1124 where any unprocessed residual data is prepared (or added to) the next frame. Program control then returns to 1110 where the next frame is read.
The data record processing routine 1120 is described in 
Next, the acceleration values are converted into a floating point form at step 1212. Gain and offset errors can be corrected in this step. This routine also computes the magnitude of the acceleration as the square root of the sum of the squares of the three components.
Step 1214 calculates the current position from the acceleration data. With reference to 
In the following short program, the values of acceleration are “ac->p.f” for the y value of acceleration and “ac->p.l” for the X value of acceleration (the z value is not needed). This program computes PØ and RØ, and it acquires the initial yaw value as WØ.
 
 
 
// acquire reference for pitch and roll gyros. Used to 
 
// correct for G later 
 
void GetRollPitchZero (PositionAttitudeRecord * ac, 
 
 long double magnitude) 
 
{ 
 
 long double xmag, ymag, numAvg; 
 
 xmag=ac—>p.f/magnitude; 
 
 ymag=ac—>p.l/magnitude; 
 
 numAvg=GO; // for backward average of all samples 
 
 // numAvg=1; // for no averaging 
 
 rref = −asinl (ymag): 
 
 pref = asinl (xmag); 
 
 // average over all samples, equal weights for all 
 
 p0 = ((p0 * (numAvg−1)) + (deg(pref)+ac—>a.p))/numAvg; 
 
 r0 = ((r0 * (numAvg−1)) + (deg(rref)+ac—>a.r))/numAvg; 
 
 if (GO == 1) // this one is the first 
 
 { 
 
 w0 = ac—>a.w; // init to current yaw count 
 
 } 
 
} 
 
 
Acquisition of rØ and pØ values allows the definition of a reference frame for integration in which the transformed X and Y acceleration components have no contribution from the gravitational force. X and Y in the reference frame are perpendicular to the direction of the gravity vector, while Z in the reference frame is parallel to the gravity vector.
GetRollPitchZero also averages PØ and RØ readings on all subsequent calls after the first call to achieve better and better estimates for these values.
At step 1320, since the only acceleration is that of gravity, we assume that the camera is motionless, and we arbitrarily set the velocity values in all three directions to zero. This assumption holds because the camera is hand-held and is never stable when the human carrier is in motion. If the camera were mounted upon some conveyance that can move very smoothly at a uniform velocity, then this assumption would not hold, and some additional data indicating the velocity of the camera would have to be recorded. In an airplane or automobile, for example, the speedometer reading or ground speed reading could be recorded to assume that this algorithm functions properly.
Next, at step 1318, the current pitch, yaw, and roll are transformed into coordinates that indicate these parameters relative to the newly-defined reference frame. This step 1318 is always performed regardless of whether the magnitude of the acceleration matches that of gravity.
To facilitate, the following computations, the yaw, pitch, and roll values, which are presently referenced to a horizontal plane, must be converted into what is called the quaternion form. This is a four dimensional vector with three imaginary components and one real component. This is done to facilitate the transformation of the acceleration values, which are presently referenced to the tilted camera plane, into valves referenced to the horizontal reference plane (just defined, preparatory to integrating the acceleration values to produce velocity and displacement values.
This calculation is performed by the following program. In this program, the input variable is a record “AttitudeRecord” which contains yaw “w”, pitch “p”, and roll “r”. The returned quaternion values are “s”, “i”, “j”, and “k”, where “s” is the real value and the others are the imaginary values.
 
 
 
// convert yaw,pitch,roll to quaternion form 
 
void AttitudeQuaternion (AttitudeRecord * p, 
 
 QuaternionRecord * qcos) 
 
{ 
 
 long double cw,cp,cr,sw,sp,sr; /* sine and cosine */ 
 
 long double rp, rw, rr; 
 
 long double trace, c[3][3]; 
 
 rw=rad(p—>w): 
 
 rp=rad(p—>p); 
 
 rr=rad(p—>r): 
 
 cw=cosl (rw): 
 
 cp=cosl (rp); 
 
 cr=cosl (rr): 
 
 sw=sinl (rw); 
 
 sp=sinl (rp); 
 
 sr=sinl (rr); 
 
// use cosine matrix form for calculation 
 
 c[0][0]=cw*cp; c[0][1]=sw*cp; c[0][2]=−sp; 
 
 c[1][0]=(−cr*sw) + (sr*sp*cw); c[1][1]=(cr*cw)*(sr*sp*sw); 
 
 c[1][2]=sr*cp; 
 
 c[2][0]=(sr*sw) + (cr*sp*cw); c[2][1]=(−sr*cw)+(cr*sp*sw); 
 
 c[2][2]=cr*cp; 
 
 trace=c[0][0] + c[1][1] + c[2][2]; 
 
 qcos—>s=sqrt1(1+trace)/2.; 
 
 qcos—>i=(c[1][2] − c[2][1])/(4.* qcos—>s); 
 
 qcos—>j=(c[2][0] − c[0][2])/(4.* qcos—>s); 
 
 qcos—>k=(c[0][1] − c[1][0])/(4.* qcos—>s); 
 
 
At step 1324, the acceleration vector is transformed from the camera body coordinate frame into the stable reference frame.
At step 1326, the integration of the transformed acceleration values is carried out as follows:
The quaternion coordinate transformation process is carried out by using two cross multiplications, and is illustrated below:
 
 
 
 //returns rotated vector in rp 
 
 void QuaternionRotate (positionRecord *v, 
 
 
 QuaternionRecord *q. 
 
 
 PositionRecord *rp) 
 
 { 
 
 
 QuaternionRecord vq,qi.rq; 
 
 
 // quaternion multiplication qi v q 
 
 
 // from the book. 
 
 
 // qi is −i −j −k... 
 
 
 vq.s=0; vq.i=v—>f: vq.j=v—>l; vq.k=v—>u; 
 
 
 qi.s=q—>s; 
 
 
 qi.i=−q—>i; 
 
 
 qi.j=−q—>j; 
 
 
 qi.k=−q—>k; 
 
 
 QuaternionMultiply (&qi, &vq, &rq); 
 
 
 QuaternionMultiply (&rq, q, &vq); //reissue vq 
 
 
 rp—>f=vq.i; 
 
 
 rp—>l=vq.j; 
 
 
 rp—>u=vq.k. 
 
 
The incoming arguments to this function are a three-dimensional vector “v” that is to be rotated and a four-dimensional quaternion vector “q” that defines the rotation. The three-dimensional vector “v” is first transformed into a four-dimensional vector “vq” with the fourth component “vq.s” set to zero.
First, an inverse “qi” is formed of the quaternion “q”. Next, the incoming vector “vq” is quaternion multiplied by the inverse quaternion vector “qi;”. The result of this multiplication “rq” is then quaternion multiplied by the quaternion vector “qi” Three components of the resulting vector, which is returned as “vq”, are transferred back into the vector “rp” which is returned as the transformed result.
The quaternion multiplication is defined by the following program: void QuaternionMultiply (QuaternionRecord *q,
 
 
 
{ 
 
 r—>s=(q—>s*s—>s)−(q—>i*s—>i)−(q—>j*s—>j )−(q—>k*s—>k); 
 
 r—>i=(q—>s*s—>i)+(q—>i*s—>s)+(q—>j*s—>k)−(q—>k*s—>j ); 
 
 r—>j=(q—>s*s—>j)−(q—>i*s—>k)+(q—>j*s—>s)+(q—>k*s—>i); 
 
 r—>k=(q—>s*s—>k)+(q—>i*s—>j)−(q—>j*s—>i)+(q—>k*s—>s). 
 
} 
 
 
The details of the step 1122 in 
In addition to writing out the records 775 (
An alternative method of position estimation using the inertial platform is now described. The accelerometer inputs described above as the vector “pos” in the program “acc2pos.c” is replaced by a vector of constant velocity as shown in this program fragment:
 
 
 
 if (magnitude < G + DELTA_MAG//+DELTA 
 
   && magnitude > G − DELTA_MAG//−DELTA 
 
   ) 
 
 { 
 
 // for velocity estimation method 
 
 // dx = dy = dz = 0; 
 
 pos—>p.f=0; 
 
 } 
 
 else 
 
 { 
 
 pos—>p.f=500; // assume motion is in direction 
 
     // camera is pointing 
 
 } 
 
 pos—>p.l=0; pos—>p.u=0; 
 
 
This sets the velocity vector to one of two values, depending upon the magnitude of instantaneous acceleration being experienced. The vector component “pos->p.f” is the component pointing in the direction of the camera.
If the magnitude is below the threshold G+ or −DELTA_MAG (the force of gravity plus or minus a small deviation, determined by empirical measurement), the camera is assumed to be at rest. If the magnitude is outside this range the velocity is set to be the average velocity of a person walking. The camera is pointed in the direction the operator is walking whenever the operator moves, and this velocity vector is transformed using, the same quaternion as the acceleration measurement above.
The velocity vector is rotated in the following code fragment:
The position is then calculated by summing each resultant component:
The full text of the alternative “acc2pos.c” file is given in Appendix F. This file is to be substituted for the “acc2pos.c” file listed in Appendix B.
In 
The velocity estimate is then transformed from platform coordinates to reference coordinates in box 3380. The resulting transformed velocity is summed component-wise to produce the position estimate in box 3390.
These boxes in 
Referring now to 
As shown in 
In 
The rangefinder 485 is shown connected to the CPU 480 by means of two serial communication lines, an outgoing serial communication line TXA1 carrying commands from the CPU 480 to the rangefinder 485, and a return serial communication line RXA1 carrying serial information from the rangefinder 485 back to the CPU 480. The rangefinder 485 returns gathered information periodically, at its own rate of speed. The CPU 480 formulates a range packet 520 (
The two gyroscopes, the directional gyroscope 400 and the vertical gyroscope 410, are designed so that when they are deprived of power, they return to rest positions with the vertical gyroscope 410 having its axis vertically disposed and with the directional gyroscope 400 having axis horizontally disposed.
When the camera 100 is placed into operation, the central processing unit 480 causes the control logic 490 to generate a GYRON signal and to feed it to a gyroscope regulated power supply 420. In response, the gyroscope power supply 420 generates a plus 10 volt, regulated +GYRO signal which feeds power to both of the gyroscopes 400 and 410. In response, the gyroscope motors begin to spin so their axis are stabilized and so that the gimbals associated with the gyroscopes begin to generate pairs of quadrature modulated signals indicating the rotational motions of the tracking data acquisition unit 105.
The directional gyroscope 400 generates two square wave signals in quadrature as the platform 415 is rotated about a vertical axis to the left or to the right. These quadrature signals, which may be called collectively the yaw signal, appear on the two wires DOA and DOB. These signals arise from sensors associated with the gimbals within the gyroscope 400 in response to rotation of the gimbals.
The vertical gyroscope 410 is similarly equipped with two sets of sensors associated with its gimbals to generate pitch and roll quadrature modulated signals. The pitch signal, which appears on the two wires V1A and V1B, indicates the rate at which the camera 100 is pointing more upwards towards the ceiling or more downwards towards the floor. The roll, signal which appears on two wires V0A and V0B, indicates the rate at which the camera is tilting to one side or to the other, away from or towards the vertical.
These quadrature modulated pairs of signals require brief explanation. Assume for the moment that the camera is being rotated horizontally from left to right. This will cause a yaw signal to appear on the two wires D0A and D0B. Each wire bears a square wave signal, and the square waves are at quadrature with each other. This means that a negative going transition of the first of the square wave signals is followed by a negative going transition of the second of the square wave signals. Likewise, a positive going transition of the first signal is always followed by a positive going transition of the second signal. The speed of these transitions indicates the speed with which the camera is being rotated from left to right. If the camera motion stops, then the signals remain stationary until camera motion proceeds once again.
If the direction of rotation is reversed, then again square wave signals are generated—but this time in the opposite phase of quadrature. Thus, if a left-to-right motion causes a first signal to make its transitions ahead of the second signal, then a right-to-left motion will cause the second signal to make its transitions ahead of the first signal. This is identical to the way in which the motion signals work in a mouse pointing device of the type commonly used with digital computers.
The pitch and roll signals, represented respectively by the V1A-V1B and by the V0A-V0B signal lines, operate in a manner identical to the yaw signal just described, with the information being conveyed by quadrature modulated square waves. The three pairs of quadrature modulated signals V1A, V1B, V0A, V0B, and D0A, D1B are fed into respective quadrature decoders 450, 455 and 460. The quadrature decoders 450, 455 and 460 are conventional models, in this case Hewlett Packard Model No. HCTL 2020. The three accelerometers 435, 440, and 445 are shown each generating an analog accelerometer output signal SIG0, SIG1, and SIG2 and also a temperature signal TEMP0, TEMP1, and TEMP2. These signals flow into the multiplexer and A-to-D converter 465.
In the manner described above, the central processing unit 480 is enabled to obtain data indicating the distance of the subject from the rangefinder 485; it is enabled to obtain pitch, roll, and yaw data values from the vertical and directional gyroscopes 400 and 410: and it is enabled to obtain data defining the instantaneous acceleration of the tracking data acquisition unit 105 from the accelerometers 435, 440 and 445 in all three coordinate directions. The CPU 480 continuously packages this information, as explained in steps 600 to 615 in 
The shift register and encoder 475 converts the signal into a modulated serial tracking data signal which is presented over the audio data line 115 to the audio record input 125 of the VCR 130.
To summarize the operation of the tracking data acquisition unit 105 as shown in 
It then combines all of this information into a packet, with each byte in the packet containing a “1” start bit, a nibble of data, and three trailing “0” stop bits, with a 3 byte header 530 and 550 such as those shown at 535 or 540 in 
Upon playback, the video signal 150 flows directly into the personal computer 185. The modulated tracking data signal 145 flows to a demodulator 155. Following demodulation, the unmodulated tracking data signal flows over a signal line 170 to the PC 185.
The program 2406 begins at 2408 by initializing the system. Initialization includes such steps as turning on the power supply 420 for the gyroscopes, programming and initializing the three quadrature decoders 450, 455, and 460, and setting up the analog to digital converter (within the block 465 in 
Next, at 2050, data is gathered from the rangefinder 485. At 2052, the analog to digital converter is commanded to gather from the accelerometers 435, 445, and 440 the current acceleration of the tracking data acquisition unit 105.
At step 2054, the above data, together with previously stored values of yaw, roll, and pitch are combined into a data packet, with 4 bits of data per byte, as has been explained above (steps 600, 605, 610, and 615 in 
At step 2056, the resulting data packet is placed into RAM memory as a series of bytes to await transmission to the shift register and encoder 475.
At step 2058, the interrupt driven program 2402 is placed into service to transmit the bytes of data to the shift register and encoder 475.
At step 2060, the program 2406 tests to see if all of the data bytes have been transmitted. Alternatively, the program simply suspends itself until a fixed time interval has expired. In either case, after transmission is completed or after the expiration of the time interval, program control recommences with step 2050.
The program 2406 thus continuously operates to assemble data packets and to transmit them to the shift register and encoder 475 where the data is modulated onto an audio signal suitable for recordation on the audio soundtrack of a VCR.
The program 2402 is an interrupt driven program placed into operation by the interrupt signal INT1 every time the shift register and encoder 475 successfully transmits a byte of information. At 2062, this program simply sends a data byte from RAM to the shift register and encoder 475 until there are no more data bytes that remain to be transmitted. This interrupt driven routine frees up the program 2406 from the time consuming task of continuously monitoring for when to transmit the next byte of data.
The program 2404 is also an interrupt driven program. It is placed into operation every time one of the three quadrature decoders receives a signal fluctuation from one of the gyroscopes. In response to INT2, this program gathers pitch, roll, and yaw values from the two gyroscopes and stores them in RAM for later transmission at step 2064.
Three display programs are available for viewing the information stored in the positional database.
The spatial database program 335 (
The movie mapper program 325 is described in detail below.
The positional frame retrieval program 330 allows the user to identify a region in space on the camera path using the WORLD TOOLKIT. The program defines a rectangular solid in space about each imaged object. The location of each item imaged is computed from the data in each record. All the image records where the location of the item image falls outside of the rectangular solid for an item are discarded, and all remaining records are displayed as a movie view of the item from different perspectives. In essence, all available frames showing the item or the volume indicated are displayed sequentially, giving all the views available of the desired item or volume.
The data tracking and acquisition unit and modulator 105 has illustratively been shown connected to a rangefinder, receiving therefrom a serial data signal which is conveyed to the central computer for possible use in a data retrieval system. The positional frame retrieval program 330 uses this range data to determine the position of imaged objects and to retrieve all images containing a designated object, as contrasted with the movie mapper program technique of retrieving images based upon camera position and orientation (described below).
For example, in 
The range data is preserved in the positional database 322 for this embodiment of the invention. Accordingly, the retrieval program 330, in response to a mouse click at the position of the object, may locate all records 775 which, from position, camera angle, and distance to subject, relate to images of that object. These may be grouped into an object database and displayed as a video movie, as described above.
In addition to a rangefinder, other devices may be attached to the serial data input of the tracking data acquisition unit and modulator 105, and data may be captured from these other devices. For example, data may be captured from a gas chromatograph or from a chemical sniffer. Sound may be recorded from a microphone. Average light intensity may be recorded from a photo cell. Infrared records of motion in the vicinity may be recorded. Data may be gathered from stationary machinery or data collection devices, such as flow meters or temperature sensors. Any type of data that has a spatial reference may be gathered in this manner.
Another embodiment of the invention is shown in 
In this embodiment, the tracking data acquisition unit and modulator 105 is not attached to the camera, but is attached by a serial communicator tether 3102 (which could include a radio linkage) directly to the serial port of the computer 185, such that the tracking and video data entry and storage program continuously accepts the data and stores it in the tracking database 324. The tracking data acquisition unit is thus enabled to be used as a mouse pointing device for the positional frame retrieval program 330 to guide in the retrieval and display of images—an inertial joystick.
The tracking database 324 may be on the hard disk as previously, but preferably it is a RAM circular buffer that is shared by the tracking database to positional database conversion program 310. Alternatively, the tracking data values may be sent as messages between the two programs running under Windows and subject to the standard Windows message dispatcher (not shown). Both of the programs 305 and 310 can be simplified, since neither is dealing with video or with frame numbers in this embodiment.
The tracking database to positional database conversion program operates continuously, receiving tracking data containing unnormalized acceleration and orientation data and converting it into normalized position and orientation data, and sending the resulting data directly to the positional frame retrieval program 330, thereby causing the program 330 to update the display continuously in response to manual movement of the tracking data acquisition unit and modulator 105 through time and space.
As an alternative, two computers can be utilized. A first portable computer (not shown) can be attached to the tracking data acquisitional unit and modulator 105 can contain the program elements 305, 324, 310 and 330, shown in 
As a third alterative, the tracking data acquisition unit and modulator 105 in 
The arrangement illustrated in 
Another embodiment of the invention utilizes a movie mapper 325 (
The program 325 is written in Microsoft C++ to run under Microsoft Windows, Version 3.1. Some of the programs call upon routines contained within the Microsoft Video For Windows Development Kit, Version 1.1. All of the above may be obtained from Microsoft Corporation, 1 Microsoft Way, Redmond, Wash. 98052. The Media Control Interface “MCIWind” 10944 (
With reference to 
The program 325 opens up the selected “*.AVI” file. It also looks for and attempts to open a telemetry file, containing the positional information, which has the same name and the file name suffix “*.TLA”. The “*.TLA” file must be prepared for this program by adding to the beginning of the file a single line of text. The line is “HDR<tab ><last frame number>” where <tab> is the tab character, and <last frame number> is the first number on the last line of the file. If no “*.TLA” file is found, the system issues an error message but permits one to browse through the “*.AVI” file in the normal Microsoft manner. The program also looks for and attempts to open an “*.MTA” file for its own use in defining overlay characteristics. An empty “*.MTA” file should be supplied, since the program will issue an error message and quit if none is found. The File popdown menu contains the usual list of Microsoft options, including Open AVI, Print, Print Preview, Print Setup, Exit, and a numbered list of recently opened AVI files to facilitate recalling a file recently opened.
The figures illustrate what happens when an AVI file BACK.AVI and its corresponding telemetry file BACK.TLA were successfully opened. Upon opening this file, the program 325 causes a Video child window 10110 to be opened, displaying in this case a view of the back yard of a private home. This video window is labelled at the top with “BLACK.AVI—Video” to identify both the file and the fact that this is the child window. The child window 10110 provides controls that are standard Microsoft controls for scrolling through a sequence of video images. These include a VCR-like control 10108. Clicking on this control starts the video playback if it is stopped, and stops it if it is running. The control is marked with a square when the video is playing, and it is marked with a triangle (shown) when the video is stopped. The Video popdown menu contains selections for changing the size of the video window to the original size, half the original size, or double the original size. A mouse-actuated slider control 10103 (
A View pulldown menu permits additional child windows to be opened that relate to the position information. The View menu provides the following options, which are described below:
Actuating the Plan command causes a plan view: XY child window 10120 to open up, displaying the path 10123 over which the camera was moved during the process of recording the sequential images. This window is labeled: “BACK.AVI—Plan View: XY” to identify the file name as well as the nature of the view. While not clearly visible in 
Activating the Elevation command causes an Elevational View: XZ child window 10130 to open up, displaying the camera path of movement as seen from the side, rather than from the top. The display in all other respects is identical to the plan view display just described.
Activating the Yaw command causes a Yaw View child window 10140 to open up, displaying the various yaw directions the camera assumed during the image recording process. Yaw may be thought of as compass direction.
Likewise, activating the Pitch command causes a Pitch View child window 10150 to open up, displaying pitch directions in a fashion analogous to the Yaw View above. Pitch is inclination of the camera in the vertical image plane, that is looking up and down. In this example, the images do not vary significantly in pitch.
Activating the Roll command opens a Roll View child window 10160, displaying roll directions as above. Roll is the tilt of the image plane from side to side, or leaning.
By clicking twice upon a point on the camera path in any of the child windows 10120, 10130, 10140, 10150, or 10160, the user may signal the program to switch to displaying the image closest to the point where the mouse pointer was clicked and having the desired position, angle, or orientation. This selection process provides a rapid method for retrieving and positioning the video for playback based upon the desired position of the camera when an image was captured.
Activating the Orientation View command causes a child window 10180 to open up, displaying the orientation of the camera (pitch, roll, and yaw) graphically. Unfortunately, the absence of colors in 
The actual direction of the camera, when it captured the image shown in the child window 10110, is indicated by the line 10183, which appears half in red and half in blue in the actual program display (and does not match the bold black line 10189). The dotted line 10184 is a projection of the camera direction line 10183 onto the X-Y plane. As a sequence of images is displayed in response to actuation of the play control 10108, the red-blue line 10183 swings about, indicating the orientation of the camera, and the dotted line 10184 swings about below (or above) the line 10183 like a shadow at noontime on the equator.
Roll is represented by the ratio of blue and red portions of the line 10183. If the roll value is zero, then the line is half red and half blue. Roll in a clockwise direction increases the blue, while roll in a counterclockwise direction increases the red. A positive roll gives more red.
A toolbar containing push button controls (10141, 10142, etc.) appears in the window 10101 and may be selectively displayed or hidden by actuating the Toolbar command in the View pulldown menu. The push button 10141 is an alternate way to open a file. The push buttons 10142 and 10145 respectively wind to the first and the last frames, and the push buttons 10143 and 10144 respectively move back and forward by one frame at a time.
The push button 10146 zooms in, and the push button 10147 zooms out. These two push buttons control the portion of the video path that is displayed by the Plan View and Elevational View child windows 10120 and 10130, and the orientations shown in the Yaw View, the Pitch View, and the Roll View. To zoom in, and with reference to 
The user may also create a rectangle within the Elev: XZ window, if desired. When the zoom-in push button 10146 is actuated, the selected rectangle fills the XZ window, and the X axis of the XY window is zoomed in the X axis only. Points not within the XZ selection rectangle are then excluded from the elevational view.
The user may also create a rectangle in the Yaw View window 10140, the Pitch View window 10150, or the Roll View window 10160, if desired. When the zoom-in push button 10146 is actuated, the selected rectangle fills the window, and the Yaw, Pitch, or Roll values displayed within the selected rectangle expand to fill the display. Points in the Plan View: XY window 10120 and the Yaw View window 10140 which do not have yaw, pitch, and roll values within the resulting displayed Yaw View. Pitch View, and Roll View windows are excluded from the Plan View window and Elev XZ window.
Actuation of the zoom-out push button 10147 causes the plan and elevational displays to return to their original appearance (as shown in 
Actuating the Overlay Visibility . . . menu selection from the View menu causes the display of an Overlay Visibility dialog window 11110 (
The Overlay items listed above will be described later.
The final command in the View popdown menu is the Status command, which hides or displays a status line at the bottom of the window 10190 and which indicates such things as the frame number and the X, Y, Z, Yaw, Pitch, and Roll coordinates of the camera corresponding to the image that is being displayed.
The Frame pop down menu displays the following commands, all of which relate to simply positioning the video as if it were a continuous video tape recording:
Additionally, the Frame pop down menu displays the following commands which have a special meaning:
The Loop Forward function may alternatively be started and stopped by striking the space bar. Each strike toggles the Loop Forward function between the started and stopped state.
The Action Menu has functions corresponding to the Toolbar buttons Zoom In 10146 and Zoom Out 10147. It also has functions corresponding to the Head Forward button 10148 and Head Back button 10149. Finally the Adjust Parameters function brings up a dialog box 10310 (
The Head Forward 10148 and Head Back 10149 buttons and functions allow the user to move forward or back up from the currently displayed frame. The Head Forward frame and Head Back frame are shown as green dots 10123 and 10124 on the Plan View window, and as green rectangles 10420 and 10422 (
The Head Forward frame is chosen by the program such that when it is displayed the appearance to the user is that the user has moved forward. This frame is selected in the following manner. Search all the frames in the telemetry file (*.tla) and determine which are within the front field of view angle from the perspective of the current frame.
The front field of view is defined here. Define a ray with its origin at the current frame's x-y location and extending in the direction of the yaw angle, called the centerline of the frame. Define a pair of rays with the same origin, called left and right lines of the frame, which make an angle with the centerline specified by the user in the Action-Adjust Parameters dialog (
Of all the frames within the field of view (fov), determine which are within an operator specified radius (the Action-Adjust Parameters dialog Neighborhood Multiplier item 10320 (
The weight given this distance error is proportional to the value of the Action-Adjust Parameters dialog Selecting Side Angles scroll bar item 10340 (
Sometimes there is not an appropriate frame. In that case, none are selected and no corresponding overlay is displayed.
The Head Back frame is calculated in an similar manner to that used to the Head Forward frame with the exception that this frame must lie in the rear field of view. The rear field of view is a yaw angle range that can be found by reflecting the front field of view angle range to the back of the current frame. These fields of view are the same magnitude and face in opposite directions. For the case of jumping backward, the yaw angle goal is equal to the yaw angle of the current frame.
The keyboard Up-arrow-key and letter I key also execute the Head Forward function, the keyboard Down-arrow-key and letter K key also execute the Head Back function.
The View menu-Triple Mci function causes the MCIview window to expand to include three video windows (
If no frame is found that meets the criteria for selection, no frame is displayed. If a frame has been chosen for the left frame or the right frame, that frame is displayed within its own MCIwnd, located to the left or the right of the center frame.
The left and right frames are aligned with the center frames based on the fov and on the yaw and pitch values of the centerlines of the frames. The fov defines a “pixel per degree” displacement on the screen. For each degree the left or right frame's centerline disagrees with the predicted centerline (center frame's centerline plus or minus twice the fov) the frame is shifted a corresponding number of pixels. Likewise, the frame is shifted up or down by the pixel per degree amount by which the frame's pitch differs from the center frame's pitch.
The left arrow key and the J key on the keyboard select a new frame for viewing. Initially the frame selected is the displayed left frame described above. The 0 through 9 keys allow the selection of a frame (if one exists) which has a centerline less than twice the fov angle. Pressing the 1 key sets the goal centerline angle to the centerline angle of the current frame plus or minus 10 percent of twice the fov angle. The 2 key similarly sets the goal centerline angle to 20 percent of twice the fov angle. The 0 key sets the goal centerline angle to 100 percent of twice the fov angle. Note that this setting yields the frame which precisely abuts the center frame, since points on the edge of the center frame lie on a vertical plane extending from the current point of view which makes an angle of exactly “fov” degrees with the current frame centerline.
An overlay item represents a point or area of interest of the database as projected onto the current frame. Several overlay item types are defined by the movie mapper program. The overlay items which represent frames are the jump forward rectangle 10420 (
Additionally, one or more frames may be defined as Entrance frames, marked on the Video Overlay window with an Entrance item 11230 (
Three overlay item types describe areas rather than points. An Exit item marks an area of the Plan View containing frames of the current database which when viewed will cause the display of an associated Entrance frame. A Launch Pad area item 10722 (
An Exit area is defined by the operator's actions:
The operator clicks on the Plan View window, holding the left mouse button down and moving the pointer to another point within the plan view window. This action creates a rectangle drawn on the Plan View 10122 (
A Launch Pad item is defined in a similar fashion. The operator clicks and drags on the Plan View window as above, and then invokes the Objects-Create Launch Pad dialog 10600 (
Each of these overlay items is projected onto the current video frame according to the overlay calculation code described above.
The Window pop down menu provides conventional Microsoft Windows window control functions that need not be described here. The Help popdown menu also needs no special explanation.
The object program structure of the movie mapper 325 is described in overview in 
The operating program is composed of a number of objects each of which is an instance of some class of objects. These objects are represented by rectangles in 
When the program commences operating, it first appears as an object named CVidApp 10902 (
This CMainFrame object next launches a child frame derived from Microsoft's CMDIChildWnd that is of the class CMDITextWnd 10938. This object gives rise to a child window that is modified from the Microsoft original in that its title line (positioned above the window) may be dynamically altered while the program is in operation.
This first child object launches within itself an instance of the CMCIView 10940 object, which launches MCIWnd 10944 to display the sequence of video images.
The CMciView object 10944 also launches a CMCIWnd object 10950. The CMCIWnd object 10950 attaches itself to the MCIWnd object 10944 so that Windows operating system events come to the CMCIWnd 10950 object instead of being sent directly to the MCIWnd object 10944. In most cases the CMCIWnd 10950 object merely forwards the events to the MCIWnd object 10944. The CMCIWnd object 10950 intercepts mouse events, so that it may sense operator clicks on the overlay objects. The CMCIWnd object 10950 also intercepts MCIWnd redraw requests, forwards these requests to MCIWnd 10944 for video refresh, and then redraws the overlay objects associated with the video frame being displayed.
The CMciView and MCIView objects are the lower-most of the seven objects shown in 
Six more windows may be opened by the user through activation of the View pop down menu, as has been described. Each of these windows corresponds to an additional pair of nested objects which appear within the CMainFrame object 10905 shown in 
If the user opens the Plan View: XY window 10120 (
If the user opens the Yaw View window 10140, then the object CMDITextWnd 10918 containing the object CYawView 10910 is created within the CMainFrame object 10905, and this pair of objects together create the child window shown at 10140 in 
If the user opens the Pitch View window 10195, then the object CMDITextWnd 10923 containing the object CPitchView 10925 is created within the CMainFrame object 10905, and this pair of objects together create the child window shown at 10195 in 
If the user opens the Roll View window 10160, then the object CMDITextWnd 10923 containing the object CRollView 10915 is created within the CMainFrame object, and this pair of objects together create the child window shown at 10160 in 
As the user closes the windows, the corresponding pairs of objects are destroyed.
The objects, once created, send messages back and forth to each other over the paths illustrated in 
When the user “talks” to the program, using the keyboard or mouse, in general the user communicates with the active window (in the case of the keyboard) or the window that the mouse is in (in the case of the mouse), selecting a different active window by clicking within the window boundaries. The nine windows shown in 
The central coordinating object is the document object, which is an instance of CVidDoc 10927 which is derived from the class Cdocument (a Microsoft class). This object contains the key system variables that determine the state of the system. Included, as illustrated in 
If any window receives a message that calls for adjustment of one of the key system variables, that message is sent immediately to the document object CVidDoc 10907. The value of the key variable is adjusted, and then the document object 10907 broadcasts an “Update All Views” message over the path 10980 to the MCIWnd child window object 10944, over path 10911 to object 10910, over path 10921 to object 10920, over path 10926 to object 10925, over path 10916 to object 10915, over path 10936 to object 10935, over path 10941 to object 10940, and over path 10946 to object 10945. Each responds accordingly. The “Update All Views” message contains a hint that says either:
The individual window objects next communicate with the document object 10907 over paths 10911, 10916, 10921, 10926, 10936, 10941, and 10946 and receive information via paths 10912, 10917, 10922, 10927, 10937, 10942, and 10947 to learn of the new state of the system and to retrieve from the document object 10907 whatever data they need to update their respective windows. For example, if the user at 10902 clicks upon the “zoom out” push button 10146 (
Double clicking on the path in one of the windows 10110, 10120, 10130, 10140, 10150, 10160, and 10180 (
When the user activates the video controls within the child window 10110 (
The program provides the facility of navigating through the video database by selecting frames of data from the database which represent translations and rotations from the position of the current frame's point of view. The program searches the database for frames which best meet the criteria, and the operator then selects one of these frames using the keys or mouse as described above. The following paragraphs describe the method the program uses to select the best frame for each of the possible operator choices (turn left, turn right, jump forward, jump backward, jump forward and simultaneously turn right, jump forward and simultaneously turn left).
First, the program initializes variables which are used to keep track of the best entry found for each of the selections above. Cw_slope is clockwise, and ccw_slope is counterclockwise. Fov is the slope data for the current frame. LeftDiag is the slope data for the frame to the left of the current frame, its centerline close to twice the fov counterclockwise of the current frame's centerline. RightDiag is the slope data for the frame to the right of the current frame, its centerline close to twice the fov clockwise of the current frame's centerline.
 
 
 
void Tla_File::select_field_of_view(unsigned short current_frame) 
 
{ 
 
 unsigned short fov_subset_index = MIN_FRAME_COUNT:// index used w/ subset array 
 
 unsigned short subset_index; 
// index used w/ data arrays 
 
 SlopeData 
Fov; 
 
 SlopeData 
LeftDiag; 
 
 SlopeData 
RightDiag; 
 
 float IndexCurrentSlope; 
 
 int 
current_x 
= get_x_data(current_frame);  
// get x coor for current frame 
 
 int 
current_y 
= get_y_data(current_frame);  
// get y coor for current frame 
 
 int 
index_x; 
// a coor of point/frame under test of being in camera's field of view 
 
 int 
index_y; 
 
 BOOL 
same_location; 
// true if indexed point and current point are same point or location 
 
 BOOL 
in_front_fov; 
// true if indexed point is in the camera's field of view at current pt 
 
 BOOL 
in_rear_fov; 
// true if indexed point is in the current pt camera's rear view mirror's fov 
 
 BOOL 
in_left_diag; 
// true if indexed point is in the left diagonal's range as seen from current  
 
 
 
 pt 
 
 BOOL 
in_right_diag; 
// true if indexed point is in the right diagonal's range as seen from current  
 
 
 
 pt 
 
 // time saving combination used in side frame selection tradeoff 
 
 // m_Selecting_Tradeoff is 1 to 17 
 
 float DistanceGain = (float)(NEUTRAL_DIST_GAIN * m_Selecting_Tradeoff /  
 
 DEFAULT_PRIORITY); // ~⅛ to 2+ 
 
 // calc slope of line of clockwise field of view limit within the xy plan (plan view) 
 
 Fov.cw_slope = get_yaw_data(current_frame) − (m_HorzFieldOfViewAngle / 2); 
 
 // calc slope of line of counterclockwise field of view limit within the xy plan (plan view) 
 
 Fov.ccw_slope = get_yaw_data(current_frame) + (m_HorzFieldOfViewAngle / 2); 
 
 CalcSlopeData converts the cw_slope and ccw_slope angles of the current frame to the  
 
 tangent of the angles, with quadrant. 
 
(FIG. 33. step 11520) 
 
 CalcSlopeData(&Fov); // calc variables used in testing slope limits. Means of testing if yaw in  
 
 bounds 
 
 // sets goal for side frame selection as fraction of m_HorzFieldOfViewAngle 
 
 float TurnAngleGoal = m_SideFrameGain * m_HorzFieldOfViewAngle; 
 
 // left is ccw and TurnAngleGoal is added to turn left 
 
 // right is cw and TurnAngleGoal is subtracted to turn right 
 
 if (TurnAngleGoal > m_MaxHeadingAngle) // note this is a new use for m_MaxHeadingAngle 
 
 { 
 
 
 // want right most limit of left diag range to be left of current yaw 
 
 LeftDiag.cw_slope = get_yaw_data(current_frame) + TurnAngleGoal −  
 
 m_MaxHeadingAngle; 
 
 
 // want left most limit of right diag range to be right of current yaw 
 
 RightDiag.ccw_slope = get_yaw_data(current_frame) − TurnAngleGoal +  
 
 m_MaxHeadingAngle; 
 
 } 
 
 else 
 
 { 
 
 LeftDiag.cw_slope = get_yaw_data(current_frame); 
 
 RightDiag.ccw_slope = get_yaw_data(current_frame); 
 
 } 
 
 // note this is a new use for m_MaxHeadingAngle 
 
 LeftDiag.ccw_slope = get_yaw_data(current_frame) + TurnAngleGoal +  
 
 m_MaxHeadingAngle; 
 
 RightDiag.cw_slope = get_yaw_data(current_frame) − TurnAngleGoal −  
 
 m_MaxHeadingAngle; 
 
 CalcSlopeData converts the cw_slope and ccw_slope angles of the LeftDiag and RightDiag to the  
 
 tangent of the angles, with quadrant.  
 
(FIG. 33, step 11530) 
 
 CalcSlopeData(&LeftDiag); // calc variables used in testing slope limits. Means of testing if  
 
 yaw in bounds 
 
 CalcSlopeData(&RightDiag); // calc variables used in testing slope limits. Means of testing if  
 
 yaw in bounds 
 
 m_FovSubsetIndexMax = NO_FRAMES; 
 
 float  
CurrentPointYaw = get_yaw_data(current_frame); // use for finding most aligned fov pt 
 
 float  
IndexPointYaw; 
 
 float  
Cos_CurrentPointYaw = (float)cos(CurrentPointYaw * DEG_TO_RAD); 
 
 float  
Sin_CurrentPointYaw = (float)sin(CurrentPointYaw * DEG_TO_RAD); 
 
 float  
xCurrentMinusIndex; 
// diff in x between current pt and index pt 
 
 float  
yCurrentMinusIndex; 
// diff in y between current pt and index pt 
 
 // in these rating, smaller is better 
 
 // used for selecting best frames to use for right and left mciwnds 
 
 float 
AdjIndexCurrentDistanceRating; 
// rating by distance from current point adj for  
 
 
 
 angle 
 
 float 
WeightedRadiusDistanceRating; 
// rating by distance from neighbor hood radius 
 
 float 
LeftIndexRating; 
// measure of merit for indexed pt as left pt 
 
 float 
RightIndexRating; 
// measure of merit for indexed pt as right pt 
 
 float 
FovIndexRating; 
// measure of merit for indexed pt as fwd jump pt 
 
 float 
FwdSmallestDisplayRating 
= HIGH_VALUE_RATING; // best measure of merit for  
 
 
 
 fwd jump pt so far 
 
 float 
RearSmallestDisplayRating 
= HIGH_VALUE_RATING; // best measure of merit for  
 
 
 
 rear jump pt so far 
 
 float 
LeftSmallestDisplayRating 
= HIGH_VALUE_RATING; // best measure of merit for  
 
 
 
 left display pt so far 
 
 float 
RightSmallestDisplayRating 
= HIGH_VALUE_RATING; // best measure of merit for  
 
 
 
 right display pt so far 
 
 float 
LeftSmallestTurnRating 
= HIGH_VALUE_RATING; // best measure of merit for  
 
 
 
 left turn pt so far 
 
 float 
RightSmallestTurnRating 
= HIGH_VALUE_RATING; // best measure of merit for  
 
 
 
 right turn pt so far 
 
 float 
LeftSmallestDiagRating 
= HIGH_VALUE_RATING; // best measure of merit for  
 
 
 
 left diag turn pt so far 
 
 float 
RightSmallestDiagRating 
= HIGH_VALUE_RATING; // best measure of merit for  
 
 
 
 right diag turn pt so far 
 
 float 
DisplayYawAbsDiff; 
// abs diff in yaw of limit yaw + trial display pts 
 
 float 
TurnYawAbsDiff; 
// abs diff in yaw of limit yaw + trial turn pts 
 
 float 
CurrentIndexYawAbsDiff; 
// abs diff in yaw of current and index pts 
 
 float 
IndexCurrentYawDiff; 
// signed diff in yaw of current and index pts 
 
 BOOL 
IndexYawToLeftOfCurrentYaw; 
// is candidate frame's yaw pointing to left of  
 
 
 
 current yaw 
 
 float 
DistanceSquared; 
// square of distance betw index and current pts. 
 
 float 
NeighborRadiusSquared 
= m_NeighborRadius * m_NeighborRadius: 
 
 sqr of neighborhood radius 
 
 float 
MultipliedNeighborRadiusSquared  
// sqr of multiplied limit of neighborhood radius 
 
 = m_NeighborhoodMultiplier * m_NeighborhoodMultiplier *  
 
 NeighborRadiusSquared; 
 
The result variables are set to reflect the selection results when no frames are found. (FIG. 33, step  
 
11510) 
 
 m_FovPtClosestInYaw 
= NO_FRAMES; 
// no closest point 
 
 m_RearFovPtClosestInYaw 
= NO_FRAMES; 
// no closest point 
 
 m_PtLeftFOV 
= current_frame; 
// if find nothing better, show behind current  
 
 
 
 point 
 
 m_PtRightFOV 
= current_frame; 
// if find nothing better, show behind current  
 
 
 
 point; 
 
 m_PtLeftTurn 
= current_frame; 
// if find nothing better, show over current point; 
 
 
 // no closest point 
 
 m_PtRightTurn 
= current_frame; 
// if find nothing better. show over current point; 
 
 m_PtLeftDiag 
= NO_FRAMES; 
 
 m_PtRightDiag 
= NO_FRAMES; 
 
 float LeftFovPtYaw 
= CurrentPointYaw + m_HorzFieldOfViewAngle; 
// don't  
 
 
 
 worry  
 
 
 
 if > 180′ 
 
 float RightFovPtYaw 
= CurrentPointYaw − m_HorzFieldOfViewAngle; 
// don't  
 
 
 
 worry  
 
 
 
 if < −180′ 
 
 float Left2FovPtYaw 
= CurrentPointYaw + (2 * m_HorzFieldOfViewAngle); 
// don't  
 
 
 
 worry  
 
 
 
 if > 180′ 
 
 float Right2FovPtYaw 
= CurrentPointYaw − (2 * m_HorzFieldOfViewAngle); 
// don't  
 
 
 
 worry  
 
 
 
 if < −180′ 
 
 float LeftTurnPtYaw 
= CurrentPointYaw + TurnAngleGoal; 
// don't  
 
 
 
 worry  
 
 
 
 if > 180′ 
 
 float RightTurnPtYaw 
= CurrentPointYaw − TurnAngleGoal; 
// don't  
 
 
 
 worry  
 
 
 
 if < 180′ 
 
 Now iterate through all frames in the database. (FIG. 32, Steps 11430, 11450, and 11465) The search  
 
 may be limited to a subset of the all the frames in the database, if the operator has zoomed in on one  
 
 of the data windows (Plan View, Elev. View, Yaw View, Pitch View, Roll View). 
 
 unsigned short frame_index; 
 
 if (m_zoom_subset_index_max != NO_FRAMES) 
// If there are points in reg subset 
 
 { 
 
 for (subset_index = MIN_FRAME_COUNT; 
 
 subset_index <= m_zoom_subset_index_max; // do all pts in reg subset defined by views 
 
 subset_index++ 
 
 ) 
 
 { 
 
 in_front_fov 
= FALSE; 
 
 in_rear_fov 
= FALSE; 
 
 in_left_diag 
= FALSE; 
 
 in_right_diag 
= FALSE; 
 
 frame_index = get_frame_from_zoom_subset(subset_index); 
 
 IndexPointYaw = get_yaw_data(frame_index); 
 
 Get the X and Y data for the frame. (FIG. 34, step 11610) In this loop “index” is the index of the  
 
 frame being tested. “Current” is the index of the currently displayed frame. 
 
 index_x 
= get_x_data(frame_index); 
 
 index_y 
= get_y_data(frame_index); 
 
 
 // calc offset using normal x,y axes 
 
 xCurrentMinusIndex = current_x − index_x; 
 
 yCurrentMinusIndex = current_y − index_y; 
 
 Calculate distance from current frame's location to index frame's location on plan view. (FIG. 34,  
 
 step 11620) 
 
 DistanceSquared = (float)(xCurrentMinusIndex*xCurrentMinusIndex +  
 
 yCurrentMinusIndex*yCurrentMinusIndex); 
 
 // calc slope of line from current point to point under test (subset_index point) 
 
 // first prevent divide by zero 
 
 same_location = FALSE; 
 
 Calculate yaw difference between current frame and index frame. Make sure to keep result in range  
 
 of +/− 180 degrees. (FIG. 34, step 11630) 
 
 IndexCurrentYawDiff = IndexPointYaw − CurrentPointYaw; // pos yaw is counter clockwise 
 
 if (((IndexCurrentYawDiff >= 0) 
// if candidate's yaw is closer to current pt's yaw in ccw dir 
 
 && (IndexCurrentYawDiff <= 180) 
// but no wrap around that makes far really close on  
 
 
 other side 
 
 ) 
 
 ¦¦ ( IndexCurrentYawDiff < −180) 
// appears to be clockwise 
 
 // but does wrap around so makes big duff really close on  
 
 other side 
 
 ) 
 
 { 
 
 IndexYawToLeftOfCurrentYaw = TRUE; 
 
 } 
 
 else 
 
 { 
 
 IndexYawToLeftOfCurrentYaw = FALSE; 
 
 } 
 
 CurrentIndexYawAbsDiff = (float)(fabs(CurrentPointYaw − IndexPointYaw)); 
 
 // Cant be further apart than 180 
 
 if (CurrentIndexYawAbsDiff >= 180) 
 
 { 
 
 CurrentIndexYawAbsDiff = 360 − CurrentIndexYawAbsDiff; 
 
 } 
 
 Test for special cases of slope for the line between the index and the current. The math calculation  
 
 causes an error if the slope is vertical. 
 
 Then calculate slope in the more general case. (FIG. 34, step 11640) 
 
 // you would think that checking index_x and index_y would catch this 
 
 // but the math is sometimes inexact evidently so explicitly check if same point 
 
 if (current_frame == frame_index) 
 
 { 
 
 // two points are on exactly same spot. You cant see yourself in your field of  
 
 view 
 
 IndexCurrentSlope = 0; 
// s/b undefined, really. 
 
 same_location = TRUE: 
 
 } 
 
 else 
 
 { 
 
 if (index_x == current_x) 
 
 { 
 
 if (index_y > current_y) 
 
 { 
 
 IndexCurrentSlope = MAX_SLOPE: 
 
 } 
 
 else if (index_y < current_y) 
 
 { 
 
 IndexCurrentSlope = −MAX_SLOPE; 
 
 } 
 
 else 
 
 { 
 
 // two points are on exactly same spot. You cant see yourself in your field of  
 
 view 
 
 IndexCurrentSlope = 0; 
// s/b undefined, really. 
 
 same_location = TRUE; 
 
 } 
 
 } 
 
 else // ok tc calc slope. no divide by zero 
 
 { 
 
 IndexCurrentSlope = ((float)index_y − current_y) / (index_x − current_x); 
 
 } 
 
 } 
 
 Test the indexed point to find if it is in the front or rear field of view (fov) of the current frame, in the  
 
 RightDiag's fov, or in the LeftDiag's fov. Jump and turn right's frame will be selected from the  
 
 RightDiag fov. Jump and turn left's frame will be selected from the LeftDiag fov. (FIG. 34, step  
 
 11650) 
 
 // So, is the indexed point within the FRONT field of view of current point? 
 
 // Is it between the cw and ccw slope limits? If so, then in fov 
 
 // Note. Here x,y are data x,y, not display pixel x,y. First quadrant is pos x and pos y. 
 
 if ( index_y >= current_y) 
 
 { 
 
 if (index_x >= current_x) 
// index_quadrant = FIRST_QUADRANT; 
 
 { 
// slopes in this quadrant are positive. pos x/ pos y 
 
 if (( (Fov.cw_quadrant == FIRST_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >= Fov.cw_slope) // proper relationship 
 
 ) 
 
 ¦¦ ( Fov.cw_quadrant == FOURTH_QUADRANT) // (IndexCurrentSlope >=  
 
 cw_slope) is automatic here 
 
 ) 
 
 { 
 
 if (( (Fov.ccw_quadrant == FIRST_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= Fov.ccw_slope) // proper relationship 
 
 ) 
 
 ¦¦ (Fov.ccw_quadrant == SECOND_QUADRANT) // (IndexCurrentSlope <=  
 
 cw_slope) is automatic here 
 
 ) 
 
 { 
 
 in_front_fov = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 // see if in left diag yaw range 
 
 if (( (LeftDiag.cw_quadrant == FIRST_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >= LeftDiag.cw_slope)// proper relationship 
 
 ) 
 
 ¦¦ ( LeftDiag.cw_quadrant == FOURTH_QUADRANT) // (IndexCurrentSlope >=  
 
 cw_slope) is automatic here 
 
 ) 
 
 { 
 
 if (( (LeftDiag.ccw_quadrant == FIRST_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= LeftDiag.ccw_slope) // proper relationship 
 
 ) 
 
 ¦¦ (LeftDiag.ccw_quadrant == SECOND_QUADRANT) // (IndexCurrentSlope <=  
 
 cw_slope) is automatic here 
 
 ) 
 
 { 
 
 in_left_diag = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 // see if in right diag yaw range 
 
 if (( (RightDiag.cw_quadrant == FIRST_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >= RightDiag.cw_slope) // proper relationship 
 
 ) 
 
 ¦¦ ( RightDiag.cw_quadrant == FOURTH_QUADRANT) // (IndexCurrentSlope >=  
 
 cw_slope) is automatic here 
 
 ) 
 
 { 
 
 if (( (RightDiag.ccw_quadrant == FIRST_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= RightDiag.ccw_slope)// proper relationship 
 
 ) 
 
 ¦¦ (RightDiag.ccw_quadrant == SECOND_QUADRANT) // (IndexCurrentSlope <=  
 
 cw_slope) is automatic here 
 
 ) 
 
 { 
 
 in_right_diag = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 } 
// if quadrant 
 
else // (index_x < current_x)  
index_quadrant = SECOND_QUADRANT; 
 
 { 
// slopes in this quadrant are negative. neg x/ pos y 
 
 if (( (Fov.cw_quadrant == SECOND_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >= Fov.cw_slope) // greater than here means less negative 
 
 ) 
 
 ¦¦ ( Fov.cw_quadrant == FIRST_QUADRANT) // must be ok so far 
 
 ) 
 
 { 
 
 if (( (Fov.ccw_quadrant == SECOND_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= Fov.ccw_slope) // less than here means more negative 
 
 ) 
 
 ¦¦ (Fov.ccw_quadrant == THIRD_QUADRANT) // must be ok 
 
 ) 
 
 { 
 
 in_front_fov = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 // see if in left diag yaw range 
 
 if (( (LeftDiag.cw_quadrant == SECOND_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >= LeftDiag.cw_slope)// greater than here means less negative 
 
 ) 
 
 ¦¦ ( LeftDiag.cw_quadrant == FIRST_QUADRANT) // must be ok so far 
 
 ) 
 
 { 
 
 if (( (LeftDiag.ccw_quadrant == SECOND_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= LeftDiag.ccw_slope)// less than here means more negative 
 
 ) 
 
 ¦¦ (LeftDiag.ccw_quadrant = THIRD_QUADRANT) // must be ok 
 
 ) 
 
 { 
 
 in_left_diag = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 // see if in right diag yaw range 
 
 if (( (RightDiag.cw_quadrant == SECOND_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >= RightDiag.cw_slope) // greater than here means less negative 
 
 ) 
 
 ¦¦ ( RightDiag.cw_quadrant == FIRST_QUADRANT) // must be ok so far 
 
 ) 
 
 { 
 
 if (( (RightDiag.ccw_quadrant == SECOND_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= RightDiag.ccw_slope) // less than here means more negative 
 
 ) 
 
 ¦¦ (RightDiag.ccw_quadrant == THIRD_QUADRANT) // must be ok 
 
 ) 
 
 { 
 
 in_right_diag = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 } 
// else quadrant 
 
 } 
 
else 
// (index_y < current_y) 
 
 { 
 
 if (index_x >= current_x) 
// index_quadrant = FOURTH_QUADRANT; 
 
 { 
// slopes in this quadrant are negative. pos x/ neg y 
 
 if (( (Fov.cw_quadrant == FOURTH_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >= Fov.cw_slope) 
// greater than here means less negative 
 
 ) 
 
 ¦¦ (Fov.cw_quadrant == THIRD_QUADRANT) 
 
 ) 
 
 { 
 
 if (( (Fov.ccw_quadrant == FOURTH_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= Fov.ccw_slope) 
// less than here means more negative 
 
 ) 
 
 ¦¦ ( Fov.ccw_quadrant == FIRST QUADRANT) 
 
 ) 
 
 { 
 
 in_front_fov = TRUE: 
 
 } 
// ccw 
 
 } 
// cw 
 
 // see if in left diag yaw range 
 
 if (( (LeftDiag.cw_quadrant == FOURTH_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >=. LeftDiag.cw_slope) // greater than here means less negative 
 
 ) 
 
 ¦¦ (LeftDiag.cw_quadrant == THIRD_QUADRANT) 
 
 ) 
 
 { 
 
 if (( (LeftDiag.ccw_quadrant == FOURTH_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= LeftDiag.ccw slope) // less than here means more negative 
 
 ) 
 
 ¦¦ ( LeftDiag.ccw_quadrant == FIRST_QUADRANT) 
 
 ) 
 
 { 
 
 in_left_diag = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 // see if in right diag yaw range 
 
 if (( (RightDiag.cw_quadrant == FOURTH_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >= RightDiag.cw_slope) // greater than here means less negative 
 
 ) 
 
 ¦¦ (RightDiag.cw_quadrant == THIRD_QUADRANT) 
 
 ) 
 
 { 
 
 if (( (RightDiag.ccw_quadrant == FOURTH_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= RightDiag.ccw_slope) // less than here means more negative 
 
 ) 
 
 
 ¦¦ ( RightDiag.ccw_quadrant == FIRST_QUADRANT) 
 
 ) 
 
 { 
 
 in_right_diag = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 } 
// if quadrant 
 
else 
// (index_x < current_x) index_quadrant = THIRD_QUADRANT; 
 
 { 
// slopes in this quadrant are positive. neg x/ neg y 
 
 if (( (Fov.cw_quadrant == THIRD_QUADRANT) 
// both same quadrant 
 
 && (IndexCurrentSlope >= Fov.cw_slope) 
// proper relationship 
 
 ) 
 
 ¦¦ ( Fov.cw_quadrant == SECOND_QUADRANT) 
 
 ) 
 
 { 
 
 if (( (Fov.ccw_quadrant == THIRD_QUADRANT) 
// both same quadrant 
 
 && (IndexCurrentSlope <= Fov.ccw_slope) 
// proper relationship 
 
 ) 
 
 ¦¦ (Fov.ccw_quadrant == FOURTH_QUADRANT) 
 
 ) 
 
 { 
 
 in_front_fov = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 // see if in left diag yaw range 
 
if (( (LeftDiag.cw_quadrant == THIRD_QUADRANT) 
// both same quadrant 
 
 && (IndexCurrentSlope >= LeftDiag.cw_slope) // proper relationship 
 
 ) 
 
 ¦¦ ( LeftDiag.cw_quadrant == SECOND_QUADRANT) 
 
 ) 
 
 { 
 
 if (( (LeftDiag.ccw_quadrant == THIRD_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= LeftDiag.ccw_slope) // proper relationship 
 
 ) 
 
 ¦¦ (LeftDiag.ccw_quadrant == FOURTH_QUADRANT) 
 
 ) 
 
 { 
 
 in_left_diag = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 // see if in right diag yaw range 
 
 if (( (RightDiag.cw_quadrant == THIRD_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >= RightDiag.cw_slope) // proper relationship 
 
 ) 
 
 ¦¦ ( RightDiag.cw_quadrant == SECOND_QUADRANT) 
 
 ) 
 
 { 
 
 if (( (RightDiag.ccw_quadrant == THIRD_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= RightDiag.ccw_slope) // proper relationship 
 
 ) 
 
 ¦¦ (RightDiag.ccw_quadrant == FOURTH_QUADRANT) 
 
 ) 
 
 { 
 
 in_right_diag = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 } 
// else quadrant 
 
 } 
 
Calculate weighted distance rating, based on the neighbor radius set by the operator, which defines the  
 
optimal distance to jump forward or backward from the current frame. (FIG. 34. step 11660) 
 
 WeightedRadiusDistanceRating = (float)(fabs(NeighborRadiusSquared − DistanceSquared) *  
 
 DistanceGain); 
 
Test index point to see if it is better than the current candidate for the jump forward or jump backward  
 
selection. (FIG. 32, step 11495) 
 
 if (!same_location) 
// indexed and current points are not at same x,y 
 
 { 
 
 FovIndexRating = CurrentIndexYawAbsDiff + WeightedRadiusDistanceRating; 
 
 // find ‘green dot’, jump forward point and find which pts are in forward 
 
 // field of view subset 
 
 if (in_front_fov) 
// if in field of view 
 
 { 
 
 // put this subset_index point in further subset of points in field of view 
 
 *(m_pFovSubsetIndex + fov_subset_index) = *(m_pZoomSubsetIndex + subset_index); 
 
 fov_subset_index++; 
// increment after using, get ready for loop 
 
 m_FovSubsetIndexMax++; 
// equal to highest index in this fov subset 
 
 if (m_FovPtClosestInYaw == NO_FRAMES) 
// if we don't have a current champion 
 
 { 
// add criterion of keeping inside twice the neighborhood radius 
 
 if ((MultipliedNeighborRadiusSquared >= DistanceSquared) // in the double hood 
 
 // Use this point only if it is not too different from current point's heading 
 
 // Note the first champ is closer to the current angle difference than max limit 
 
 && (CurrentIndexYawAbsDiff < m_MaxHeadingAngle) 
 
 ) 
 
 { 
 
 m_FovPtClosestInYaw = subset_index; 
 
 FwdSmallestDisplayRating = FovindexRating; 
// save for next candidate  
 
 
 comparison 
 
 } 
 
 } 
 
 else 
// have a valid champ 
 
 { 
 
 // if this fov pt has smaller total rating than defending champ 
 
 if ((FwdSmallestDisplayRating > FovIndexRating) 
 
 // add criterion of keeping inside twice the neighborhood radius 
 
 && (MultipliedNeighborRadiusSquared >= DistanceSquared) // in the hood 
 
 // Use this point only if it is not too different from current point's heading 
 
 // Note the first champ is closer to the current angle difference than max limit 
 
 && (CurrentIndexYawAbsDiff < m_MaxHeadingAngle) 
 
 ) 
 
 { 
 
 m_FovPtClosestInYaw = subset_index; 
// save for next candidate  
 
 
 comparison 
 
 FwdSmallestDisplayRating = FovIndexRating; 
 
 } 
// end if new champ beats old champ 
 
 } 
// end else have a valid champ 
 
 } 
// end jump forward point 
 
 else 
// not in front fov 
 
 { 
 
 // So, is the indexed point within the REAR field of view of current point? 
 
 // Is it between the reverse cw and ccw slope limits? If so, then in rear fov 
 
 // Note. Here x,y are data x,y, not display pixel x,y. First quadrant is pos x  
 
 and pos y. 
 
 if ( index_y >= current_y) 
 
 { 
 
 if (index_x >= current_x) 
// index_quadrant = FIRST_QUADRANT; 
 
 { 
 
 if (( (Fov.rear_cw_quadrant == FIRST_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope >= Fov.cw_slope) 
// proper relationship 
 
 ) 
 
 ¦¦ ( Fov.rear_cw_quadrant == FOURTH_QUADRANT) // (−IndexCurrentSlope >=  
 
 rear_cw_slope) is automatic here 
 
 ) 
 
 { 
 
 if (( (Fov.rear_ccw_quadrant == FIRST_QUADRANT) // both same quadrant 
 
 && (IndexCurrentSlope <= Fov.ccw_slope) 
// proper  
 
 
 relationship 
 
 ) 
 
 ¦¦ (Fov.rear_ccw_quadrant == SECOND_QUADRANT) //  
 
 (−IndexCurrentSlope <= 
 
rear_ccw_slope) is automatic here 
 
 ) 
 
 { 
 
 in_rear_fov = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 } 
// if quadrant 
 
 else 
// (index_x < current_x) index_quadrant =  
 
 
 SECOND_QUADRANT: 
 
 { 
 
 if (( (Fov.rear_cw_quadrant == SECOND_QUADRANT) // both same  
 
 quadrant 
 
 && (IndexCurrentSlope >= Fov.cw_slope) 
// proper relationship 
 
 ) 
 
 ¦¦ ( Fov.rear_cw_quadrant == FIRST QUADRANT) // must be ok so far 
 
 ) 
 
 { 
 
 if (( (Fov.rear_ccw_quadrant == SECOND_QUADRANT) // both same  
 
 quadrant 
 
 && (IndexCurrentSlope <= Fov.ccw_slope) 
// proper  
 
 
 relationship 
 
 ) 
 
 ¦¦ (Fov.rear_ccw_quadrant == THIRD_QUADRANT) // must be ok 
 
 ) 
 
 { 
 
 in_rear_fov = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 } 
// else quadrant 
 
 } 
 
 else  
// (index_y < current_y) 
 
 { 
 
 if (index_x >= current_x) 
// index_quadrant = FOURTH_QUADRANT; 
 
 { 
 
 if (( (Fov.rear_cw_quadrant == FOURTH_QUADRANT) // both same  
 
 quadrant 
 
 && (IndexCurrentSlope >= Fov.cw_slope) 
// proper relationship 
 
 ) 
 
 ¦¦ (Fov.rear_cw_quadrant == THIRD_QUADRANT) 
 
 ) 
 
 { 
 
 if (( (Fov.rear_ccw_quadrant == FOURTH_QUADRANT) // both same  
 
 quadrant 
 
 && (IndexCurrentSlope <= Fov.ccw_slope) 
// proper relationship 
 
 ) 
 
 ¦¦ ( Fov.rear_ccw_quadrant == FIRST_QUADRANT) 
 
 ) 
 
 { 
 
 in_rear_fov = TRUE; 
 
 } 
// ccw 
 
 } 
// cw 
 
 } 
// if quadrant 
 
 else 
// (index_x < current_x) index_quadrant =  
 
 
 THIRD_QUADRANT; 
 
 { 
 
 if (( (Fov.rear_cw_quadrant == THIRD_QUADRANT) // both same  
 
 quadrant 
 
 && (IndexCurrentSlope >= Fov.cw_slope) 
// proper relationship 
 
 ) 
 
 ¦¦ ( Fov.rear_cw_quadrant == SECOND_QUADRANT) 
 
 ) 
 
 { 
 
 if (( (Fov.rear_ccw_quadrant == THIRD_QUADRANT) // both same  
 
 quadrant 
 
 && (IndexCurrentSlope <= Fov.ccw_slope) 
// proper relationship 
 
 ) 
 
 ¦¦ (Fov.rear_ccw_quadrant == FOURTH_QUADRANT) 
 
 ) 
 
 { 
 
 in_rear_fov = TRUE; 
 
 { 
// ccw 
 
 } 
// cw 
 
 } 
// else quadrant 
 
 } 
 
 // see if have new champion, find rear fov pt most aligned in yaw to current  
 
 frame 
 
 if (in_rear_fov) 
// if in rear view field of view 
 
 { 
 
 if (m_RearFovPtClosestInYaw == NO_FRAMES) 
// if we don't have a current  
 
 
 champion 
 
 { 
// add criterion of keeping inside twice the neighborhood radius 
 
 if ((MultipliedNeighborRadiusSquared >= DistanceSquared) 
// in the double  
 
 
 hood 
 
 // Use this point only if it is not too different from current point's heading 
 
 // Note the first champ is closer to the current angle difference than max limit 
 
 && (CurrentIndexYawAbsDiff < m_MaxHeadingAngle) 
 
 ) 
 
 { 
 
 m_RearFovPtClosestInYaw = subset_index: 
 
 RearSmallestDisplayRating = FovIndexRating; 
// save for next candidate  
 
 
 comparison 
 
 } 
 
 } 
 
 else // have a valid champ 
 
 { 
 
 // if this rear fov pt has smaller total rating than defending champ 
 
 if ((RearSmallestDisplayRating > FovIndexRating) 
 
 // add criterion of keeping inside twice the neighborhood radius 
 
 && (MultipliedNeighborRadiusSquared >= DistanceSquared) 
// in the hood 
 
 // Use this point only if it is not too different from current point's heading 
 
 // Note the first champ is closer to the current angle difference than max  
 
 limit 
 
 && (CurrentIndexYawAbsDiff < m_MaxHeadingAngle) 
 
 ) 
 
 { 
 
 m_RearFovPtClosestInYaw = subset_index: 
 
 RearSmallestDisplayRating = FovindexRating; 
// save for next candidate  
 
 
 comparison 
 
 } 
// end if new champ beats old champ 
 
 } 
// end else have a valid champ 
 
 } 
// end if in rear fov 
 
 } 
// end else not in front fov 
 
 } 
// end if not same location 
 
 if m_FovPtClosestInYaw == current_frame) 
// s/b impossible but ... 
 
 { 
 
 AfxMessageBox(“Tla_File::select_field_of_view( ) m_FovPtClosestInYaw ==  
 
 current_frame”); 
 
 } 
 
 if (m_RearFovPtClosestInYaw == current_frame) 
// s/b impossible but ... 
 
 { 
 
 AfxMessageBox(“Tla_File::select_field_of view( ) m_RearFovPtClose_stInYaw ==  
 
 current_frame”); 
 
 } 
 
 Test index point to see if it is better than the current candidate for the jump and turn right or jump  
 
 and turn left selection. (FIG. 32, step 11495) 
 
 // looking for side frame candidates 
 
 if ((NeighborRadiusSquared >= DistanceSquared) 
// in the hood 
 
 && (!same_location) 
// and indexed and current points do not have identical  
 
 
 x,y location 
 
 ) 
 
 { 
 
 // the trig is there to forgive offset if the side frame is pointing in line  
 
 w/ the offset vector 
 
 // 
running from the current center point to the side frame. This is  
 
 
 because offsets are less 
 
 // 
noticeable if there are in the direction in which you are looking.  
 
 
 Move your head forward 
 
 // 
and back like a pigeon. Some movement of objects but not as  
 
 
 much as when you move 
 
 // 
your head left and right. Don't want to forgive completely so put  
 
 
 in a minimum. 
 
 AdjIndexCurrentDistanceRating 
 
 = (float)((fabs(xCurrentMinusIndex * (fabs_quick_cos(IndexPointYaw) + 0.2)) 
 
 + fabs(yCurrentMinusIndex *  
 
 (fabs_quick_sin(IndexPointYaw) + 0.2)) 
 
 ) 
 
 * DistanceGain 
 
 ); 
 
 // do left displayed frame 
 
 if (IndexYawToLeftOfCurrentYaw == TRUE) 
 
 { 
 
 DisplayYawAbsDiff = (float)(fabs(LeftFovPtYaw − IndexPointYaw)); 
 
 // Cant be further apart than 180 
 
 if (DisplayYawAbsDiff >= 360) 
 
 { 
 
 DisplayYawAbsDiff −= 360; 
 
 } 
 
 else if (DisplayYawAbsDiff >= 180) 
 
 { 
 
 DisplayYawAbsDiff = 360 − DisplayYawAbsDiff; 
 
 } 
 
 // within neighborhood, within constrained subset  
 
 m_MaxHeadingAngle 
 
 // if this pt is closer in yaw and in distance to goal than defending  
 
 champ 
 
 LeftIndexRating = DisplayYawAbsDiff + AdjIndexCurrentDistanceRating; 
 
 if (LeftSmallestDisplayRating > LeftIndexRating) 
 
 { 
 
 // if is actually pointing to the correct side but  
 
 not too far out 
 
 if (Left2FovPtYaw <= 180) 
// nothing weird 
 
 { 
 
 if ((IndexPointYaw > CurrentPointYaw) 
 
 && (Left2FovPtYaw >= IndexPointYaw) 
 
 ) 
 
 { 
 
 // convert from subset index to frame 
 
 m_PtLeftFOV 
= frame_index; 
 
 LeftSmallestDisplayRating 
= LeftIndexRating;// save it as  
 
 
 benchmark 
 
 } 
 
 } 
 
 else 
// weird range split by +/− 180 line 
 
 { 
 
 if ((IndexPointYaw > CurrentPointYaw) 
 
 ¦¦ (Left2FovPtYaw >= IndexPointYaw + 360) 
 
 ) 
 
 { 
 
 // convert from subset index to frame 
 
 m_PtLeftFOV 
= frame_index: 
 
 LeftSmallestDisplayRating 
= LeftIndexRating;// save it as  
 
 
 benchmark 
 
 } 
 
 } 
 
 } 
 
Test index point to see if it is better than the current candidate for turn left turn or right turn selection.  
 
(FIG. 32, step 11495) 
 
 // now choose the left turn frame 
 
 TurnYawAbsDiff = (float)(fabs(LeftTurnPtYaw − IndexPointYaw)); 
 
 // Cant be further apart than 180 
 
 if (TurnYawAbsDiff >= 360) 
 
 { 
 
 TurnYawAbsDiff −= 360; 
 
 } 
 
 else if (TurnYawAbsDiff >= 180) 
 
 { 
 
 TurnYawAbsDiff = 360 − TurnYawAbsDiff; 
 
 } 
 
 // within neighborhood, within constrained subset  
 
 m_MaxHeadingAngle 
 
 // if this pt is closer in yaw and in distance to goal than  
 
 defending champ 
 
 LeftIndexRating = TurnYawAbsDiff + AdjIndexCurrentDistanceRating; 
 
 if (LeftSmallestTurnRating > LeftIndexRating) 
 
 { 
 
 // if is actually pointing to the correct side  
 
 but not too far out 
 
 if (Left2FovPtYaw <= 180) 
// nothing weird 
 
 { 
 
 if ((IndexPointYaw > CurrentPointYaw) 
 
 && (Left2FovPtYaw >= IndexPointYaw) 
 
 ) 
 
 { 
 
 // convert from subset index to frame 
 
 m_PtLeftTurn 
= frame_index; 
 
 LeftSmallestTurnRating 
= LeftIndexRating;// save it as  
 
 
 benchmark 
 
 } 
 
 } 
 
 else 
// weird range split by +/− 180 line 
 
 { 
 
 if ((IndexPointYaw > CurrentPointYaw) 
 
 ¦¦ (Left2FovPtYaw >= IndexPointYaw + 360) 
 
 ) 
 
 { 
 
 // convert from subset index to frame 
 
 m_PtLeftTurn 
= frame_index; 
 
 LeftSmallestTurnRating 
= LeftIndexRating;// save it as  
 
 
 benchmark 
 
 } 
 
 } 
 
 } 
 
 } 
// end if IndexYawToLeftOfCurrentYaw 
 
 else 
// on index yaw is to the right of the current yaw 
 
 { 
 
 // do right displayed frame 
 
 DisplayYawAbsDiff = (float)(fabs(RightFovPtYaw − IndexPointYaw)); 
 
 // Cant be further apart than 180 
 
 if (DisplayYawAbsDiff >= 360) 
 
 { 
 
 DisplayYawAbsDiff −= 360; 
 
 } 
 
 else if (DisplayYawAbsDiff >= 180) 
 
 { 
 
 DisplayYawAbsDiff = 360 − DisplayYawAbsDiff; 
 
 } 
 
 // within neighborhood, within constrained subset  
 
 m_MaxHeadingAngle 
 
 // if this pt is closer in yaw and in distance to goal than  
 
 defending champ 
 
 RightIndexRating = DisplayYawAbsDiff + AdjIndexCurrentDistanceRating; 
 
 if (RightSmallestDisplayRating > RightIndexRating) 
 
 { 
 
 // if is actually pointing to the correct side but  
 
 not too far out 
 
 if (Right2FovPtYaw >= −180) 
// nothing weird 
 
 { 
 
 if ((IndexPointYaw < CurrentPointYaw) 
 
 && (Right2FovPtYaw <= IndexPointYaw) 
 
 ) 
 
 { 
 
 // convert from subset index to frame 
 
 m_PtRightFOV 
= frame_index; 
 
 RightSmallestDisplayRating 
= RightIndexRating;// save it as  
 
 
 benchmark 
 
 } 
 
 } 
 
 else 
// weird range split by +/− 180 line 
 
 { 
 
 if ((IndexPointYaw < CurrentPointYaw) 
 
 ¦¦ (Right2FovPtYaw <= IndexPointYaw − 360) 
 
 ) 
 
 { 
 
 // convert from subset index to frame 
 
 m_PtRightFOV 
= frame_index; 
 
 RightSmallestDisplayRating 
= RightIndexRating;// save it as  
 
 
 benchmark 
 
 } 
 
 } 
 
 } // end if m_PtRightFOV 
 
 // now choose the right turn frame 
 
 TurnYawAbsDiff = (float)(fabs(RightTurnPtYaw − IndexPointYaw)); 
 
 // Cant be further apart than 180 
 
 if (TurnYawAbsDiff >= 360) 
 
 { 
 
 TurnYawAbsDiff −= 360; 
 
 } 
 
 else if (TurnYawAbsDiff >= 180) 
 
 { 
 
 TurnYawAbsDiff = 360 − TurnYawAbsDiff; 
 
 } 
 
 // within neighborhood, within constrained subset 
 
 // if this pt is closer in yaw and in distance to goal than  
 
 defending champ 
 
 RightIndexRating = TurnYawAbsDiff + AdjIndexCurrentDistanceRating; 
 
 if (RightSmallestTurnRating > RightIndexRating) 
 
 { 
 
 // if is actually pointing to the correct side but  
 
 not too far out 
 
 if (Right2FovPtYaw >= −180) 
// nothing weird 
 
 { 
 
 if ((IndexPointYaw < CurrentPointYaw) 
 
 && (Right2FovPtYaw <= IndexPointYaw) 
 
 ) 
 
 { 
 
 // convert from subset index to frame 
 
 m_PtRightTurn 
= frame_index; 
 
 RightSmallestTurnRating 
= RightIndexRating;// save it as  
 
 
 benchmark 
 
 } 
 
 } 
 
 else 
// weird range split by +/− 180 line 
 
 { 
 
 if ((IndexPointYaw < CurrentPointYaw) 
 
 ¦¦ (Right2FovPtYaw <= IndexPointYaw − 360) 
 
 ) 
 
 { 
 
 // convert from subset index to frame 
 
 m_PtRightTurn 
= frame_index; 
 
 RightSmallestTurnRating 
= RightIndexRating;// save it as  
 
 
 benchmark 
 
 } 
 
 } 
 
 } 
// end if m_PtRightTurn 
 
 } 
// end if not IndexYawToLeftOfCurrentYaw 
 
 } 
// end if within neighborhood radius 
 
Test index point to see if it is better than the current candidate for turn left frame or right frame display in  
 
Triple Mci display mode. (FIG. 32, step 11495) 
 
 if (in_left_diag) 
// if in range 
 
 { 
 
 // now choose the left diag frame 
 
 TurnYawAbsDiff = (float)(fabs(LeftTurnPtYaw − IndexPointYaw)); 
 
 // Cant be further apart than 180 
 
 if (TurnYawAbsDiff >= 360) 
 
 { 
 
 TurnYawAbsDiff −= 360; 
 
 } 
 
 else if (TurnYawAbsDiff >= 180) 
 
 { 
 
 TurnYawAbsDiff = 360 − TurnYawAbsDiff; 
 
 } 
 
 LeftIndexRating = TurnYawAbsDiff + WeightedRadiusDistanceRating; 
 
 if ((m_PtLeftDiag == NO_FRAMES) 
// if we don't have a current champion 
 
 // or if this pt is closer in yaw and in distance to goal than defending champ 
 
 ¦¦ (LeftSmallestDiagRating > LeftIndexRating) 
 
 ) 
 
 { 
 
 // the absolute standards 
 
 if ((MultipliedNeighborRadiusSquared >= DistanceSquared) // in the double  
 
 hood 
 
 // Use this point only if it is not too different from turn point's heading 
 
 // Note the first champ is closer to the current angle difference than max  
 
 limit 
 
 && (TurnYawAbsDiff < m_MaxHeadingAngle) 
 
 ) 
 
 { 
 
 // convert from subset index to frame 
 
 m_PtLeftDiag 
= frame_index; 
 
 LeftSmallestDiagRating 
= LeftIndexRating; // save it as benchmark 
 
 } 
 
 } 
 
 } 
// end if in diag range 
 
 if (in_right_diag) 
// if in range 
 
 { 
 
 // now choose the left diag frame 
 
 TurnYawAbsDiff = (float)(fabs(RightTurnPtYaw − IndexPointYaw)); 
 
 // Cant be further apart than 180 
 
 if (TurnYawAbsDiff >= 360) 
 
 { 
 
 TurnYawAbsDiff −= 360; 
 
 } 
 
 else if (TurnYawAbsDiff >= 180) 
 
 { 
 
 TurnYawAbsDiff = 360 −TurnYawAbsDiff; 
 
 } 
 
 RightIndexRating = TurnYawAbsDiff + WeightedRadiusDistanceRating; 
 
 if ((m_PtRightDiag == NO_FRAMES) 
// if we don't have a current champion 
 
 // or if this pt is closer in yaw and in distance to goal than defending champ 
 
 ¦¦ (RightSmallestDiagRating > RightIndexRating) 
 
 ) 
 
 { 
 
 // the absolute standards 
 
 if ((MultipliedNeighborRadiusSquared >= DistanceSquared) 
// in the double  
 
 
 hood 
 
 // Use this point only if it is not too different from turn point's heading 
 
 // Note the first champ is closer to the current angle difference than max  
 
 limit 
 
 && (TurnYawAbsDiff < m_MaxHeadingAngle) 
 
 ) 
 
 { 
 
 // convert from subset index to frame 
 
 m_PtRightDiag 
= frame_index; 
 
 RightSmallestDiagRating = RightIndexRating; // save it as benchmark 
 
 } 
 
 } 
 
 } 
// end if in diag range 
 
 } 
// end for 
 
 if (m_PtLeftFOV == NO_FRAMES) 
 
 { 
 
 AfxMessageBox(“Tla_File::select_field_of_view( ) m_PtLeftFOV ==  
 
 NO_FRAMES”); 
 
 } 
 
 if (m_PtRightFOV == NO_FRAMES) 
 
 { 
 
 AfxMessageBox(“Tla_File::select_field_of_view( ) m_PtRightFOV ==  
 
 NO_FRAMES”); 
 
 } 
 
 if (m_FovPtClosestInYaw != NO_FRAMES) 
// if picked a point 
 
 { 
 
 if (get_frame_from_zoom_subset(m_FovPtClosestInYaw) ==  
// s/b impossible  
 
 current_frame) 
but ... 
 
 { 
 
 AfxMessageBox(“Tla_File::select_field_of_view( ) m_FovPtClosestInYaw ==  
 
 current_frame”); 
 
 } 
 
 } 
 
 } 
// end if not m_zoom_subset_index_max 
 
 return: 
 
} 
 
 The overlay window relates points and areas in the geometric space defined by the  
 
camera's movements to points and areas within a particular video frame. Geometric points and areas  
 
within the geometric space are projected to the camera's image plane using the following formula (In this  
 
code fragment the calculation is done for a Tombstone type overlay, but the calculation is the same for  
 
any overlay object.): 
 
 First, get the difference between the camera frame's x position and the overlay  
 
 object's's x position. (FIG. 35, step 11710) 
 
 numerator = −(m_pDoc—>m_mta_file.m_Tombstone[index].XCtr 
 
 − m_pDoc—>m_tla_file.get_x_data(ThisWndsFrame) 
 
 ); 
 
Next, get the difference between the camera frame's y position and the overlay object's y position. (FIG.  
 
35, step 11720) 
 
 denominator = (m_pDoc—>m_mta_file.m Tombstone[index].YCtr 
 
 − m_pDoc—>m_tla_file.get_y_data(ThisWndsFrame) 
 
 ); 
 
Calculate yaw angle of the line from the current frame's center to the point of interest. (FIG. 35, step  
 
11730) 
 
 // calc angle of line from current point to this active tombstone 
 
 if (denominator != 0) 
// don't divide by zero 
 
 { 
 
 yawFrameToOverlay = (float)(RAD_TO_DEG * atan2(numerator, denominator)); 
 
 } 
 
 else  
// denom is zero 
 
 { 
 
 // make ratio of num/denom big via a small denominator but avoid div by zero 
 
 yawFrameToOverlay = (float)(RAD_TO_DEG * atan2(numerator,  
 
 SMALL_ARBITRARY_FLOAT)): 
 
 } 
 
 Test to see if the yaw value for the angle to the point to be displayed is within the field of view of the  
 
 current frame. (FIG. 35. step 11740) 
 
 // if in limits, calc differential yaw, scale and display bar 
 
 if (((YawLimits == NORMAL_LIMITS) 
 
 && ((yawFrameToOverlay >= yawMinFov) && (yawFrameToOverlay <= yawMaxFov))  
 
 
 // note && 
 
 ) 
 
 ¦¦ ((YawLimits == WRAPPED_ LIMITS) 
 
 && ((yawFrameToOverlay >= yawMinFov) ¦¦ (yawFrameToOverlay <=  
// note ¦¦ 
 
 yawMaxFov)) 
 
 
 ) 
 
 ) 
 
 { 
 
If it is within the limits, calculate the offset from the middle pixel to the vertical line of pixels  
 
corresponding to the object's yaw angle relative to the current frame's yaw angle. (FIG. 35, step 11748) 
 
 xPixel = (int)(xMidPixel + (xScale * tan(DEG_TO_RAD * (yawCurrentPt −  
 
 yawFrameToOverlay)))); 
 
Finally, the pitch of the current frame is used to choose a point on the vertical line determined above. The  
 
calculation for CalcOverlayMarkers is described below. (FIG. 35, step 11750) 
 
 pitchFrameToOverlay = 
 
 CalcOverlayMarkers(&MarkerHalfWidth, 
 
 &MarkerHalfHeight, 
 
 m_pDoc—>m_mta_file.m_Tombstone[index].XCtr, 
 
 m_pDoc—>m_mta_file.m_Tombstone[index].YCtr, 
 
 ThisWndsFrame 
 
 ); 
 
This program segment calculates the point on the vertical line determined by yaw angle from the current  
 
frame's centerline at which to project an x,y coordinate onto the current video frame. It presumes that the  
 
photographed space is planar and is not inclined with respect to the gravitational normal. It uses a  
 
CameraHeight setting, adjustable by the operator via the Action-Adjust Parameters dialog Camera Height  
 
Above Floor entry 10316 (FIG. 21). 
 
// calculate angle between horizon and line from camera (at m_pDoc—>m_tla_flle.m_CameraHeight off  
 
flat floor) 
 
// to a particular overlay marker. Flat floor assumes z doesn't change too much. 
 
float CMciWnd::CalcOverlayMarkers(int *pHalfWidth, int *pHalfHeight, int xCtrZone, int yCtrZone, 
 
 unsigned short ThisWndsFrame) 
 
{ 
 
 float AngleHorizonToMarkerOnFloor; 
 
 double XYDistance; 
 
 // d = x{circumflex over ( )}2 + y{circumflex over ( )}2 
 
 XYDistance = ( xCtrZone − (double)(m_pDoc—>m_tla_flle.get_x_data(ThisWndsFrame))) 
 
 *( xCtrZone − (double)(m_pDoc—>m_tla_file.get_x_data(ThisWndsFrame))) + 
 
  ( yCtrZone − (double)(m_pDoc—>m_tla_file.get_y_data(ThisWndsFrame))) 
 
 *( yCtrZone − (double)(m_pDoc—>m_tla_file.get_y_data(ThisWndsFrame))); 
 
 if (XYDistance <= 0) 
 
 { 
 
 TRACE(“CMciWnd::CalcOverlayMarkers, bad XYDistance after sqrt( )/n”); 
 
 AfxMessageBox(“CMciWnd::CalcOverlayMarkers, bad XYDistance before sqrt( )/n”); 
 
 return 0; 
 
 } 
 
 else if (XYDistance == 0) 
 
 { 
 
 XYDistance = (double)SMALL_ARBITRARY_FLOAT; 
// let's not divide by zero. 
 
 } 
 
 else 
 
 { 
 
 // take square root 
 
 XYDistance = sqrt(XYDistance); 
 
 } 
 
 // for this part of calc, ignore pitch of camera, assume level 
 
 // calc angle between horizon and line from camera to center of dropped avi 
 
 AngleHorizonToMarkerOnFloor = 
 
 (float)(RAD_TO_DEG * atan2(m_pDoc—>m_tla_file.m_CameraHeight,  
 
 XYDistance)); 
 
 float SizeAdj = (float)(10 * m_pDoc—>m_tla_flle.m_CameraHeight / XYDistance); 
 
 *pHalfWidth = (int)(MAX_MARKER_WIDTH * SizeAdj); 
 
 *pHalfHeight = (int)(MAX_MARKER_HEIGHT * SizeAdj); 
 
 if (*pHalfWidth < MIN_MARKER_WIDTH) 
 
 { 
 
 *pHalfWidth = MIN_MARKER_WIDTH; 
 
 } 
 
 else if (*pHalfWidth > MAX_MARKER_WIDTH) 
 
 { 
 
 *pHalfWidth = MAX_MARKER_WIDTH; 
 
 } 
 
 if (*pHalfHeight < MIN_MARKER_HEIGHT) 
 
 { 
 
 *pHalfHeight = MIN_MARKER_HEIGHT; 
 
 } 
 
 else if (*pHalfHeight > MAX_MARKER_HEIGHT) 
 
 { 
 
 *pHalfHeight = MAX_MARKER_HEIGHT; 
 
 } 
 
 return AngleHorizonToMarkerOnFloor: 
 
} 
 
 
While the preferred embodiment of the invention has been described, it will be understood that numerous modifications and changes will occur to those skilled in the art. It is therefore intended by the appended claims to define the true scope of the invention.
| Patent | Priority | Assignee | Title | 
| 10217283, | Dec 17 2015 | GOOGLE LLC | Navigation through multidimensional images spaces | 
| 10600245, | May 28 2014 | Lucasfilm Entertainment Company Ltd | Navigating a virtual environment of a media content item | 
| 10602200, | May 28 2014 | Lucasfilm Entertainment Company Ltd. | Switching modes of a media content item | 
| 10943396, | Sep 30 2016 | Amazon Technologies, Inc | Synchronizing transmitted video data and enhancements | 
| 10950049, | Sep 30 2016 | Amazon Technologies, Inc | Augmenting transmitted video data | 
| 11103787, | Jun 24 2010 | System and method for generating a synthetic video stream | |
| 11295525, | Sep 30 2016 | Amazon Technologies, Inc. | Augmenting transmitted video data | 
| 11508125, | May 28 2014 | Lucasfilm Entertainment Company Ltd. | Navigating a virtual environment of a media content item | 
| 11645757, | Feb 08 2018 | FUGRO N V | Method of and apparatus for analyzing images | 
| 11670051, | Sep 30 2016 | Amazon Technologies, Inc. | Augmenting transmitted video data | 
| 11802968, | May 31 2017 | WOVEN BY TOYOTA, U S , INC | System of vehicles equipped with imaging equipment for high-definition near real-time map generation | 
| 11879977, | May 31 2017 | WOVEN BY TOYOTA, U S , INC | System of vehicles equipped with imaging equipment for high-definition near real-time map generation | 
| 8989434, | Apr 05 2010 | GOOGLE LLC | Interactive geo-referenced source imagery viewing system and method | 
| 9025810, | Apr 05 2010 | GOOGLE LLC | Interactive geo-referenced source imagery viewing system and method | 
| 9589078, | Sep 24 2012 | FUTUREWEI TECHNOLOGIES, INC | Constructing three dimensional model using user equipment | 
| 9990750, | Apr 05 2010 | GOOGLE LLC | Interactive geo-referenced source imagery viewing system and method | 
| Patent | Priority | Assignee | Title | 
| 3363332, | |||
| 3580996, | |||
| 4023202, | Dec 24 1975 | The United States of America as represented by the Secretary of the Navy | Television tracking symbol generator | 
| 4084184, | Jul 26 1976 | TV Object locator and image identifier | |
| 4169666, | Jan 23 1978 | Magicam, Inc. | Foreground stabilization system for use in composite photography | 
| 4179823, | Jan 13 1978 | Hughes Aircraft Company | Real-time simulation of a polygon face object system as viewed by a moving observer | 
| 4283766, | Sep 24 1979 | Walt Disney Productions | Automatic camera control for creating special effects in motion picture photography | 
| 4343037, | Jun 15 1979 | Redifon Simulation Limited | Visual display systems of the computer generated image type | 
| 4373169, | Oct 30 1979 | The Boeing Company | Multi-window visual display system for flight simulators | 
| 4449198, | Nov 21 1979 | U S Philips Corporation | Device for interactive video playback | 
| 4463380, | Sep 25 1981 | Lockheed Martin Corp | Image processing system | 
| 4484192, | Dec 17 1981 | Allied Corporation | Moving map display | 
| 4486775, | Oct 17 1980 | QUANTEL LIMITED, 37 VICTORIA AVENUE, SOUTHEND ON SEA, ESSEX | Object recognition | 
| 4488249, | |||
| 4495580, | Mar 30 1981 | E-Systems, Inc. | Navigation system | 
| 4561063, | Feb 09 1982 | Barr & Stroud Limited | Apparatus for identifying the position of a body | 
| 4628453, | Oct 17 1983 | Hitachi, Ltd. | Navigation apparatus for mobile system | 
| 4645459, | Jul 30 1982 | THESEUS RESEARCH, INC | Computer generated synthesized imagery | 
| 4682160, | Jul 25 1983 | Harris Corporation | Real time perspective display employing digital map generator | 
| 4687326, | Nov 12 1985 | General Electric Company | Integrated range and luminance camera | 
| 4737921, | Jun 03 1985 | PICKER INTERNATIONAL, INC | Three dimensional medical image display system | 
| 4751507, | Jul 23 1984 | International Business Machines Corporation | Method for simultaneously displaying an image and an enlarged view of a selectable portion of the image with different levels of dot detail resolution | 
| 4752836, | Sep 07 1984 | WOLFENSOHN ASSOCIATES, L P | Method and apparatus for reproducing video images to simulate movement within a multi-dimensional space | 
| 4766541, | Oct 24 1984 | Williams Electronics Games, Inc. | Apparatus for generating interactive video game playfield environments | 
| 4791572, | Nov 20 1985 | METS, INC | Method for accurately displaying positional information on a map | 
| 4807158, | Sep 30 1986 | IVEX CORPORATION, 4357 J PARK DRIVE, NORCROSS, GA 30093, A DE CORP | Method and apparatus for sampling images to simulate movement within a multidimensional space | 
| 4829304, | May 20 1986 | Harris Corporation | Map-aided navigation system employing TERCOM-SITAN signal processing | 
| 4855820, | Oct 05 1987 | Down hole video tool apparatus and method for visual well bore recording | |
| 4855822, | Jan 26 1988 | Honeywell, Inc. | Human engineered remote driving system | 
| 4857902, | May 14 1987 | ADVANCED INTERACTION, INC , A CORP OF TEXAS | Position-dependent interactivity system for image display | 
| 4876651, | May 11 1988 | Honeywell INC | Digital map system | 
| 4891761, | Mar 31 1988 | Mets, Inc. | Method for accurately updating positional information provided on a digital map | 
| 4910674, | Jul 21 1984 | MBB GmbH | Navigation of aircraft by correlation | 
| 4939662, | Oct 07 1987 | Aisin AW Co., Ltd.; Kabushiki Kaisha Shinsangyokai Hatsu | Navigation apparatus | 
| 4939663, | Apr 04 1988 | Harris Corporation | Elevation map-referenced mechanism for updating vehicle navigation system estimates | 
| 4969036, | Mar 31 1989 | HONEYWELL INC , HONEYWELL PLAZA, MINNEAPOLIS, MN 55408, A CORP OF DE | System for computing the self-motion of moving images devices | 
| 4972319, | Sep 25 1987 | Electronic global map generating system | |
| 4984179, | Jan 21 1987 | Intel Corporation | Method and apparatus for the perception of computer-generated imagery | 
| 4989151, | Feb 23 1988 | Kabushiki Kaisha Toshiba | Navigation apparatus and matching method for navigation | 
| 4992866, | Jun 29 1989 | ABICON, INC | Camera selection and positioning system and method | 
| 4994971, | Dec 06 1985 | TELE ATLAS INTERNATIONAL B V | System for setting up and keeping up-to-date datafiles for road traffic | 
| 5016007, | Apr 19 1985 | Honda Giken Kogyo Kabushiki Kaisha | Apparatus for displaying travel path | 
| 5023725, | Oct 23 1989 | IMMERSIVE LICENSING, INC | Method and apparatus for dodecahedral imaging system | 
| 5023798, | Jun 06 1987 | Robert Bosch GmbH | Method of and apparatus for determining a position of a land vehicle | 
| 5049988, | Aug 10 1989 | Radiodetection Limited | Scanning T.V. camera | 
| 5060162, | Dec 09 1988 | Matsushita Electric Industrial Co., Ltd. | Vehicle in-situ locating apparatus | 
| 5072396, | Nov 08 1989 | Smiths Industries Public Limited Company | Navigation systems | 
| 5073819, | Apr 05 1990 | ROADWARE CORPORATION | Computer assisted video surveying and method thereof | 
| 5075861, | Jul 18 1988 | Israel Aircraft Industries Ltd. | Integrated stabilized optical and navigation system | 
| 5086396, | Feb 02 1989 | Honeywell Inc. | Apparatus and method for an aircraft navigation system having improved mission management and survivability capabilities | 
| 5089816, | Oct 16 1989 | BRONXWIDE ENTERPRISES, INC | Chart instrument for displaying real time vehicle position relative to information on charts | 
| 5115398, | Jul 04 1989 | U.S. Philips Corp. | Method of displaying navigation data for a vehicle in an image of the vehicle environment, a navigation system for performing the method, and a vehicle comprising a navigation system | 
| 5123088, | Jun 27 1988 | Nippon Telegraph and Telephone Corp. | Method and apparatus for creating and displaying navigators for guiding to related image information | 
| 5124938, | Jul 23 1990 | GOODRICH CORPORATION | Gyroless platform stabilization techniques | 
| 5128874, | Jan 02 1990 | HONEYWELL PLAZA, A CORP OF DE | Inertial navigation sensor integrated obstacle detection system | 
| 5133050, | Oct 24 1988 | Carleton University | Telescope operating system | 
| 5146212, | Jan 04 1990 | Apple Inc | Manipulatable orientation for a translatable graphic object | 
| 5155683, | Apr 11 1991 | Vehicle remote guidance with path control | |
| 5166878, | Apr 07 1989 | FRANK DATA INTERNATIONAL N V | Method and apparatus of computer aided surveying for obtaining digital, 3D topographic information | 
| 5177685, | Aug 09 1990 | MASSACHUSETTS INSTITUTE OF TECHNOLOGY, A CORP OF MA | Automobile navigation system using real time spoken driving instructions | 
| 5182641, | Jun 17 1991 | The United States of America as represented by the Administrator of the | Composite video and graphics display for camera viewing systems in robotics and teleoperation | 
| 5187571, | Feb 01 1991 | TTI Inventions A LLC | Television system for displaying multiple views of a remote location | 
| 5189402, | May 14 1987 | Advanced Interaction, Inc. | Content addressable video system for image display | 
| 5214615, | Feb 26 1990 | ACOUSTIC POSITIONING RESEARCH INC | Three-dimensional displacement of a body with computer interface | 
| 5214757, | Aug 07 1990 | MICHAEL BAKER JR , INC | Interactive automated mapping system | 
| 5227985, | Aug 19 1991 | University of Maryland; UNIVERSITY OF MARYLAND A NON-PROFIT ORGANIZATION OF MD | Computer vision system for position monitoring in three dimensions using non-coplanar light sources attached to a monitored object | 
| 5259037, | Feb 07 1991 | L-3 Communications Corporation | Automated video imagery database generation using photogrammetry | 
| 5262867, | Jun 20 1990 | Sony Corporation | Electronic camera and device for panoramic imaging and object searching | 
| 5265025, | Jul 11 1990 | Mitsubishi Denki Kabushiki Kaisha | Navigation system using satellite signals | 
| 5267042, | Jan 11 1991 | Pioneer Electronic Corporation | Image pickup device for automatically recording the location where an image is recorded | 
| 5268998, | Nov 27 1990 | Paraspectives, Inc. | System for imaging objects in alternative geometries | 
| 5270694, | May 14 1987 | Advanced Interaction, Inc. | Content addressable video system for image display | 
| 5274387, | Jun 06 1990 | Mazda Motor Corporation | Navigation apparatus for vehicles | 
| 5299300, | Feb 22 1990 | Harris Corporation | Interpolation processing of digital map imagery data | 
| 5322441, | Oct 05 1990 | Texas Instruments Incorporated | Method and apparatus for providing a portable visual display | 
| 5325472, | Apr 13 1990 | Matsushita Electric Industrial Co., Ltd. | Image displaying system for interactively changing the positions of a view vector and a viewpoint in a 3-dimensional space | 
| 5327233, | Dec 15 1990 | Samsung Electronics, Ltd. | Movable security camera apparatus | 
| 5335072, | May 30 1990 | Minolta Camera Kabushiki Kaisha | Photographic system capable of storing information on photographed image data | 
| 5381338, | Jun 21 1991 | HOOPER, DAVID C | Real time three dimensional geo-referenced digital orthophotograph-based positioning, navigation, collision avoidance and decision support system | 
| 5384588, | May 13 1991 | Sony Corporation | System for omindirectional image viewing at a remote location without the transmission of control signals to select viewing parameters | 
| 5388990, | Apr 23 1993 | The United States of America as represented by the Administrator of the | Virtual reality flight control display with six-degree-of-freedom controller and spherical orientation overlay | 
| 5392225, | Oct 20 1992 | OL SECURITY LIMITED LIABILITY COMPANY | Method and apparatus for correlating target data | 
| 5396583, | Oct 13 1992 | Apple Inc | Cylindrical to planar image mapping using scanline coherence | 
| 5490075, | Aug 01 1994 | The United States of America as represented by the Administrator of the | Global positioning system synchronized active light autonomous docking system | 
| 5495576, | Jan 11 1993 | INTELLECTUAL VENTURS FUND 59 LLC; INTELLECTUAL VENTURES FUND 59 LLC | Panoramic image based virtual reality/telepresence audio-visual system and method | 
| 5512941, | Mar 04 1991 | Canon Kabushiki Kaisha | Image sensing apparatus | 
| 5523783, | Oct 19 1992 | Fuji Photo Optical Co., Ltd. | Pan head control system for TV camera | 
| 5530650, | Oct 28 1992 | McDonnell Douglas Corp. | Computer imaging system and method for remote in-flight aircraft refueling | 
| 5555018, | Apr 25 1991 | Large-scale mapping of parameters of multi-dimensional structures in natural environments | |
| 5559707, | Jun 24 1994 | Garmin Switzerland GmbH | Computer aided routing system | 
| 5563650, | Nov 24 1992 | FRANK DATA INTERNATIONAL B V | Method and device for producing panoramic images, and a method and device for consulting panoramic images | 
| 5568152, | Feb 04 1994 | Trimble Navigation Limited | Integrated image transfer for remote target location | 
| 5598209, | Oct 20 1993 | LIBRE HOLDINGS, INC | Method for automatically adjusting a video conferencing system camera | 
| 5600368, | Nov 09 1994 | Rovi Technologies Corporation | Interactive television system and method for viewer control of multiple camera viewpoints in broadcast programming | 
| 5601353, | Dec 20 1995 | Vulcan Patents LLC | Panoramic display with stationary display device and rotating support structure | 
| 5602564, | Nov 14 1991 | Hitachi, Ltd. | Graphic data processing system | 
| 5633946, | May 19 1994 | Geospan Corporation | Method and apparatus for collecting and processing visual and spatial position information from a moving platform | 
| 5636036, | Feb 27 1987 | Interactive video system having frame recall dependent upon user input and current displayed image | |
| 5642285, | Jan 31 1995 | Trimble Navigation Limited | Outdoor movie camera GPS-position and time code data-logging for special effects production | 
| 5644694, | Dec 14 1994 | DREAMFACTORY SOFTWARE, INC | Apparatus and method for digital movie production | 
| 5645077, | Jun 16 1994 | Massachusetts Institute of Technology | Inertial orientation tracker apparatus having automatic drift compensation for tracking human head and other similarly sized body | 
| 5682332, | Sep 10 1993 | Criticom Corporation | Vision imaging devices and methods exploiting position and attitude | 
| 5684943, | Nov 30 1990 | Sun Microsystems Inc | Method and apparatus for creating virtual worlds | 
| 5689611, | Oct 09 1992 | Sony Corporation | Panorama image producing method and apparatus | 
| 5703604, | May 22 1995 | IMMERSIVE LICENSING, INC | Immersive dodecaherdral video viewing system | 
| 5729471, | Mar 31 1995 | The Regents of the University of California | Machine dynamic selection of one video camera/image of a scene from multiple video cameras/images of the scene in accordance with a particular perspective on the scene, an object in the scene, or an event in the scene | 
| 5739848, | Sep 08 1993 | Toyota Jidosha Kabushiki Kaisha | Object recognition apparatus and method | 
| 5751578, | May 16 1995 | GOODRICH CORPORATION | Platform attitude measurement system | 
| 5764276, | May 13 1991 | Sony Corporation | Method and apparatus for providing perceived video viewing experiences using still images | 
| 5768640, | Oct 27 1995 | Konica Corporation | Camera having an information recording function | 
| 5793367, | Jan 07 1993 | Canon Kabushiki Kaisha | Apparatus and method for displaying both an image and control information related to the image | 
| 5794216, | Jul 14 1995 | BROOKS & KUSHMAN P C | Methods and system for data acquisition in a multimedia real estate database | 
| 5815411, | Sep 10 1993 | Criticom Corporation | Electro-optic vision system which exploits position and attitude | 
| 5838906, | Oct 17 1994 | EOLAS TECHNOLOGIES INC | Distributed hypermedia method for automatically invoking external application providing interaction and display of embedded objects within a hypermedia document | 
| 5850352, | Mar 31 1995 | CALIFORNIA, THE UNIVERSITY OF, REGENTS OF, THE | Immersive video, including video hypermosaicing to generate from multiple video views of a scene a three-dimensional video mosaic from which diverse virtual video scene images are synthesized, including panoramic, scene interactive and stereoscopic images | 
| 5854843, | Jun 07 1995 | The United States of America as represented by the Secretary of the Air | Virtual navigator, and inertial angular measurement system | 
| 5881321, | May 09 1997 | Cammotion, Inc..; COMMOTION, INC | Camera motion sensing system | 
| 5897223, | Nov 17 1997 | L-3 Communications Corporation | Stabilized platform system for camera | 
| 5913078, | Nov 01 1994 | Konica Corporation | Camera utilizing a satellite positioning system | 
| 5937096, | Nov 30 1994 | Canon Kabushiki Kaisha | Motion image processing apparatus and method | 
| 6006126, | Jan 28 1991 | INTEGRA RADIONICS, INC | System and method for stereotactic registration of image scan data | 
| 6011585, | Jan 19 1996 | Apple Computer, Inc. | Apparatus and method for rotating the display orientation of a captured image | 
| 6037936, | Mar 27 1995 | Criticom Corp. | Computer vision system with a graphic user interface and remote camera control | 
| 6040824, | Jul 31 1996 | AISIN AW CO , LTD | Information display system with touch panel | 
| 6064355, | May 24 1994 | Texas Instruments Incorporated | Method and apparatus for playback with a virtual reality system | 
| 6133947, | Nov 15 1995 | BEJING XIAOMI MOBILE SOFTWARE CO ,LTD ; BEIJING XIAOMI MOBILE SOFTWARE CO ,LTD | Image processing system capable of displaying photographed image in combination with relevant map image | 
| 6141034, | Dec 15 1995 | STAR CO | Immersive imaging method and apparatus | 
| 6195122, | Jan 31 1996 | TRANSCENIC, INC | Spatial referenced photography | 
| 6233004, | Apr 19 1994 | Canon Kabushiki Kaisha | Image processing method and apparatus | 
| 6282362, | Nov 07 1995 | Trimble Navigation Limited | Geographical position/image digital recording and display system | 
| 6292215, | Jan 31 1995 | TRANSCENIC, INC | Apparatus for referencing and sorting images in a three-dimensional system | 
| 6449011, | Mar 27 1992 | Canon Kabushiki Kaisha | Video camera system having panhead for use in video conference or the like | 
| 6680746, | Nov 28 1994 | Canon Kabushiki Kaisha | Apparatus and method for controlling configuration of video camera | 
| 6768563, | Feb 24 1995 | Canon Kabushiki Kaisha | Image input system | 
| 7050102, | Jan 31 1995 | TRANSCENIC, INC | Spatial referenced photographic system with navigation arrangement | 
| 7849393, | Dec 09 1992 | DISCOVERY COMMUNICATIONS, LLC | Electronic book connection to world watch live | 
| 20010026318, | |||
| 20020067412, | |||
| 20100250120, | |||
| 20100302280, | |||
| 20100325589, | |||
| CA2058877, | |||
| JP2004173083, | |||
| JP3072309, | |||
| JP4336091, | |||
| JP5048964, | |||
| JP63164782, | |||
| RE42289, | Jan 31 1996 | TRANSCENIC, INC | Spatial referenced photographic system with navigation arrangement | 
| WO9016131, | |||
| WO9300647, | 
| Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc | 
| Jan 16 2009 | VINCENT, ROBERT STANFORD | TRANSCENIC, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 026125/ | 0442 | |
| Apr 11 2011 | Transcenic, Inc. | (assignment on the face of the patent) | / | 
| Date | Maintenance Fee Events | 
| Jan 01 2018 | REM: Maintenance Fee Reminder Mailed. | 
| Jun 18 2018 | EXP: Patent Expired for Failure to Pay Maintenance Fees. | 
| Date | Maintenance Schedule | 
| Jun 03 2017 | 4 years fee payment window open | 
| Dec 03 2017 | 6 months grace period start (w surcharge) | 
| Jun 03 2018 | patent expiry (for year 4) | 
| Jun 03 2020 | 2 years to revive unintentionally abandoned end. (for year 4) | 
| Jun 03 2021 | 8 years fee payment window open | 
| Dec 03 2021 | 6 months grace period start (w surcharge) | 
| Jun 03 2022 | patent expiry (for year 8) | 
| Jun 03 2024 | 2 years to revive unintentionally abandoned end. (for year 8) | 
| Jun 03 2025 | 12 years fee payment window open | 
| Dec 03 2025 | 6 months grace period start (w surcharge) | 
| Jun 03 2026 | patent expiry (for year 12) | 
| Jun 03 2028 | 2 years to revive unintentionally abandoned end. (for year 12) |