Provided herein are methods and systems for image registration from multiple sources. A method for image registration includes rendering a common field of interest that reflects a presence of a plurality of elements, wherein at least one of the elements is a remote element located remotely from another of the elements and updating the common field of interest such that the presence of the at least one of the elements is registered relative to another of the elements.

Patent
   10181361
Priority
Aug 12 2011
Filed
May 04 2017
Issued
Jan 15 2019
Expiry
Aug 12 2031

TERM.DISCL.
Assg.orig
Entity
Small
6
159
currently ok
1. A method comprising:
capturing one or more local images of a physical environment of a local device, the one or more local images comprising a representation of a first element, wherein the one or more local images have a first alignment and orientation when viewed relative to a coordinate system;
receiving, from a remote device, a remote image including a virtual element, wherein, prior to transmission, the remote image had a second alignment and orientation when viewed relative to the coordinate system, and wherein the remote image is received in a transformed state resulting, at least in part, from a skew, a shift, a crop, a translation, or combination thereof of the remote image during transmission such that display of the remote image in the transformed state results in a transformed alignment and orientation different from the second alignment and orientation;
generating a common field of interest based on the one or more local images and the remote image such that at least one of the first element and the virtual element is spatially registered relative to the other of the first element and the virtual element, wherein generating the common field of interest comprises applying one or more image transforms to one or more of the remote image and the one or more local images, and wherein the one or more image transforms are based on a first transformation characteristic of one or more of the local device and the remote device and a second transformation characteristic resulting from transmission of one or more of the remote image and the one or more local images, wherein the applying the one or more image transforms facilitates display of the remote image having the second alignment and orientation when viewed relative to the coordinate system; and
causing the common field of interest to be rendered via the local device.
10. A method comprising:
capturing a video of a local physical environment using a mobile device;
rendering a physical image representing a portion of the captured video of the local physical environment via the mobile device, the physical image comprising a representation of a physical element, wherein the physical image has a first alignment and orientation when viewed relative to a coordinate system;
receiving a virtual image from a remote device via a network, the virtual image comprising a representation of a virtual element, wherein, prior to transmission, the virtual image had a second alignment and orientation when viewed relative to the coordinate system, and wherein the virtual image is received in a transformed state resulting, at least in part, from a skew, a shift, a crop, a translation, or combination thereof of the virtual image during transmission such that display of the virtual image in the transformed state results in a transformed alignment and orientation different from the second alignment and orientation;
generating a common field of interest based on the physical image and the virtual image such that at least one of the physical element and the virtual element is spatially registered relative to the other of the physical element and the virtual element, wherein generating the common field of interest comprises applying one or more image transforms to one or more of the physical image and the virtual image, and wherein the one or more image transforms are based on a first transformation characteristic of one or more of the mobile device and the remote device and a second transformation characteristic resulting from transmission of one or more of the physical image and the virtual image, wherein the applying the one or more image transforms facilitates display of the virtual image having the second alignment and orientation when viewed relative to the coordinate system; and
causing the common field of interest to be rendered via the mobile device.
18. A method comprising:
receiving, via a network, a video of a remote physical environment;
rendering a remote virtual image representing at least a portion of the video of the remote physical environment via a local device, the remote virtual image comprising a representation of a first virtual element, wherein, prior to transmission, the remote virtual image had a first alignment and orientation when viewed relative to a coordinate system, and wherein the remote virtual image is received in a transformed state resulting, at least in part, from a skew, a shift, a crop, a translation, or combination thereof of the remote virtual image during transmission such that display of the remote virtual image in the transformed state results in a transformed alignment and orientation different from the first alignment and orientation;
causing a local virtual image to be generated via the local device, wherein the local virtual image overlays the rendered remote virtual image, the local virtual image comprising a representation of a second virtual element, wherein the local virtual image has a second alignment and orientation when viewed relative to the coordinate system;
causing information representing the local virtual image and representing a spatial relationship between the local virtual image and the remote virtual image to be transmitted to a remote device;
generating a common field of interest based on the remote virtual image and the information representing the local virtual image and representing the spatial relationship between the local virtual image and the remote virtual image such that at least one of the first virtual element and the second virtual element is spatially registered relative to the other of the first virtual element and the second virtual element, wherein generating the common field of interest comprises applying one or more image transforms to one or more of the remote virtual image and the local virtual image, and wherein the one or more image transforms are based on a first transformation characteristic of one or more of the local device and the remote device and a second transformation characteristic resulting from transmission of one or more of the remote virtual image and the local virtual image, wherein the applying the one or more image transforms facilitates display of the remote virtual image having the first alignment and orientation when viewed relative to the coordinate system; and
causing the common field of interest to be rendered via the remote device.
2. The method of claim 1, wherein the one or more local images are part of a live video capture.
3. The method of claim 1, wherein the local device is a mobile device or tablet.
4. The method of claim 1, further comprising the step of calibrating the common field of interest by aligning a calibration feature of a remote field and a calibration feature of a local field.
5. The method of claim 4, wherein the calibration features of the remote field and the local field are aligned relative to the coordinate system.
6. The method of claim 4, wherein the calibration features of the remote field and the local field are aligned relative to a pre-defined virtual fiducial.
7. The method of claim 1, wherein the at least one of the first element and the virtual element is spatially registered relative to the other of the first element and the virtual element based upon at least a registration feature inserted onto at least one of the remote image and the one or more local images.
8. The method of claim 7, wherein the registration feature is a virtual image inserted onto at least one of the remote image and the one or more local images.
9. The method of claim 7, wherein the registration feature is a virtual image rendered in the common field of interest.
11. The method of claim 10, wherein the mobile device is a handheld device or wearable device.
12. The method of claim 10, further comprising the step of calibrating the common field of interest by aligning a calibration feature of a remote field and a calibration feature of a local field.
13. The method of claim 12, wherein the calibration features of the remote field and the local field are aligned relative to the coordinate system.
14. The method of claim 12, wherein the calibration features of the remote field and the local field are aligned relative to a pre-defined virtual fiducial.
15. The method of claim 10, wherein the at least one of the physical element and the virtual element is spatially registered relative to the other of the physical element and the virtual element based upon at least a registration feature inserted onto at least one of the virtual image and the physical image.
16. The method of claim 15, wherein the registration feature is an additional virtual image inserted onto at least one of the virtual image and the physical image.
17. The method of claim 15, wherein the registration feature is an additional virtual image rendered in the common field of interest.
19. The method of claim 18, wherein the local device is a handheld device or wearable device.
20. The method of claim 18, further comprising the step of calibrating the common field of interest by aligning a calibration feature of a remote field and a calibration feature of a local field.

This application is a continuation of, and claims priority to, U.S. patent application Ser. No. 13/208,926, filed on Aug. 12, 2011, entitled “System and Method for Image Registration of Multiple Video Streams,” the entire contents of which are hereby incorporated herein by reference.

Video combiners in extensive use today combine video from two separate sources using various multiplexing and media combining technology. When two video sources are combined or multiplexed the two video sources are not necessarily in a desired alignment. Misalignments are often due to lack of synchronization between the video sources.

As an example, conventional video streaming rely on algorithms to systematically remove data during compression and decompression processes that allow more efficient transmission of video/image feeds. Loss of data and changes of resolution, aspect ration, skew, and other factors impact (e.g. transform) the raw viewing of video. Accordingly, when two video streams are combined from two distinct sources, the resultant composite video or series of images can be misaligned.

Disclosed are systems and methods for establishing image registration of multiple video/image streams to align multiple video/image streams for a desired rendering of images. A Spatial Image Registration System (SIRS) uses detection methods, systems, symbols and/or detection points introduced within the images of separate video feeds to verify and if necessary, apply multiple image transformations to perform an alignment between the original and transmitted feeds. In the case of virtual interactive presence (VIP), SIRS aides in creating a common field of interest with users interactions spatially registered or matched regardless of transmission or display differences.

Methods are described for image registration or co-localization. One method comprises: rendering a common field of interest that reflects a presence of a plurality of elements, wherein at least one of the elements is a remote element located remotely from another of the elements; and updating the common field of interest such that the presence of the at least one of the elements is registered relative to another of the elements.

Another method comprises: generating a first image representing a first element; generating a second image representing a second element disposed remotely from the first element; and rendering a composite image including the first image and the second image, wherein at least one of the first image and the second image is registered relative to the other of the first image and the second image based upon a registration feature.

A system for image registration is described. The system comprises: a display configured for displaying a common field of interest; a sensor configured for obtaining image data; a processor in signal communication with the display and the sensor, wherein the processor is configured to perform steps comprising, rendering a common field of interest that reflects a presence of a plurality of elements based upon the image data, wherein at least one of the elements is a remote element located remotely from another of the elements; updating the common field of interest such that the presence of the at least one of the elements is registered relative to another of the elements; and outputting the common field of interest to the display.

Additional advantages will be set forth in part in the description which follows or may be learned by practice. The advantages will be realized and attained by means of the elements and combinations particularly pointed out in the appended inventive concepts. It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not to be considered restrictive.

The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate embodiments and together with the description, serve to explain the principles of the methods and systems provided:

FIG. 1 illustrates virtual interactive presence;

FIG. 2A illustrates virtual interactive presence;

FIG. 2B illustrates a local expert assisting a remote user;

FIG. 3 illustrates an exemplary registration system;

FIG. 4A illustrates an exemplary process performed by the registration system of FIG. 3;

FIG. 4B illustrates a local field of an exemplary process performed by the registration system of FIG. 3;

FIG. 4C illustrates a remote field of an exemplary process performed by the registration system of FIG. 3;

FIG. 4D illustrates a local field of an exemplary process performed by the registration system of FIG. 3;

FIG. 4E illustrates a remote field of an exemplary process performed by the registration system of FIG. 3;

FIG. 4F illustrates an offset of a registration mechanism;

FIG. 4G illustrates the transformation of the offset of the registration mechanism of FIG. 4F;

FIG. 4H illustrates an exemplary process performed by the registration system of FIG. 3;

FIG. 5 illustrates an exemplary virtual presence system;

FIG. 6 illustrates exemplary processes performed within a graphics server;

FIG. 7 illustrates exemplary processes performed within a network server;

FIG. 8 illustrates a side view of an exemplary VIP display;

FIG. 9 illustrates a user's view of an exemplary VIP display;

FIG. 10 illustrates a user's view of an exemplary VIP display;

FIG. 11 illustrates an exemplary method;

FIG. 12 illustrates another exemplary method;

FIG. 13 illustrates virtual presence in a remote surgical environment;

FIG. 14 illustrates merging of medical imaging with an operative field; and

FIG. 15 illustrates an exemplary operational environment.

Before the present methods and systems are disclosed and described, it is to be understood that the methods and systems are not limited to specific synthetic methods, specific components, or to particular compositions, as such may, of course, vary. It is also to be understood that the terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting.

As used in the specification and the appended inventive concepts, the singular forms “a,” “an” and “the” include plural referents unless the context clearly dictates otherwise.

Ranges may be expressed herein as from “about” one particular value, and/or to “about” another particular value. When such a range is expressed, another embodiment includes from the one particular value and/or to the other particular value. Similarly, when values are expressed as approximations, by use of the antecedent “about,” it will be understood that the particular value forms another embodiment. It will be further understood that the endpoints of each of the ranges are significant both in relation to the other endpoint, and independently of the other endpoint.

“Optional” or “optionally” means that the subsequently described event or circumstance may or may not occur, and that the description includes instances where said event or circumstance occurs and instances where it does not.

Throughout the description and claims of this specification, the word “comprise” and variations of the word, such as “comprising” and “comprises,” means “including but not limited to,” and is not intended to exclude, for example, other additives, components, integers or steps. “Exemplary” means “an example of” and is not intended to convey an indication of a preferred or ideal embodiment.

Disclosed are components that can be used to perform the disclosed methods and systems. These and other components are disclosed herein, and it is understood that when combinations, subsets, interactions, groups, etc. of these components are disclosed that while specific reference of each various individual and collective combinations and permutation of these may not be explicitly disclosed, each is specifically contemplated and described herein, for all methods and systems. This applies to all aspects of this application including, but not limited to, steps in disclosed methods. Thus, if there are a variety of additional steps that can be performed it is understood that each of these additional steps can be performed with any specific embodiment or combination of embodiments of the disclosed methods.

The present methods and systems may be understood more readily by reference to the following detailed description of preferred embodiments and the Examples included therein and to the Figures and their previous and following description.

Disclosed are methods and systems for image registration of multiple video streams. The disclosed methods and systems can utilize virtual reality. Virtual reality (VR) refers to a computer-based application which provides a human-computer interface such that the computer and its devices create a sensory environment which is dynamically controlled by the actions of the individual, so that the environment appears “real” to the user. With VR, there is communication between a computer system and a user. The computer creates a sensory environment for the user to experience which may be, in one aspect, multisensory (although this is not essential) and the computer creates a sense of reality in response to user inputs.

In one exemplary aspect, the system disclosed can utilize at least two types of VR, Immersive and Non-immersive. Immersive VR creates the illusion that the user is actually in a different environment. In one aspect, the system accomplishes this through the use of such devices as Head Mounted Displays (HMD's), earphones, and input devices such as gloves or wands. In another aspect, in order to enhance to realism of the experience, a plurality of Degrees of Freedom (DOF's) are utilized, which the software can simulate. Generally, the more the DOF's, the better the realism of the experience. Exemplary DOF's include, without limitation: X,Y,Z, roll, pitch, and yaw.

Non-immersive VR creates an environment that is differentiable from the user's surrounding environment. It does not give the illusion that the user is transported to another world. Non-immersive VR works by creating a 3-dimensional image and surround sound through the use of stereo projection systems, computer monitors, and/or stereo speakers. Non-immersive VR can be run from a personal computer without added hardware.

In one aspect, movement in Immersive VR can be realized by a system through the use of optical, acoustical, magnetic, or mechanical hardware called trackers. Preferably, the input devices have as many of these trackers as possible, so that movement can be more accurately represented. For instance, virtual gloves can have up to 3 trackers for each index, and more for the palm and wrist, so that the user can grab and press objects. In one aspect, the trackers can be equipped with positioning sensors, that tell a computer which direction the input is facing and how the input device is tilted in all directions. This gives a sensor with six degrees of freedom.

Output devices bring the user to the virtual world. An example of an output device that can be used in the present system include, without limitation, head mounted displays (HMD) in the form of glasses or goggles, which allow a user to wear a display system on their head. One approach to the HMD is to use a single Liquid Crystal Display (LCD), wide enough to cover both eyes. Another approach is to have two separated displays—one for each eye. This takes somewhat more computer power, since the images displayed are different. Each display has a separate image rendered from the correct angle in the environment. Eye-tracking can be combined with HMDs. This can allow, for example, surgeons to move their eyes to the part of an image they want to enhance.

Another example of an output device that can be used in an embodiment of the present system is shuttered glasses. This device updates an image to each eye every other frame, with the shutter closed on the other eye. Shuttered glasses require a very high frame rate in order to keep the images from flickering. This device is used for stereo monitors, and gives an accurate 3-d representation of a 2-d object, but does not immerse the user in the virtual world.

Another output device that can be used in an embodiment of the present system is a screen with multiple projectors. The screen can be either a plane or bent. A challenge when using multiple projectors on the same screen is that there can be visible edges between the projections. This can be remedied be using a soft-edge system wherein the projection goes more and more transparent at the edges and the projections overlap. This produces an almost perfect transition between the images. In order to achieve a desired 3D effect, shuttered glasses can be used. Special glasses can be used, that alternate between making the glass either completely opaque or completely transparent. When the left eye is opaque, the right one is transparent. This is synchronized to the projectors that are projecting corresponding images on the screen.

In another aspect, a Cave Automatic Virtual Environment (CAVE) can also be used in the present system. A CAVE can use mirrors in a cube-shaped room to project stereo images onto the walls, giving the illusion that you are standing in a virtual world. The world is constantly updated using trackers, and the user is allowed to move around almost completely uninhibited.

Disclosed are methods and systems for image registration. Such methods and systems can render a number of elements/participants virtually present into a field of interest in a manner such that the users can interact for any given purpose, such as the delivery of remote expertise. A field of interest can comprise varying amounts of “real” and “virtual” elements, depending on a point of view. Elements can include any “real” or “virtual” object, subject, participant, or image representation. Various components of the disclosed methods and systems are illustrated in FIG. 1.

A common field of interest 101 can be a field within which elements are physically and/or virtually present. Point of Reality (or Point of View) can refer to the vantage of the element/participant that is experiencing the common field of interest. In FIG. 1, exemplary points of reality, or points of view, are shown at 102 and 103, representing displays. The common field of interest 101 can appear similar from both vantages, or points of view, but each comprises differing combinations of local (physical) and remote (virtual) elements/participants.

Local elements can be elements and/or participants which are physically present in the common field of interest. In FIG. 1, element A 105 is a local element for field A 104 and is physically present in field A 104. Element B 107 is a local element for field B 106 and is physically present in field B 106. It is understood that virtual elements (not shown) can be inserted or overlaid in field A 104 and/or field B 106, as desired.

Remote elements can be elements and/or participants that are not physically present in the common field of interest. They are experienced as “virtually present” from any other local vantage point. As shown in FIG. 1, element B 107 is a remote element to field A 104 and is virtually present in field A 104. Element A 105 is a remote element in field B 106 and is virtually present in field B 106.

Methods for rendering a virtual interactive presence by combining local and remote elements and/or participants can comprise one or more of the following steps. A common local field can be rendered in a manner that reflects the presence of the field, elements and/or participants. As shown in FIG. 2A, Participant A can experience real elements in field A through a viewer. The common local field can be rendered such that it is experienced remotely in a manner that enables remote participants to experience it similarly to the local persons. As shown in FIG. 2A, this is illustrated by Participant A experiencing element B as virtually present in field A.

Remote persons can insert themselves and/or interact with the virtual field as rendered to them. For example, Participant A can insert hands, instruments, etc. into field A and interact with the virtual element(s) B. Viewer B can view a ‘virtual compliment’ to this, with Viewer B's real elements interacting with Participant A's virtual elements.

The common local field can be continuously updated such that the presence of the remote participants can be rendered in real time. For example, the remote scene can be the most up-to-date available with the time lag between the remote capture and the local render kept as low as possible. Conversely, if there is a need to introduce a timing difference, this can be accomplished as well.

The common local field can be scaled to a size and depth to meaningfully match the local scene. And the common local field can be configurable, such that remote elements can be made more or less transparent, removed entirely, or otherwise altered to suit the needs of the local user.

Each field is captured by a digital camera. The resulting image is physically distorted from its reality, based upon the physical characteristics of the camera. A processor, therefore, receives and displays a “physically” distorted version of the local reality. Likewise, a digital camera also captures the remote field(s), but the incoming stream is relayed through a transmission device and across a network. The processor, therefore, receives the remote stream that contains both physical and transmission-based distortion. The processor must then apply a series of transformations that removes the physical and transmission-based distortion from the common local field.

The local participants can experience the virtually present participants in a manner that enables continuous interaction in the common local field. FIG. 2B illustrates a local expert assisting a remote user. The hands of the local expert 201 are slightly transparent and superimposed into the field that is viewed by the remote user. The remote user can view the local expert's hands, the remote user's hands and a puzzle located at the remote user's location. The local expert is assisting the remote user in assembling a puzzle.

FIG. 3 illustrates an exemplary registration system 300. As shown, the registration system 300 can comprise a first display 302 and a second display 304 configured for displaying one or more of an image, a video, a composite video/image, and a common field of interest, for example. However, it is understood that any number of displays can be included in the system 300. In certain aspects, the second display 304 can be disposed remotely from the first display 302. As an example, each of the first display 302 and the second display 304 can be configured to render the common field of interest thereon. As a further example, each of the first display 302 and the second display 304 can be configured to render at least one of the local field and the remote field thereon. In certain aspects, at least one of the first display 302 and the second display 304 can be a VIP display, as described in further detail herein. However, it is understood that each of the first display 302 and the second display 304 can be any type of display including a monoscopic display and a stereoscopic display, for example. It is understood that any number of any type of display can be used.

A first sensor 306 can be in signal communication with at least the first display 302 and can be configured for obtaining image data such as a virtual presence data, for example. In certain aspects, the first sensor 306 can be one or more of a camera, an infrared sensor, a light sensor, a RADAR device, a SONAR device, a depth scan sensor, and the like. It is understood that the first sensor 306 can be any device or system capable of capturing/obtaining an image data representative of at least one of a “real” element and a “virtual” element.

A second sensor 308 can be in signal communication with at least the second display 304 and can be configured for obtaining image data such as virtual presence data, for example. In certain aspects, the second sensor 308 can be one or more of a camera, an infrared sensor, a light sensor, a RADAR device, a SONAR device, a depth scan sensor, and the like. It is understood that the second sensor 308 can be any device or system capable of capturing/obtaining an image data representative of at least one of a “real” element and a “virtual” element. It is further understood that any number of sensors can be used.

A plurality of processors 310, 312 can be in direct or indirect signal communication with at least one of the first display 302, the second display 304, the first sensor 306, and the second sensor 308. Each of the processors 310, 312 can be configured to render the image data collected by the sensors 306, 308 onto at least one of the displays 302, 304. It is understood that the processors 310, 312 can be configured to modify the image data and the resultant image for transmission and display. It is further understood that any number of processors can be used, including one. In certain aspects, the system 300 comprises only the processor 310, 312 in data communication with each other.

In certain aspects, each of the displays 302, 304 can comprise an associated one of the processors 310, 312 for rendering images onto the displays 302, 304. Each of the processors 310, 312, or another system comprising a processor, can communicate with each other through a network connection. For example, remote sites can connect via the Internet. Tasks can be divided amongst each of the processors 310, 312. For example, one of the processors 310, 312 can be configured as a graphics processor or graphics server and can gather images from one of the sensors 306, 308 and/or a network server, perform an image composition tasks, and drive one or more of the displays 302, 304.

FIG. 4A illustrates exemplary processes 400 that can be performed with at least one the processors 310, 312. As shown, the processors 310, 312 can be configured to render a common field of interest that reflects a presence of a plurality of elements based upon the image data obtained by at least one of the sensors 306, 308. As an example, at least one of the elements rendered in the common field of interest can be a remote element physically located remotely from another of the elements. In certain aspects the processors 310, 312 can be configured to update the common field of interest such that the presence of at least one of the elements is registered relative to another of the elements. The processors 310, 312 can also be configured to render/output the common field of interest to at least one of the displays 302, 304. As an example, the processors 310, 312 can render interaction between a remote user and a local user in the common field of interest. As a further example the presence of the remote element can be rendered in real time to the local user and the presence of a local element can be rendered in real time to the remote user.

In step 402, a registration mechanism can be generated. As an example, the registration mechanism can be an image including a registration feature having a pre-determined location and arrangement. In an aspect, at least one of the first sensor 306 and the second sensor 308 can capture image data to generate a registration image representing the registration mechanism. As an example, a pre-defined pattern of dots or markers having any shape and size can be digitally inserted into the registration image to define the registration feature. As a further example, the registration feature can be a virtual image overlaid or combined with the registration image.

An exemplary case is shown in FIG. 4B and FIG. 4C, wherein the sensors 306, 308 capture image data to produce a registration mechanism. As illustrated in FIG. 4B and FIG. 4C, each of a pair of coordinate systems 421, 431 with identical dimensions is disposed in each of a local field 422 and a remote field 432. As an example, each of the coordinate systems 421, 431 can be a square grid system. However, other coordinate systems can be used. The coordinate systems 421, 431 are situated identically in position and orientation relative to the respective sensors 306, 308 in each of the respective fields 422, 432. In an aspect, mounts 424, 434 coupled to the sensors 306, 308 are perpendicular to an edge of the respective coordinate system 421, 431. A fiducial 425, 435 or reference point can be defined in substantially identical or identical pre-determined locations in each of the fields 422, 432 based upon the coordinate systems 421, 431, such as a corner of a lower-left quadrant, for example.

In an aspect, a pre-defined first pattern of dots 426 or markers can be disposed on the coordinate system 421 as a registration feature, and the coordinates of each of the dots 426 with respect to the fiducial 425 can be stored. A second pattern of dots 436 or markers can be disposed on the coordinate system 431 with respect to the fiducial 435 so that a coordinate of each of the dots 436 of the second pattern corresponds to a coordinate of one of the dots 426 of the first pattern. Image data of the field 422 captured by the sensor 306 can be defined as the registration mechanism including the dots 426 as the registration feature. As an example, data relating to the coordinates of each of the dots 426, 436 can be stored on a storage device for subsequent retrieval. As a further example, the data relating to the coordinate of each of the dots 426, 436 can be transmitted between the processors 310, 312 of the system 300 to calibrate each of the fields 422, 432.

In an exemplary aspect, illustrated in FIG. 4D and FIG. 4E, a spatial tracking, motion tracking, or similar system can be used in lieu of a grid. As an example, in FIG. 4D and FIG. 4E, a Flock of Birds (Ascension Technology Corp., Burlington, Vt.) motion tracking system is used. However, other spatial tracking and/or motion tracking systems can be used. As shown in FIG. 4D and FIG. 4E, a plurality of planes 440, 450 with identical dimensions can be positioned in each field 422, 432. The planes 440, 450 can be arranged to define a bottom of the respective fields 422, 432. As an example, the planes 440, 450 can be situated identically in position and orientation with respect to the sensors 306, 308 in each of the fields 422, 432. In an aspect, mounts 424, 434 coupled to the sensors 306, 308 can be perpendicular to an edge of the respective plane 440, 450. A fiducial 442, 452 or reference point can be recognized in identical pre-determined locations of each of the fields 422, 432 such as a corner of a lower-left quadrant, for example.

As an example, shown in FIG. 4D and FIG. 4E, the fiducials 442, 452 are devices that are configured to transmit a pulsed DC magnetic field. As a further example, a pre-defined first pattern of dots 444 or markers can be disposed on the plane 440 as a registration feature. The coordinates of each of the dots 444 with respect to the fiducial 442 can be noted by affixing magnetic receivers (not shown) to each of the dots 444 to measure the magnetic field produced by the fiducial 442 at the various locations of the dots 444. From the measurements, the position and coordinates of each of the dots 444 relative to the fiducial 442 can be computationally derived by the Flock of Birds system and stored. As an example, data relating to the coordinates of each of the dots 444 can be stored on a storage device for subsequent retrieval. As a further example, the data relating to the coordinate of each of the dots 444 can be transmitted between the processors 310, 312 of the system 300 to calibrate each of the fields 422, 432.

A second pattern of dots 454 or markers can be disposed on the plane 450 with respect to the fiducial 452 and based upon the position and coordinates of each of the dots 444 relative to the fiducial 442. Accordingly, a coordinate of each of the dots 454 of the second pattern can correspond to a coordinate of one of the dots 444 of the first pattern, relative to the respective fiducial 442, 452. It is understood that the position and coordinate information relating to the dots 444, 454 can be transmitted between the fields 422, 432 or processor 310, 312 by a system external to the system 300. It is further understood that the position and coordinate information relating to the dots 444, 454 can be transmitted along with image data. Other methods for generating a registration mechanism can be used

Returning to FIG. 4A, the registration mechanism having the registration feature is transmitted to one of the processors 310, 312 for transformation and rendering, as shown in step 404. During the transmission of the registration mechanism, the underlying data can be compressed and decompressed and may be modified or lost. Accordingly, when the registration mechanism is received and rendered by the one of the processors 310, 312, the elements represented in the registration mechanism may be skewed, shifted, cropped, or transformed. Likewise, the registration feature would also be transformed in a similar manner, whereby the resultant pattern and location of the registration feature would not match the pre-defined location and pattern prior to transmission.

In step 406, the one of the processors 310, 312 receives the registration mechanism to de-transform or register the elements represented thereby. As an example, the one of the processor 310, 312 analyzes the registration mechanism to discover a location and arrangement of the registration feature. Since the registration feature has pre-determined characteristics such as location and arrangement, one or more of the processors 310, 312 can compare the current transformed location and arrangement to the known, pre-determined location and arrangement. As an illustrative example, FIG. 4F shows the registration feature in an offset position 456 due to transformations caused form transmitting the registration mechanism. Accordingly, one or more of the processors 310, 312 can compare the offset position 456 of the registration feature to a known, original position 458.

From the comparison, the one of the processors 310, 312 can determine a set of transforms that should be applied to the registration mechanism in order to return the underlying data or image to the desired state (e.g. the original position 458), as shown in FIG. 4G. One skilled in the art of image processing would understand that various transform methods and algorithms can be applied to an image to “de-transform” the image to an original state. One or more of the processors 310, 312 can continue to apply transforms to the registration mechanism until the original arrangement and location of the registration features are achieved, as shown in FIG. 4G.

FIG. 4H illustrates an exemplary process 460 that can be performed with the system 300. In step 462, the first sensor 306 can capture image data to generate a first image representing a first element. Alternatively, the first image can be generated from stored image data or the like. As an example, the first image can comprise a registration feature having a pre-determined location and arrangement relative to the first image. In certain aspects, the registration feature can be inserted into the first image as a detectable marker. For example, a pre-defined pattern of dots can be digitally inserted into the image. As a further example, the registration feature can be a virtual image overlaid or combined with the first image. However, any registration feature or mechanism can be used.

The first image comprising the registration feature can be transmitted to the remote processor 312 for transformation and rendering, at step 463. During the transmission of the first image, the underlying data can be compressed and decompressed and may be modified or lost. Accordingly, when the first image is received and rendered by the processor 312, the elements represented in the first image may be skewed, shifted, cropped, or transformed Likewise, the registration feature would also be transformed in a manner similar to the first image, whereby the resultant pattern and location of the registration feature would not match the pre-defined location and pattern prior to transmission.

In step 464, the second sensor 308 can capture image data to generate a second image representing a second element disposed remotely from the first element. It is understood that the second image can be generated from stored image data or the like. As an example, the second image comprises a registration feature having a pre-determined location and arrangement relative to the second image. In certain aspects, the registration feature can be inserted into the second image as a detectable marker. For example, a pre-defined pattern of dots can be digitally inserted into the image. As a further example, the registration feature can be a virtual image overlaid or combined with the second image.

In step 465, the second image having the registration feature can be transmitted to the second display 304 disposed locally relative to the second sensor 308. During the transmission of the second image, the underlying data can be altered for formatting and compatibility with the second display 304. Accordingly, when the second image is received and rendered onto the second display 304, the elements represented in the second image may be skewed, shifted, cropped, or transformed. Likewise, the registration feature would also be transformed in a manner similar to the first image, whereby the resultant pattern and location of the registration feature would not match the pre-defined location and pattern prior to transmission. Following this transmission, the second image rendered on the second display 304 can be analyzed by processor 312 to determine the transformation of the second image.

In step 466, the processor 312 transmits the first image onto the second display 304 for rendering thereon. Similar to the rendering of the second image, a transformation may occur when rendering the first image to the second display 304. As such, each of the first image and the second image may be transformed or altered from intended previous state prior to transmission and rendering. Following this transmission, the first image rendered on the second display 304 can be analyzed by processor 312 to determine the transformation of the second image.

In an aspect, where transform parameters are known based upon the components and equipment being used, the processors 310, 312 can retrieve the known transform parameters and automatically calculate reverse transforms in order to return the images to an original state. As an example, data relating to known transforms for particular equipment and components can be stored and processed using a priori algorithms and methods. However, other methods can be used.

In step 468, the processor 312 can render a composite image to the second display 304 including the first image and the second image wherein each of the first image and the second image can be registered relative to the other of the first image and the second image based upon the registration feature. As an example, the processor 312 analyzes each of the first image and the second image to discover a location and arrangement of the registration feature for each of the first image and the second image. Since the registration feature for each of the first image and the second image have known, pre-determined characteristics such as location and arrangement, the processor 312 can compare the current transformed location and arrangement to the known, pre-determined location and arrangement. From the comparison, the processor 312 can determine a set of transforms that should be applied to each of the first image and the second image in order to return the first image and the second image to a desired state. One skilled in the art of image processing would understand that various transform methods and algorithms can be applied to an image to “de-transform” the image to an original state. The processor 312 can continue to apply transforms to at least one of the first image and the second image until the original arrangement and location of the registration features is achieved.

In an aspect, the registration feature of the second image can be used as a local reference to which the registration feature of the first image can be registered and aligned. As an example, the processor 312 can locate a centroid of each of the elements of the registration features for the first image and the second image. As a further example, the first image can be linearly shifted along any number of dimensional axes to align the first image to the second image. It is understood that non-linear shifting and alignment techniques can also be applied. It is further understood that the first image can be padded or cropped in order to match the boundaries of the second image (or some other reference image).

It is understood that the second image can be transmitted to the first display and combined in a similar manner to generate a composite image on the first display. In this way, the first display 302 and the second display 304 render composite images representing the same alignment of the first image and the second image relative to each other. Accordingly, a viewer of the second display 304 is assured that the first image received from a remote location is rendered in an intended orientation and alignment relative to the second image. Likewise, a viewer of the first display 302 is assured that the second image received from a remote location is rendered in an intended orientation and alignment relative to the first image that is generated local to the first display 302.

In step 469, the composite image rendered on each of the first display and the second display can be updated to reflect any changes to the first image and/or the second image. For example, where the sensors 306, 308 are video cameras, each sequentially captured video frame can represent a modified version of the first image and the second image, respectively. Accordingly, as the first image and the second image are modified, the composite image can be updated and each of the modified first image and the modified second image can be registered and aligned for rendering on the displays 302, 304. It is understood that any number of images and displays can be aligned in a similar manner as described herein.

FIG. 5 illustrates an exemplary virtual presence system. One such system can be used by each remote participant that is to join the same session. Each system can communicate with each other through a network connection. For example, remote sites can connect via the internet. Tasks can be divided amongst a plurality of computers in each system. For example, one computer (a graphics server) can gather images from local cameras and a network server, perform the stereo image composition tasks, and drive a local stereoscopic display system. As a further example, the processor(s) 310 of system 300 can be embodied by the graphics server.

FIG. 6 illustrates exemplary processes that can be performed with the graphics server. Images can be gathered into local data structures (frame rings). Local images can be gathered from a plurality of cameras, for example two cameras. Remote images can be provided by the network server via a high-speed remote direct memory access (RDMA) connection, for example. These images can be combined so that the remote user and the local user can be seen in the same scene (as in FIG. 3). This composite result can be transmitted to a local stereoscopic display system. A second computer can act as the network server, which can perform network encoding/decoding tasks as well as depth map generation, for example.

FIG. 7 illustrates exemplary processes that can be performed with the network server. Local images gathered from the graphics server via the RDMA connection can be analyzed and mapped with depth information, encoded for efficient network transmission, and sent to an external network connection to be received by a corresponding network server at the remote site. Simultaneously, encoded images and depth maps can be received from the remote site, decoded, and provided to the local graphics server via the RDMA connection.

The system can be user-controlled by a control terminal connected to the network server; the user can then access and control the graphics server via the dedicated network connection to the network server.

Parameters of virtual interactive presence can be configured depending on the system used. Configurable parameters include, but are not limited to, size of virtual elements, presence of virtual elements (opaque, translucent, etc.), time of virtual presence (time can be configured to be delayed, slowed, increased, etc.), superimposition of elements such that any combination of virtual and real can be superimposed and/or ‘fitted’ over one another, and the like.

FIG. 8 illustrates a side view of an exemplary VIP display. FIG. 9 illustrates a user's view of an exemplary VIP display. FIG. 10 illustrates a user's view of an exemplary VIP display.

As used herein, a “local” field of interest can refer to a local physical field and local user, thus making every other field remote. Each field can be local to its local physical user, but remote to other users. The composite of the fields can be a common field of interest. This is distinct from common “virtual worlds” in that there can be components of “real” within the local rendering of the common field of interest and interactions can be between actual video (and other) renderings of physical objects and not just graphic avatars representing users and objects. The methods and systems provided allow for virtual interactive presence to modify/optimize a physical domain by the interplay of real and virtual.

In an aspect, illustrated in FIG. 11, provided are methods for virtual interactive presence comprising rendering a common field of interest that reflects the physical presence of a remote user and a local user at 1101, rendering interaction between the remote user and the local user in the common field of interest at 1102, and continuously updating the common field of interest such that the presence of the remote user is rendered in real time to the local user and the presence of the local user is rendered in real time to the remote user at 1103.

The common field of interest can be rendered such that the remote user experiences the common field of interest similarly to the local user. The local user can experience the remote user's physical presence in a manner that enables continuous interaction in the common field of interest with the remote user. The methods can further comprise rendering the physical presence of a local object in the common field and rendering interaction between the local user and the local object in the common field. The methods can further comprise rendering the physical presence of a local object in the common field of interest and rendering interaction between the remote user and the local object in the common field of interest.

In another aspect, illustrated in FIG. 12, provided are methods for virtual interactive presence comprising rendering a local field of interest that reflects the physical presence of a local object, a volumetric image of the local object, and a local user at 1201, rendering interaction between the local object, the volumetric image, and the local user in the local field of interest at 1202, and continuously updating the local field of interest such that the presence of the local object and the volumetric image of the local object is rendered in real time to the local user at 1203.

The local object can be, for example, a patient and the volumetric image of the local object can be, for example, a medical image of a part of the patient. However, the local object can be any object of interest and the image of the local object can be any accurate rendering of that object. For example, could be an automobile engine and a 3D graphic of the engine, etc.

The medical image can be, for example, one of, an x-ray image, an MRI image, or a CT image. The methods can further comprise superimposing, by the local user, the volumetric image onto the local object. The superimposition can be performed automatically by a computer.

The methods can further comprise adjusting, by the local user, a property of the volumetric image. The property can be one or more of transparency, spatial location, and scale.

The methods can further comprise rendering a local tool in the local field of interest. The methods can further comprise rendering the local tool in accurate spatial relation to the rendering of the local object. The tool can be any type of tool, for example, a surgical tool.

In another aspect, provided are systems for virtual presence, comprising a virtual presence display, configured for displaying a common field of interest, a local sensor, configured for obtaining local virtual presence data, a network interface, configured for transmitting local virtual presence data and receiving remote virtual presence data, and a processor, coupled to the virtual presence display, the local sensor, and the network interface, wherein the processor is configured to perform steps comprising, rendering a common field of interest that reflects the physical presence of a remote user and a local user based on the local virtual presence data and the remote virtual presence data, rendering interaction between the remote user and the local user in the common field of interest, continuously updating the common field of interest such that the presence of the remote user is rendered in real time to the local user and the presence of the local user is rendered in real time to the remote user, and outputting the common field of interest to the virtual presence display.

The virtual presence display can be one or more of a stereoscopic display, a monoscopic display (such as a CRT, LCD, etc.), and the like. The sensor can be one or more of a camera, an infrared sensor, a depth scan sensor, and the like. The common field of interest can be rendered such that the remote user experiences the common field of interest similarly to the local user. The local user can experience the remote user's physical presence in a manner that enables continuous interaction in the common field of interest with the remote user.

The processor can be further configured to perform steps comprising rendering the physical presence of a local object in the common field of interest and rendering interaction between the local user and the local object in the common field of interest.

The processor can be further configured to perform steps comprising rendering the physical presence of a local object in the common field of interest and rendering interaction between the remote user and the local object in the common field of interest.

Further provided are systems for virtual presence, comprising a virtual presence display, configured for displaying a local field of interest, a local sensor, configured for obtaining local virtual presence data, a processor, coupled to the virtual presence display and the local sensor, wherein the processor is configured to perform steps comprising, rendering a local field of interest that reflects the physical presence of a local object and a local user based on the local virtual presence data and a volumetric image of the local object, rendering interaction between the local object, the volumetric image, and the local user in the local field of interest, continuously updating the local field of interest such that the presence of the local object and the volumetric image of the local object is rendered in real time to the local user, and outputting the local field of interest to the virtual presence display.

The virtual presence display can be one or more of a stereoscopic display, a monoscopic display (such as a CRT, LCD, etc.), and the like. The sensor can be one or more of a camera, an infrared sensor, a depth scan sensor, and the like.

The local object can be, for example, a patient and the volumetric image of the local object can be, for example, a medical image of a part of the patient. The medical image can be, for example, one of, an x-ray image, an MRI image, or a CT image. However, the local object can be any object of interest and the image of the local object can be any accurate rendering of that object. For example, could be an automobile engine and a 3D graphic of the engine, etc.

The processor can be further configured to perform steps comprising superimposing, by the local user, the volumetric image onto the local object. The processor can be further configured to perform steps comprising adjusting, by the local user, a property of the volumetric image. The property can be one or more of transparency, spatial location, and scale.

The processor can be further configured to perform steps comprising rendering a local tool in the local field of interest. The processor can be further configured to perform steps comprising rendering the local tool in accurate spatial relation to the rendered local object.

The disclosed methods and systems can have broad applications. For example, surgery, gaming, mechanics, munitions, battle field presence, instructional efforts (training) and/or any other situation where interaction is part of the scenario.

Also disclosed are methods and systems that enable a remote expert to be virtually present within a local surgical field. Virtual interactive presence can be used to enable two surgeons remote from each other to interactively perform a surgical procedure. The methods and system enable two or more operators to be virtually present, and interactive, within the same real operative field, thus supporting remote assistance and exporting surgical expertise.

The methods and systems can also be used to superimpose imaging data of the operative anatomy onto the anatomy itself for guidance and orientation (augmented reality). The methods and systems can be used for training of students. The methods and systems augment and enhance the field of robotics by virtually bringing an expert into the robotic field to guide the robot operator. The methods and systems are applicable to endoscopic procedures by inserting the expert's hands directly into the endoscopic field for guidance. The methods and systems expand remote surgery by providing the assistance of a remote expert to an actual local surgeon, whose basic skills can handle emergencies, and who will learn from the virtual interaction. The methods and systems can be used at trauma sites and other medical environments. The methods and systems can be used to provide remote assistance in other areas such as engineering, construction, architecture, and the like. The methods and systems disclosed can be used to transmit expertise to a remote ‘site of need’, merge contemporary imaging directly into the surgical field, and train surgical students

An exemplary remote surgical assistance system for transmitting surgical maneuvers of a local expert to a remote surgeon for the purpose of guiding/assisting the remote surgeon is illustrated in FIG. 13. The remote surgical field can be viewed by the remote surgeon with a binocular video system. The video system can show the field with his hands and instruments performing the procedure. The viewing system can be referred to as a surgical videoscope.

The binocular video rendering of the remote field can be transmitted to the local expert), who can view the (now virtual) stereoscopic rendering of the procedure through a second surgical videoscope system. The local expert can insert his hands into the virtual field, thus seeing his real hands within the virtual field.

The video image of the local expert's hands can be transmitted back to the remote surgeon's surgical videoscope system superimposed into the real field. The remote surgeon can then see the expert's virtual hands within his surgical field in a spatially/anatomically relevant context. With this system, the local expert can use his hands to show the remote surgeon how to perform the case.

Exemplary elements of the system can comprise a remote station where the remote surgeon can perform the operative procedure, a remote surgical videoscope system comprised of, for example, a fixed stereoscopic videoscope that may resemble a mounted microscope. This apparatus can be used by the remote surgeon to view the operative field. Any other type of suitable VIP display can be used. The system can project the binocular video image to a similar local surgical videoscope at a local station. The local surgical videoscope can receive the binocular video image of the remote procedure and allow the local expert to view it. The local videoscope can view the local surgeons hands as they move within the virtual remote field as viewed through the local videoscope. The local videoscope can then transmit the local expert's hands back to the remote videoscope so that the remote surgeon can see the expert's virtual hands within the real field.

With this system, the local expert can show the remote surgeon the appropriate maneuvers that result in successful completion of the case. The remote surgeon can have a basic skill set to carry out the new procedure. Therefore, the local expert can simply demonstrates to the remote surgeon new ways to apply the skill set. This system does not have to supplant the remote surgeon, but can be used to enhance his/her capability. The remote surgeon can be on hand to rapidly deal with any emergencies. Time delay is minimized because the remote surgeon can use his/her own hands to perform the task, eliminating the need for the local expert to manipulate remote robotic apparatuses.

Also disclosed are methods and systems for merging contemporary medical imaging onto an operative field. A volume image can be obtained of the operative field. For example, a volume MRI of the head, prior to the surgical procedure. The image data can be reconstructed into a three dimensional rendering of the anatomy. This rendering can be transmitted to the surgical videoscope that will be used to view the operative field. Through the videoscope, the surgeon can view this 3D rendering in a translucent manner superimposed onto the surgical field. In this case, the surgeon would see a rendered head superimposed on the real head. Using software tools in the surgical videoscope interface, the surgeon can rotate and scale the rendered image until it “fits” the real head. The videoscope system can allow the surgeon to differentially fade the rendered head and real head so that the surgeon can “look into” the real head and plan the surgery.

Exemplary elements of the system can comprise a surgical videoscope viewing system through which the surgeon views the surgical field. A computer for reconstruction of a volume-acquired MRI/CT (or other) image with sufficient resolution to enable matching it to the real surgical anatomy. The volume rendered image can be displayed through the videoscope system so that the surgeon can see it stereoscopically. A software interface can enable the surgeon to vary the translucency of the rendered and real anatomy so that the rendered anatomy can be superimposed onto the real anatomy. The surgeon can “open up” the rendered anatomy to view any/all internal details of the image as they relate to the real anatomy. Surgical tools can be spatially registered to the rendered anatomy so that behavior can be tracked and applied to the image.

As shown in FIG. 14, an example of such a task is placing small objects inside a jar of dark gelatin so that they are not visible to the surgeon. The task is for the surgeon to use a long forceps to reach into the gelatin and touch or grasp the objects. The Surgical Videoscope system can obtain a volume scan of the gelatin jar and render the jar in three dimensions and display a binocular rendering through the videoscope. The surgeon can view the rendering and the real jar through the scope system and fit the rendered jar onto the real jar. By differentially adjusting translucency, the surgeon can reach into the real jar with a forceps and grasp a selected object, while avoiding other designated objects.

The grasping instrument can be spatially registered onto the volumetric rendering of the surgical field, thereby allowing a graphic of the tool to be displayed on the rendering of the surgical field in appropriate anatomic orientation. This can provide enhanced guidance. This can be implemented by touching designated landmarks on the real object (jar) with a digitizer that communicates with the image rendering system, thus defining the object/probe relationship. Because the object (jar) is registered to the image of the jar by superimposition, a graphic of the probe can be displayed in relation to the image of the jar enabling virtual surgery.

There are many situations in which the present system can be used. For example, remote surgery, medical training, and tele-medicine, which can be used for third world countries or in a military situation. Surgeons remotely located from patients can assist other surgeons near the patient, can assist medics near the patient, and can perform surgical operations when coupled to a robotic surgery system. Other examples include, augmented or enhanced surgery—normal surgery using virtual environments, an example of which is endoscopic surgery. Surgical procedures can also be simulated. Surgeons located remote from each other may plan and practice a procedure before carrying out the operation on a real patient.

Other applications include the preparation of patient before surgery, medical therapy, preventative medicine, exposure therapy, reducing phobias, training people with disabilities and skill enhancement, and the like.

The viewer then views the projection through passive stereoscopic polarized glasses (similar to sunglasses) that route the left-eye image to the left eye, and the right-eye image to the right eye. This provides an illusion of stereopsis when the correctly-offset images are properly rendered by the software. The system can be replaced by other types of stereoscopic displays with no functional detriment to the system. The stereoscopic display can comprise at least two display projectors fitted with polarizing lenses, a back-projection screen material that maintains light polarization upon diffusion, special glasses that restrict each eye to see only light of a particular polarization, and the viewer. The image to be viewed can be rendered with two slightly different view transformations, reflecting the different locations of the ideal viewer's two eyes. One projector displays the image rendered for the left eye's position, and the other projector displays the image rendered for the right eye's position. The glasses restrict the light so that the left eye sees only the image rendered for it, and the right eye sees only the image rendered for it. The viewer, presented with a reasonable stereoscopic image, will perceive depth.

FIG. 15 is a block diagram illustrating an exemplary operating environment for performing the disclosed methods. This exemplary operating environment is only an example of an operating environment and is not intended to suggest any limitation as to the scope of use or functionality of operating environment architecture. Neither should the operating environment be interpreted as having any dependency or requirement relating to any one or combination of components illustrated in the exemplary operating environment.

The methods can be operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the system and method include, but are not limited to, personal computers, server computers, laptop devices, and multiprocessor systems. Additional examples include set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.

The methods may be described in the general context of computer instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. The system and method may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.

The methods disclosed herein can be implemented via one or more general-purpose computing devices in the form of a computer 1501. The components of the computer 1501 can include, but are not limited to, one or more processors or processing units 1503, a system memory 1512, and a system bus 1513 that couples various system components including the processor 1503 to the system memory 1512.

The system bus 1513 represents one or more of several possible types of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures. By way of example, such architectures can include an Industry Standard Architecture (ISA) bus, a Micro Channel Architecture (MCA) bus, an Enhanced ISA (EISA) bus, a Video Electronics Standards Association (VESA) local bus, and a Peripheral Component Interconnects (PCI) bus also known as a Mezzanine bus. This bus, and all buses specified in this description can also be implemented over a wired or wireless network connection. The bus 1513, and all buses specified in this description can also be implemented over a wired or wireless network connection and each of the subsystems, including the processor 1503, a mass storage device 1504, an operating system 1505, application software 1506, data 1507, a network adapter 1508, system memory 1512, an Input/Output Interface 1510, a display adapter 1509, a display device 1511, and a human machine interface 1502, can be contained within one or more remote computing devices 1514a,b,c at physically separate locations, connected through buses of this form, in effect implementing a fully distributed system.

The computer 1501 typically includes a variety of computer readable media. Such media can be any available media that is accessible by the computer 1501 and includes both volatile and non-volatile media, removable and non-removable media. The system memory 1512 includes computer readable media in the form of volatile memory, such as random access memory (RAM), and/or non-volatile memory, such as read only memory (ROM). The system memory 1512 typically contains data such as data 1507 and/or program modules such as operating system 1505 and application software 1506 that are immediately accessible to and/or are presently operated on by the processing unit 1503.

The computer 1501 may also include other removable/non-removable, volatile/non-volatile computer storage media. By way of example, FIG. 15 illustrates a mass storage device 1504 which can provide non-volatile storage of computer code, computer readable instructions, data structures, program modules, and other data for the computer 1501. For example, a mass storage device 1504 can be a hard disk, a removable magnetic disk, a removable optical disk, magnetic cassettes or other magnetic storage devices, flash memory cards, CD-ROM, digital versatile disks (DVD) or other optical storage, random access memories (RAM), read only memories (ROM), electrically erasable programmable read-only memory (EEPROM), and the like.

Any number of program modules can be stored on the mass storage device 1504, including by way of example, an operating system 1505 and application software 1506. Each of the operating system 1505 and application software 1506 (or some combination thereof) may include elements of the programming and the application software 1506. Data 1507 can also be stored on the mass storage device 1504. Data 1507 can be stored in any of one or more databases known in the art. Examples of such databases include, DB2®, Microsoft® Access, Microsoft® SQL Server, Oracle®, mySQL, PostgreSQL, and the like. The databases can be centralized or distributed across multiple systems.

A user can enter commands and information into the computer 1501 via an input device (not shown). Examples of such input devices include, but are not limited to, a keyboard, pointing device (e.g., a “mouse”), a microphone, a joystick, a serial port, a scanner, tactile input devices such as gloves, and other body coverings, and the like. These and other input devices can be connected to the processing unit 1503 via a human machine interface 1502 that is coupled to the system bus 1513, but may be connected by other interface and bus structures, such as a parallel port, game port, or a universal serial bus (USB).

A display device 1511 can also be connected to the system bus 1513 via an interface, such as a display adapter 1509. A computer 1501 can have more than one display adapter 1509 and a computer 1501 can have more than one display device 1511. For example, a display device can be a monitor, an LCD (Liquid Crystal Display), or a projector. In addition to the display device 1511, other output peripheral devices can include components such as speakers (not shown) and a printer (not shown) which can be connected to the computer 1501 via Input/Output Interface 1510.

The computer 1501 can operate in a networked environment using logical connections to one or more remote computing devices 1514a,b,c. By way of example, a remote computing device can be a personal computer, portable computer, a server, a router, a network computer, a peer device or other common network node, and so on. Logical connections between the computer 1501 and a remote computing device 1514a,b,c can be made via a local area network (LAN) and a general wide area network (WAN). Such network connections can be through a network adapter 1508. A network adapter 1508 can be implemented in both wired and wireless environments. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets, and the Internet 1515.

One or more VIP displays 1516a,b,c,d,e can communicate with the computer 1501. In one aspect, VIP display 1516 e can communicate with computer 1501 through the input/output interface 1510. This communication can be wired or wireless. Remote VIP displays 1516a,b,c can communicate with computer 1501 by communicating first with a respective remote computing device 1514a,b,c which then communicates with computer 1501 through the network adapter 1508 via a network such as the Internet 1515. Remote VIP display 1516 d can communicate with computer 1501 without the need for a remote computing device. Remote VIP display 1516d can communicate via a network, such as the Internet 1515. The VIP displays 1516a,b,c,d,e can communicate wireless or through a wired connection. The VIP displays 1516a,b,c,d,e can communicate individual or collectively as part of a VIP display network.

For purposes of illustration, application programs and other executable program components such as the operating system 1505 are illustrated herein as discrete blocks, although it is recognized that such programs and components reside at various times in different storage components of the computing device 1501, and are executed by the data processor(s) of the computer. An implementation of application software 1506 may be stored on or transmitted across some form of computer readable media. Computer readable media can be any available media that can be accessed by a computer. By way of example, and not limitation, computer readable media may comprise “computer storage media” and “communications media.” “Computer storage media” include volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules, or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by a computer.

Unless otherwise expressly stated, it is in no way intended that any method set forth herein be construed as requiring that its steps be performed in a specific order. Accordingly, where a method claim does not actually recite an order to be followed by its steps or it is not otherwise specifically stated in the inventive concepts or descriptions that the steps are to be limited to a specific order, it is no way intended that an order be inferred, in any respect. This holds for any possible non-express basis for interpretation, including: matters of logic with respect to arrangement of steps or operational flow; plain meaning derived from grammatical organization or punctuation; the number or type of embodiments described in the specification.

It will be apparent to those skilled in the art that various modifications and variations can be made in the present methods and systems without departing from the scope or spirit. Other embodiments will be apparent to those skilled in the art from consideration of the specification and practice disclosed herein. It is intended that the specification and examples be considered as exemplary only, with a true scope and spirit being indicated by the following claims.

Guthrie, Barton L., Dillavou, Marcus W., Shum, Phillip Corey, Shenai, Mahesh B., Deaton, Drew Steven, May, Matthew Benton

Patent Priority Assignee Title
11382712, Dec 22 2019 AUGMEDICS LTD.; AUGMEDICS LTD Mirroring in image guided surgery
11389252, Jun 15 2020 AUGMEDICS LTD. Rotating marker for image guided surgery
11750794, Mar 24 2015 AUGMEDICS LTD. Combining video-based and optic-based augmented reality in a near eye display
11766296, Nov 26 2018 AUGMEDICS LTD Tracking system for image-guided surgery
11801115, Dec 22 2019 AUGMEDICS LTD. Mirroring in image guided surgery
11896445, Jul 07 2021 AUGMEDICS LTD. Iliac pin and adapter
Patent Priority Assignee Title
3931679, Nov 05 1973 HUNTINGTON NATIONAL BANK THE Dental patient simulator
4601664, Mar 18 1985 DENTAL-EZ, INC Temporomandibular joint articulator and dental manikin incorporating it
4970666, Mar 30 1988 Land Development Laboratory, Inc. Computerized video imaging system for creating a realistic depiction of a simulated object in an actual environment
5102340, Dec 14 1989 Kaltenbach & Voigt GmbH & Co. Dental teaching and practicing apparatus
5391081, May 13 1992 UNIVERSITSY OF FLORIDA RESEARCH FOUNDATION, INCORPORTED Method and apparatus for simulating neuromuscular stimulation during medical surgery
5403192, May 10 1993 MEDSIM - EAGLE SIMULATION, INC Simulated human lung for anesthesiology simulation
5584701, May 12 1992 University of Florida Research Foundation, Incorporated Self regulating lung for simulated medical procedures
5668608, Jul 26 1995 QUARTERHILL INC ; WI-LAN INC Motion vector estimation method and apparatus for use in an image signal encoding system
5769641, May 13 1992 University of Florida Research Foundation, Incorporated Apparatus and method for synchronizing cardiac rhythm related events
5772442, May 13 1992 FLORIDA UNIVERSITY OF RESEARCH FOUNDATION, INC , Apparatus and method for simulating bronchial resistance or dilation
5779484, May 13 1992 University of Florida Research Foundation Apparatus and method of stimulating breathing sounds
5853292, May 08 1996 GAUMARD SCIENTIFIC COMPANY, INC ; GAUMARD SCIENTIFC COMPANY, INC Computerized education system for teaching patient care
5868579, May 13 1992 UNIVERSITY OF FLORIDA RESEARCH FOUNDATION, INC Apparatus and method for simulating lung sounds in a patient simulator
5882207, May 13 1992 University of Florida Research Foundation Apparatus and method for quantifying fluid delivered to a patient simulator
5890908, May 13 1992 University of Florida Research Foundation Apparatus for and method of simulating the injection and volatilizing of a volatile drug
5900923, Nov 26 1996 MEDSIM USA, INC ; MEDSIM INC ; MEDSIM LTD Patient simulator eye dilation device
5941710, May 13 1992 FLORIDA, UNIVERSITY OF, RESEARCH FOUNDATION, INC Apparatus and method of simulating the determination of continuous blood gases in a patient simulator
6042477, Dec 12 1996 Gula Consulting Limited Liability Company Method of and system for minimizing the effects of time latency in multiplayer electronic games played on interconnected computers
6157677, Mar 22 1995 IDT International Digital Technologies Deutschland GmbH Method and apparatus for coordination of motion determination over multiple frames
6166744, Nov 26 1997 Microsoft Technology Licensing, LLC System for combining virtual images with real-world scenes
6193519, May 08 1996 GAUMARD SCIENTIFIC COMPANY, INC Computerized education system for teaching patient care
6220866, Jan 15 1998 MEDSIM USA, INC ; MEDSIM INC ; MEDSIM LTD Electronic auscultation system for patient simulator
6241609, Jan 09 1998 U.S. Philips Corporation Virtual environment viewpoint control
6246975, Oct 30 1996 AMERICAN BOARD OF FAMILY MEDICINE, INC Computer architecture and process of patient generation, evolution, and simulation for computer based testing system
6257234, Aug 21 1998 RIC Investments, LLC Apparatus and method for determining respiratory mechanics of a patient and for controlling a ventilator based thereon
6273728, Sep 04 1997 FLORIDA, UNIVERSITY OF, THE Life support simulation system simulating human physiological parameters
6293519, Jul 07 1997 Luminous snake
6301339, Sep 06 1996 DATA RACE, INC System and method for providing a remote user with a virtual presence to an office
6317165, Jul 29 1998 S3 GRAPHICS CO , LTD System and method for selective capture of video frames
6443735, May 08 1996 GAUMARD SCIENTIFIC COMPANY, INC ; GAUMARD SCIENTIFIC, INC Computerized education system for teaching patient care
6461165, Jul 03 1998 Kyoto Kagaku Company Ltd. Cardiology patient simulator
6503087, May 08 1996 GAUMARD SCIENTIFIC COMPANY, INC ; GAUMARD SCIENTIFIC, INC Interactive education system for teaching patient care
6527558, May 08 1996 GAUMARD SCIENTIFIC COMPANY, INC ; GAUMARD SCIENTIFIC, INC Interactive education system for teaching patient care
6535714, Jul 02 2001 FLORIDA, UNIVERSITY OF Method, system, and apparatus for medical device training
6570563, Jul 12 1995 Sony Corporation Method and system for three-dimensional virtual reality space sharing and for information transmission
6608628, Nov 06 1998 Administrator of the National Aeronautics and Space Administration Method and apparatus for virtual interactive medical imaging by multiple remotely-located users
6692258, Jun 26 2000 MEDICAL LEARNING COMPANY, INC Patient simulator
6697451, Sep 05 2001 GE Medical Systems Global Technology Company, LLC Dynamic phantom and method for evaluating calcium scoring
6747672, Nov 01 1999 MEDICAL LEARNING COMPANY, INC Virtual patient hot spots
6747674, Nov 06 1998 Sony Corporation Image processing apparatus, image processing method, and information providing medium
6758676, May 08 1996 Gaumard Scientific Company, Inc. Interactive education system for teaching patient care
6774855, Jun 24 2002 TE Connectivity Solutions GmbH Omni-directional antenna arrays and methods of making the same
6774885, Jan 20 1999 MOTEK B V System for dynamic registration, evaluation, and correction of functional human behavior
6780016, Oct 23 2000 Human surgical trainer and methods for training
6921267, Dec 06 2002 University of Florida Research Foundation, Incorporated Lung simulator for an integrated human patient simulator
7015954, Aug 09 1999 Fuji Xerox Co., Ltd. Automatic video system using multiple cameras
7176975, Jun 19 2001 Casio Computer Co., Ltd. Image pick-up apparatus, image pick-up method, and storage medium that records image pick-up method program
7181690, Nov 12 1996 WORLDS INC System and method for enabling users to interact in a virtual space
7190331, Jun 06 2002 Siemens Corporation System and method for measuring the registration accuracy of an augmented reality system
7259761, Jul 17 1998 3D Systems, Inc Systems and methods for sculpting virtual objects in a haptic virtual reality environment
7367809, Mar 26 2004 Three-dimensional digital entity mesoscope system equipped with three-dimensional visual instruction functions
7373377, Oct 16 2002 QUANTUM IMAGING LLC Interactive virtual thematic environment
7376903, Jun 29 2004 GE Medical Systems Information Technologies 3D display system and method
7403664, Feb 26 2004 Mitsubishi Electric Research Laboratories, Inc.; Mitsubishi Electric Research Laboratories, Inc Traffic event detection in compressed videos
7728852, Mar 31 2004 Canon Kabushiki Kaisha Image processing method and image processing apparatus
7728868, Aug 02 2006 INNEROPTIC TECHNOLOGY, INC System and method of providing real-time dynamic imagery of a medical procedure site using multiple modalities
7787927, Jun 20 2003 MERATIVE US L P System and method for adaptive medical image registration
7815644, Dec 19 2003 MedIdea, LLC Instrumentation and methods for refining image-guided and navigation-based surgical procedures
7949616, Jun 01 2004 Telepresence by human-assisted remote controlled devices and robots
8046408, Aug 20 2001 Sound View Innovations, LLC Virtual reality systems and methods
8179412, Aug 19 2009 Eastman Kodak Company Merging image pixels based on main-scan misalignment
8336777, Dec 22 2008 L-3 Insight Technology Incorporated Covert aiming and imaging devices
8385687, Dec 06 2006 MATROX ELECTRONIC SYSTEMS, LTD Methods for determining a transformation between images
8398541, Jun 06 2006 Intuitive Surgical Operations, Inc Interactive user interfaces for robotic minimally invasive surgical systems
8520024, May 18 2007 UAB Research Foundation Virtual interactive presence systems and methods
8902248, Jul 14 2011 VMware LLC Method and system for measuring display performance of a remote application
9020203, May 21 2012 HELP LIGHTNING, INC System and method for managing spatiotemporal uncertainty
9210312, Jun 02 2004 Bosch Security Systems, Inc.; Robert Bosch GmbH Virtual mask for use in autotracking video camera images
20010026630,
20020049510,
20030219146,
20040009459,
20040091845,
20040161731,
20040189701,
20040193441,
20040260170,
20050074154,
20050197818,
20050203367,
20050203380,
20050267778,
20050273185,
20050289472,
20060187224,
20070018975,
20070048702,
20070055578,
20070064098,
20070149290,
20070248261,
20080024594,
20080025640,
20080031611,
20080055305,
20080079752,
20080123910,
20080123927,
20080158333,
20080231626,
20080278633,
20090058987,
20090287089,
20090300122,
20100141555,
20100226564,
20100241953,
20100295921,
20100315418,
20110018959,
20110084983,
20110116703,
20110135206,
20110183182,
20110188744,
20110216060,
20110249029,
20110270135,
20120133786,
20120201456,
20120263154,
20120320157,
20120324332,
20130038632,
20130083063,
20140176533,
20150002541,
AU2008270883,
AU2012295324,
CA2694095,
CN101405769,
CN101743567,
CN104011741,
CN1392724,
CN1929602,
EP1804209,
EP2163092,
EP2742461,
IN7420CHENP2009,
JP2002074370,
JP2007535875,
JP2009134693,
JP2010141476,
JP2010508631,
JP2010528354,
JP2013024298,
JP5227463,
NZ582133,
NZ621149,
WO49475,
WO1996009722,
WO2000948475,
WO2005119554,
WO2006108279,
WO2007059477,
WO2009005901,
WO2013025457,
WO2013177125,
WO2014105961,
///
Executed onAssignorAssigneeConveyanceFrameReelDoc
May 04 2017Help Lightning, Inc.(assignment on the face of the patent)
May 04 2017UAB Research Foundation(assignment on the face of the patent)
Mar 08 2024HELP LIGHTNING, INC COMERICA BANKSECURITY INTEREST SEE DOCUMENT FOR DETAILS 0667420259 pdf
Date Maintenance Fee Events
Aug 03 2022M2551: Payment of Maintenance Fee, 4th Yr, Small Entity.
Aug 03 2022M2554: Surcharge for late Payment, Small Entity.


Date Maintenance Schedule
Jan 15 20224 years fee payment window open
Jul 15 20226 months grace period start (w surcharge)
Jan 15 2023patent expiry (for year 4)
Jan 15 20252 years to revive unintentionally abandoned end. (for year 4)
Jan 15 20268 years fee payment window open
Jul 15 20266 months grace period start (w surcharge)
Jan 15 2027patent expiry (for year 8)
Jan 15 20292 years to revive unintentionally abandoned end. (for year 8)
Jan 15 203012 years fee payment window open
Jul 15 20306 months grace period start (w surcharge)
Jan 15 2031patent expiry (for year 12)
Jan 15 20332 years to revive unintentionally abandoned end. (for year 12)