Navigation of tubular networks

Information

  • Patent Grant
  • 11403759
  • Patent Number
    11,403,759
  • Date Filed
    Thursday, August 27, 2020
    3 years ago
  • Date Issued
    Tuesday, August 2, 2022
    a year ago
Abstract
Methods and apparatuses provide improved navigation through tubular networks such as lung airways by providing improved estimation of location and orientation information of a medical instrument (e.g., an endoscope) within the tubular network. Various input data such as image data, EM data, and robot data are used by different algorithms to estimate the state of the medical instrument, and the state information is used to locate a specific site within a tubular network and/or to determine navigation information for what positions/orientations the medical instrument should travel through to arrive at the specific site. Probability distributions together with confidence values are generated corresponding to different algorithms are used to determine the medical instrument's estimated state.
Description
BACKGROUND
1. Field of Art

This description generally relates to surgical robotics, and particularly to navigation of a medical instrument within a tubular network of a patient's body.


2. Description of the Related Art

Bronchoscopy is a medical procedure that, allows a physician to examine the inside conditions of a patient's lung airways, such as bronchi and bronchioles. The lung airways carry air from the trachea, or windpipe, to the lungs. During the medical procedure, a thin, flexible tubular tool, known as a bronchoscope, may be inserted into the patient's mouth and passed down the patient's throat into his/her lung airways, and patients are generally anesthetized in order to relax their throats and lung cavities for surgical examinations and operations during the medical procedure.


A conventional bronchoscope typically includes a light source and a small camera that allows a physician to inspect a patient's windpipe and airways, and a rigid tube may be used in conjunction with the bronchoscope for surgical purposes, e.g., when there is a significant amount of bleeding in the lungs of the patient or when a large object obstructs the throat of the patient. When the rigid tube is used, the patient is often anesthetized. Coincident with the rise of other advanced medical devices, the use of robotic bronchoscopes are increasingly becoming a reality. Robotic bronchoscopes provide tremendous advantages in navigation through tubular networks. They are easy to use and allow therapy and biopsies to be administered conveniently even during the bronchoscopy stage.


Apart from mechanical devices or platforms, e.g., robotic bronchoscopes described above, various methods and software models may be used to help with the surgical operations. As an example, a computerized tomography (CT) scan of the patient's lungs is often performed during pre-operation of a surgical examination. Data from the CT scan may be used to generate a three dimensional (3D) model of airways of the patient's lungs, and the generated 3D model enables a physician to access a visual reference that may be useful during the operative procedure of the surgical examination.


However, previous techniques for navigation of tubular networks still have challenges, even when employing medical devices (e.g., robotic bronchoscopes) and when using existing methods (e.g., performing CT scans and generating 3D models). As one example, motion estimation of a medical device (e.g., a bronchoscope tool) inside a patient's body may not be accurate based on location and orientation change of the device, and as a result the device's position may not be accurately or correctly localized inside the patient's body in real time. Inaccurate location information for such an instrument may provide misleading information to the physician that uses the 3D model as a visual reference during medical operation procedures.


Thus, there is a need for improved techniques for navigating through a network of tubular structures.


SUMMARY

The methods and apparatus disclosed herein provide improved navigation through tubular networks such as lung airways by providing improved estimation of location and orientation information of a medical instrument like a flexible or rigid elongated medical instrument (e.g., an endoscope) within the tubular network.


As one example, the apparatus is a robotic endoscopic tool to acquire “raw” location and orientation information (collectively, input data) of a desired anatomical site or of the endoscopic tool within the tubular network. The endoscopic tool includes a flexible tip and an instrument device manipulator (IDM) coupled to the endoscopic tool. Devices such as an electromagnetic sensor (EM sensor), an imaging device (e.g., optical sensor), and a robotic control system controlling the medical instrument are coupled to the instrument tip to collect the input data as the endoscopic tool enters and navigates through the tubular network. The IDM is used to control movement and position of different robotic components (e.g., the endoscopic tool) of the surgical robotic system. A processor is coupled to the endoscopic tool to receive the input data to determine moment-by-moment movements and location and orientation information of the medical instrument (e.g., a instrument tip) within the tubular network.


The processor is instructed by a navigation configuration system to use the input data to estimate the state of the medical instrument, which may include information such as position, orientation, relative and absolute depth, branch selection, etc. The processor may be further instructed to use the estimated state to locate a specific site within a tubular network and/or to determine navigation information for what positions/orientations the medical instrument should travel through to arrive at the specific site, which may be referred to as the output data or navigation data.


The navigation configuration system further includes multiple algorithm modules employing various navigation algorithms for providing the estimated state and navigation data. Example algorithms used include EM-based algorithms, image-based algorithms, and robot-based algorithms. The estimated state and navigation data generated after employing these various algorithms makes use of any one or more of the EM-based input data, image-based input data, and robot-based input data.


In some embodiments, probability distributions together with confidence values are generated by the algorithm modules, which are used to determine the medical instrument's estimated state. The “probability” of the “probability distribution”, as used herein, refers to a likelihood of an estimation or identification of location and/or orientation of the medical instrument being correct. For example, different probabilities may be calculated indicating the relative likelihood that the medical instrument is in one of several different possible airways within the lung. In contrast, the “confidence value, as used herein, reflects a measure of confidence in the estimation of the state provided by one of the algorithms. For example, relatively close to the airway opening, a particular algorithm may have a high confidence in its estimations of medical instrument position and orientation; but further into the bottom of the lung the medical instrument travels, that confidence value may drop. Generally, the confidence value is based on one or more “external” factors relating to the process by which a result is determined, whereas probability is a relative measure that arises when trying to determine possible results from a single algorithm. The algorithms, probabilities, and confidence values may be variously combined to arrive at the estimated state and navigation data.


In one embodiment, before executing an actual surgical operation on a patient, a sequence of pre-operative steps employing the improved navigation of surgical instruments (e.g., endoscopic) within a tubular network of the patient may be taken. Initially, a CT scan of the tubular network is obtained to generate a 3D model of the tubular network. A target area (e.g., a lesion to biopsy) within the tubular network is selected and a corresponding path for a surgical instrument to travel through the tubular network to reach the target area is automatically planned and displayed to a user (e.g., a physician responsible for the surgical operation). After the path is determined, a virtual endoscopic may be applied to travel through the tubular network to arrive at the target area. In the actual surgical operation, the CT scan, the generated 3D model as well as other input data (e.g., image data, EM data, robot data collected over the duration of the surgery) is combined and repeatedly analyzed during the surgery via the surgical configuration system to provide an estimation of the real-time movement information and location/orientation information of the surgical instrument (e.g., the endoscope) within the tubular network along with navigation information, which allows for more convenient operations by the physician.





BRIEF DESCRIPTION OF DRAWINGS


FIG. 1A shows an example surgical robotic system, according to one embodiment.



FIGS. 1B-1F show various perspective views of a robotic platform coupled to the surgical robotic system shown in FIG. 1A, according to one embodiment.



FIG. 2 shows an example command console for the example surgical robotic system, according to one embodiment.



FIG. 3A shows an isometric view of an example independent drive mechanism of the instrument device manipulator (IDM) shown in FIG. 1A, according to one embodiment.



FIG. 3B shows a conceptual diagram that shows how forces may be measured by a strain gauge of the independent drive mechanism shown in FIG. 3A, according to one embodiment.



FIG. 4A shows a top view of an example endoscope, according to one embodiment.



FIG. 4B shows an example endoscope tip of the endoscope shown in FIG. 4A, according to one embodiment.



FIG. 5 shows an example schematic setup of an EM tracking system included in a surgical robotic system, according to one embodiment.



FIGS. 6A-6B show an example anatomical lumen and an example 3D model of the anatomical lumen, according to one embodiment.



FIG. 7 shows a computer-generated 3D model representing an anatomical space, according to one embodiment.



FIGS. 8A-8D show example graphs illustrating on-the-fly registration of an EM system to a 3D model of a path through a tubular network, according to one embodiment.



FIGS. 8E-8F show effect of an example registration of the EM system to a 3D model of a branched tubular network, according to one embodiment.



FIG. 9A shows a high-level overview of an example block diagram of a navigation configuration system, according to one embodiment.



FIG. 9B shows an example block diagram of the navigation module shown in FIG. 9A, according to one embodiment.



FIG. 9C shows an example block diagram of the estimated state data store included in the state estimator, according to one embodiment.



FIG. 10A shows an example block diagram of the EM registration module, according to one embodiment.



FIG. 10B shows an example block diagram of the branch selection module, according to one embodiment.



FIG. 10C shows an example block diagram of the motion estimation module, according to one embodiment.



FIG. 10D shows an example block diagram of the object detection module, according to one example.



FIG. 10E shows an example block diagram of the object mapping module, according to one embodiment.



FIG. 10F shows an example block diagram of the topological reasoning module, according to one embodiment.



FIG. 11A shows two example identified objects superimposed on an image of a bronchial network along with a link connecting centers of the two objects, according to one embodiment.



FIG. 11B shows a matching between airway lumens in an actual image of a real bronchial network and a 3D model of the network, according to on embodiment.



FIG. 12 shows an example process of generating a probability distribution over multiple values of an estimated state by the state estimator, according to one embodiment.



FIG. 13 shows an example of how an error can be corrected with navigation through a tubular network of bronchial tubes by the navigation configuration system, according to one embodiment.



FIG. 14A shows an example pre-operative sequence of steps of a method for navigating the instrument tip to a particular site within the tubular network, according to one embodiment.



FIG. 14B shows an example user interface for navigation of a surgical instrument through a tubular network, according to one embodiment.



FIG. 14C shows an example user interface for tool alignment and control during an endoscopic procedure, according to one embodiment.





Reference will now be made in detail to several embodiments, examples of which are illustrated in the accompanying figures. It is noted that wherever practicable similar or like reference numbers may be used in the figures and may indicate similar or like functionality. The figures depict embodiments of the described system (or method) for purposes of illustration only. One skilled in the art will readily recognize from the following description that alternative embodiments of the structures and methods illustrated herein may be employed without departing from the principles described herein.


DETAILED DESCRIPTION OF DRAWINGS
I. Surgical Robotic System


FIG. 1A shows an example surgical robotic system 100, according to one embodiment. The surgical robotic system 100 includes a base 101 coupled to one or more robotic arms, e.g., robotic arm 102. The base 101 is communicatively coupled to a command console, which is further described with reference to FIG. 2 in Section II. COMMAND CONSOLE. The base 101 can be positioned such that the robotic arm 102 has access to perform a surgical procedure on a patient, while a user such as a physician may control the surgical robotic system 100 from the comfort of the command console. In some embodiments, the base 101 may be coupled to a surgical operating table or bed for supporting the patient. Though not shown in FIG. 1 for purposes of clarity, the base 101 may include subsystems such as control electronics, pneumatics, power sources, optical sources, and the like. The robotic arm 102 includes multiple arm segments 110 coupled at joints 111, which provides the robotic arm 102 multiple degrees of freedom, e.g., seven degrees of freedom corresponding to seven arm segments. The base 101 may contain a source of power 112, pneumatic pressure 113, and control and sensor electronics 114—including components such as a central processing unit, data bus, control circuitry, and memory—and related actuators such as motors to move the robotic arm 102. The electronics 114 in the base 101 may also process and transmit control signals communicated from the command console.


In some embodiments, the base 101 includes wheels 115 to transport the surgical robotic system 100. Mobility of the surgical robotic system 100 helps accommodate space constraints in a surgical operating room as well as facilitate appropriate positioning and movement of surgical equipment. Further, the mobility allows the robotic arms 102 to be configured such that the robotic arms 102 do not interfere with the patient, physician, anesthesiologist, or any other equipment. During procedures, a user may control the robotic arms 102 using control devices such as the command console.


In some embodiments, the robotic arm 102 includes set up joints that use a combination of brakes and counter-balances to maintain a position of the robotic arm 102. The counter-balances may include gas springs or coil springs. The brakes, e.g., fail safe brakes, may be include mechanical and/or electrical components. Further, the robotic arms 102 may be gravity-assisted passive support type robotic arms.


Each robotic arm 102 may be coupled to an instrument device manipulator (IDM) 117 using a mechanism changer interface (MCI) 116. The IDM 117 can be removed and replaced with a different type of IDM, for example, a first type of IDM manipulates an endoscope, while a second type of IDM manipulates a laparoscope. The MCI 116 includes connectors to transfer pneumatic pressure, electrical power, electrical signals, and optical signals from the robotic arm 102 to the IDM 117. The MCI 116 can be a set screw or base plate connector. The IDM 117 manipulates surgical instruments such as the endoscope 118 using techniques including direct drive, harmonic drive, geared drives, belts and pulleys, magnetic drives, and the like. The MCI 116 is interchangeable based on the type of IDM 117 and can be customized for a certain type of surgical procedure. The robotic 102 arm can include a joint level torque sensing and a wrist at a distal end, such as the KUKA AG® LBR5 robotic arm.


The endoscope 118 is a tubular and flexible surgical instrument that is inserted into the anatomy of a patient to capture images of the anatomy (e.g., body tissue). In particular, the endoscope 118 includes one or more imaging devices (e.g., cameras or other types of optical sensors) that capture the images. The imaging devices may include one or more optical components such as an optical fiber, fiber array, or lens. The optical components move along with the tip of the endoscope 118 such that movement of the tip of the endoscope 118 results in changes to the images captured by the imaging devices. The endoscope 118 is further described with reference to FIGS. 3A-4B in Section IV. Endoscope.


Robotic arms 102 of the surgical robotic system 100 manipulate the endoscope 118 using elongate movement members. The elongate movement members may include pull wires, also referred to as pull or push wires, cables, fibers, or flexible shafts. For example, the robotic arms 102 actuate multiple pull wires coupled to the endoscope 118 to deflect the tip of the endoscope 118. The pull wires may include both metallic and non-metallic materials such as stainless steel, Kevlar, tungsten, carbon fiber, and the like. The endoscope 118 may exhibit nonlinear behavior in response to forces applied by the elongate movement members. The nonlinear behavior may be based on stiffness and compressibility of the endoscope 118, as well as variability in slack or stiffness between different elongate movement members.



FIGS. 1B-1F show various perspective views of the surgical robotic system 100 coupled to a robotic platform 150 (or surgical bed), according to various embodiments. Specifically, FIG. 1B shows a side view of the surgical robotic system 100 with the robotic arms 102 manipulating the endoscopic 118 to insert the endoscopic inside a patient's body, and the patient is lying on the robotic platform 150. FIG. 1C shows a top view of the surgical robotic system 100 and the robotic platform 150, and the endoscopic 118 manipulated by the robotic arms is inserted inside the patient's body. FIG. 1D shows a perspective view of the surgical robotic system 100 and the robotic platform 150, and the endoscopic 118 is controlled to be positioned horizontally parallel with the robotic platform. FIG. 1E shows another perspective view of the surgical robotic system 100 and the robotic platform 150, and the endoscopic 118 is controlled to be positioned relatively perpendicular to the robotic platform. In more detail, in FIG. 1E, the angle between the horizontal surface of the robotic platform 150 and the endoscopic 118 is 75 degree. FIG. 1F shows the perspective view of the surgical robotic system 100 and the robotic platform 150 shown in FIG. 1E, and in more detail, the angle between the endoscopic 118 and the virtual line 160 connecting one end 180 of the endoscopic and the robotic arm 102 that is positioned relatively farther away from the robotic platform is 90 degree.


II. Command Console


FIG. 2 shows an example command console 200 for the example surgical robotic system 100, according to one embodiment. The command console 200 includes a console base 201, display modules 202, e.g., monitors, and control modules, e.g., a keyboard 203 and joystick 204. In some embodiments, one or more of the command console 200 functionality may be integrated into a base 101 of the surgical robotic system 100 or another system communicatively coupled to the surgical robotic system 100. A user 205, e.g., a physician, remotely controls the surgical robotic system 100 from an ergonomic position using the command console 200.


The console base 201 may include a central processing unit, a memory unit, a data bus, and associated data communication ports that are responsible for interpreting and processing signals such as camera imagery and tracking sensor data, e.g., from the endoscope 118 shown in FIG. 1. In some embodiments, both the console base 201 and the base 101 perform signal processing for load-balancing. The console base 201 may also process commands and instructions provided by the user 205 through the control modules 203 and 204. In addition to the keyboard 203 and joystick 204 shown in FIG. 2, the control modules may include other devices, for example, computer mice, trackpads, trackballs, control pads, video game controllers, and sensors (e.g., motion sensors or cameras) that capture hand gestures and finger gestures.


The user 205 can control a surgical instrument such as the endoscope 118 using the command console 200 in a velocity mode or position control mode. In velocity mode, the user 205 directly controls pitch and yaw motion of a distal end of the endoscope 118 based on direct manual control using the control modules. For example, movement on the joystick 204 may be mapped to yaw and pitch movement in the distal end of the endoscope 118. The joystick 204 can provide haptic feedback to the user 205. For example, the joystick 204 vibrates to indicate that the endoscope 118 cannot further translate or rotate in a certain direction. The command console 200 can also provide visual feedback (e.g., pop-up messages) and/or audio feedback (e.g., beeping) to indicate that the endoscope 118 has reached maximum translation or rotation.


In position control mode, the command console 200 uses a three-dimensional (3D) map of a patient and pre-determined computer models of the patient to control a surgical instrument, e.g., the endoscope 118. The command console 200 provides control signals to robotic arms 102 of the surgical robotic system 100 to manipulate the endoscope 118 to a target location. Due to the reliance on the 3D map, position control mode requires accurate mapping of the anatomy of the patient.


In some embodiments, users 205 can manually manipulate robotic arms 102 of the surgical robotic system 100 without using the command console 200. During setup in a surgical operating room, the users 205 may move the robotic arms 102, endoscopes 118, and other surgical equipment to access a patient. The surgical robotic system 100 may rely on force feedback and inertia control from the users 205 to determine appropriate configuration of the robotic arms 102 and equipment.


The display modules 202 may include electronic monitors, virtual reality viewing devices, e.g., goggles or glasses, and/or other means of display devices. In some embodiments, the display modules 202 are integrated with the control modules, for example, as a tablet device with a touchscreen. Further, the user 205 can both view data and input commands to the surgical robotic system 100 using the integrated display modules 202 and control modules.


The display modules 202 can display 3D images using a stereoscopic device, e.g., a visor or goggle. The 3D images provide an “endo view” (i.e., endoscopic view), which is a computer 3D model illustrating the anatomy of a patient. The “endo view” provides a virtual environment of the patient's interior and an expected location of an endoscope 118 inside the patient. A user 205 compares the “endo view” model to actual images captured by a camera to help mentally orient and confirm that the endoscope 118 is in the correct—or approximately correct—location within the patient. The “endo view” provides information about anatomical structures, e.g., the shape of an intestine or colon of the patient, around the distal end of the endoscope 118. The display modules 202 can simultaneously display the 3D model and computerized tomography (CT) scans of the anatomy the around distal end of the endoscope 118. Further, the display modules 202 may overlay the already determined navigation paths of the endoscope 118 on the 3D model and CT scans.


In some embodiments, a model of the endoscope 118 is displayed with the 3D models to help indicate a status of a surgical procedure. For example, the CT scans identify a lesion in the anatomy where a biopsy may be necessary. During operation, the display modules 202 may show a reference image captured by the endoscope 118 corresponding to the current location of the endoscope 118. The display modules 202 may automatically display different views of the model of the endoscope 118 depending on user settings and a particular surgical procedure. For example, the display modules 202 show an overhead fluoroscopic view of the endoscope 118 during a navigation step as the endoscope 118 approaches an operative region of a patient.


III. Instrument Device Manipulator


FIG. 3A shows an isometric view of an example independent drive mechanism of the IDM 117 shown in FIG. 1, according to one embodiment. The independent drive mechanism can tighten or loosen the pull wires 321, 322, 323, and 324 (e.g., independently from each other) of an endoscope by rotating the output shafts 305, 306, 307, and 308 of the IDM 117, respectively. Just as the output shafts 305, 306, 307, and 308 transfer force down pull wires 321, 322, 323, and 324, respectively, through angular motion, the pull wires 321, 322, 323, and 324 transfer force back to the output shafts. The IDM 117 and/or the surgical robotic system 100 can measure the transferred force using a sensor, e.g., a strain gauge further described below.



FIG. 3B shows a conceptual diagram that shows how forces may be measured by a strain gauge 334 of the independent drive mechanism shown in FIG. 3A, according to one embodiment. A force 331 may direct away from the output shaft 305 coupled to the motor mount 333 of the motor 337. Accordingly, the force 331 results in horizontal displacement of the motor mount 333. Further, the strain gauge 334 horizontally coupled to the motor mount 333 experiences strain in the direction of the force 331. The strain may be measured as a ratio of the horizontal displacement of the tip 335 of strain gauge 334 to the overall horizontal width 336 of the strain gauge 334.


In some embodiments, the IDM 117 includes additional sensors, e.g., inclinometers or accelerometers, to determine an orientation of the IDM 117. Based on measurements from the additional sensors and/or the strain gauge 334, the surgical robotic system 100 can calibrate readings from the strain gauge 334 to account for gravitational load effects. For example, if the IDM 117 is oriented on a horizontal side of the IDM 117, the weight of certain components of the IDM 117 may cause a strain on the motor mount 333. Accordingly, without accounting for gravitational load effects, the strain gauge 334 may measure strain that did not result from strain on the output shafts.


IV. Endoscope


FIG. 4A shows a top view of an example endoscope 118, according to one embodiment. The endoscope 118 includes a leader 415 tubular component nested or partially nested inside and longitudinally-aligned with a sheath 411 tubular component. The sheath 411 includes a proximal sheath section 412 and distal sheath section 413. The leader 415 has a smaller outer diameter than the sheath 411 and includes a proximal leader section 416 and distal leader section 417. The sheath base 414 and the leader base 418 actuate the distal sheath section 413 and the distal leader section 417, respectively, for example, based on control signals from a user of a surgical robotic system 100. The sheath base 414 and the leader base 418 are, e.g., part of the IDM 117 shown in FIG. 1.


Both the sheath base 414 and the leader base 418 include drive mechanisms (e.g., the independent drive mechanism further described with reference to FIG. 3A-B in Section III. Instrument Device Manipulator) to control pull wires coupled to the sheath 411 and leader 415. For example, the sheath base 414 generates tensile loads on pull wires coupled to the sheath 411 to deflect the distal sheath section 413. Similarly, the leader base 418 generates tensile loads on pull wires coupled to the leader 415 to deflect the distal leader section 417. Both the sheath base 414 and leader base 418 may also include couplings for the routing of pneumatic pressure, electrical power, electrical signals, or optical signals from IDMs to the sheath 411 and leader 414, respectively. A pull wire may include a steel coil pipe along the length of the pull wire within the sheath 411 or the leader 415, which transfers axial compression back to the origin of the load, e.g., the sheath base 414 or the leader base 418, respectively.


The endoscope 118 can navigate the anatomy of a patient with ease due to the multiple degrees of freedom provided by pull wires coupled to the sheath 411 and the leader 415. For example, four or more pull wires may be used in either the sheath 411 and/or the leader 415, providing eight or more degrees of freedom. In other embodiments, up to three pull wires may be used, providing up to six degrees of freedom. The sheath 411 and leader 415 may be rotated up to 360 degrees along a longitudinal axis 406, providing more degrees of motion. The combination of rotational angles and multiple degrees of freedom provides a user of the surgical robotic system 100 with a user friendly and instinctive control of the endoscope 118.



FIG. 4B illustrates an example endoscope tip 430 of the endoscope 118 shown in FIG. 4A, according to one embodiment. In FIG. 4B, the endoscope tip 430 includes an imaging device 431 (e.g., a camera), illumination sources 432, and ends of EM coils 434. The illumination sources 432 provide light to illuminate an interior portion of an anatomical space. The provided light allows the imaging device 431 to record images of that space, which can then be transmitted to a computer system such as command console 200 for processing as described herein. Electromagnetic coils 434 located on the tip 430 may be used with an electromagnetic tracking system to detect the position and orientation of the endoscope tip 430 while it is disposed within an anatomical system. In some embodiments, the coils may be angled to provide sensitivity to electromagnetic fields along different axes, giving the ability to measure a full 6 degrees of freedom: three positional and three angular. In other embodiments, only a single coil may be disposed within the endoscope tip 430, with its axis oriented along the endoscope shaft of the endoscope 118; due to the rotational symmetry of such a system, it is insensitive to roll about its axis, so only 5 degrees of freedom may be detected in such a case. The endoscope tip 430 further comprises a working channel 436 through which surgical instruments, such as biopsy needles, may be inserted along the endoscope shaft, allowing access to the area near the endoscope tip.


V. Registration Transform of EM System to 3D Model

V. A. Schematic Setup of an EM Tracking System



FIG. 5 shows an example schematic setup of an EM tracking system 505 included in a surgical robotic system 500, according to one embodiment. In FIG. 5, multiple robot components (e.g., window field generator, reference sensors as described below) are included in the EM tracking system 505. The robotic surgical system 500 includes a surgical bed 511 to hold a patient's body. Beneath the bed 511 is the window field generator (WFG) 512 configured to sequentially activate a set of EM coils (e.g., the EM coils 434 shown in FIG. 4B). The WFG 512 generates an alternating current (AC) magnetic field over a wide volume; for example, in some cases it may create an AC field in a volume of about 0.5×0.5×0.5 m.


Additional fields may be applied by further field generators to aid in tracking instruments within the body. For example, a planar field generator (PFG) may be attached to a system arm adjacent to the patient and oriented to provide an EM field at an angle. Reference sensors 513 may be placed on the patient's body to provide local EM fields to further increase tracking accuracy. Each of the reference sensors 513 may be attached by cables 514 to a command module 515. The cables 514 are connected to the command module 515 through interface units 516 which handle communications with their respective devices as well as providing power. The interface unit 516 is coupled to a system control unit (SCU) 517 which acts as an overall interface controller for the various entities mentioned above. The SCU 517 also drives the field generators (e.g., WFG 512), as well as collecting sensor data from the interface units 516, from which it calculates the position and orientation of sensors within the body. The SCU 517 may be coupled to a personal computer (PC) 518 to allow user access and control.


The command module 515 is also connected to the various IDMs 519 coupled to the surgical robotic system 500 as described herein. The IDMs 519 are typically coupled to a single surgical robotic system (e.g., the surgical robotic system 500) and are used to control and receive data from their respective connected robotic components; for example, robotic endoscope tools or robotic arms. As described above, as an example, the IDMs 519 are coupled to an endoscopic tool (not shown here) of the surgical robotic system 500


The command module 515 receives data passed from the endoscopic tool. The type of received data depends on the corresponding type of instrument attached. For example, example received data includes sensor data (e.g., image data, EM data), robot data (e.g., endoscopic and IDM physical motion data), control data, and/or video data. To better handle video data, a field-programmable gate array (FPGA) 520 may be configured to handle image processing. Comparing data obtained from the various sensors, devices, and field generators allows the SCU 517 to precisely track the movements of different components of the surgical robotic system 500, and for example, positions and orientations of these components.


In order to track a sensor through the patient's anatomy, the EM tracking system 505 may require a process known as “registration,” where the system finds the geometric transformation that aligns a single object between different coordinate systems. For instance, a specific anatomical site on a patient has two different representations in the 3D model coordinates and in the EM sensor coordinates. To be able to establish consistency and common language between these two different coordinate systems, the EM tracking system 505 needs to find the transformation that links these two representations, i.e., registration. For example, the position of the EM tracker relative to the position of the EM field generator may be mapped to a 3D coordinate system to isolate a location in a corresponding 3D model.


V. B. 3D Model Representation



FIGS. 6A-6B show an example anatomical lumen 600 and an example 3D model 620 of the anatomical lumen, according to one embodiment. More specifically, FIGS. 6A-6B illustrate relationship of centerline coordinates, diameter measurements and anatomical spaces between the actual anatomical lumen 600 and its 3D model 620. In FIG. 6A, the anatomical lumen 600 is roughly tracked longitudinally by centerline coordinates 601, 602, 603, 604, 605, and 606 where each centerline coordinate roughly approximates the center of the tomographic slice of the lumen. The centerline coordinates are connected and visualized by a centerline 607. The volume of the lumen can be further visualized by measuring the diameter of the lumen at each centerline coordinate, e.g., coordinates 608, 609, 610, 611, 612, and 613 represent the measurements of the lumen 600 corresponding to coordinates 601, 602, 603, 604, 605, and 606.



FIG. 6B shows the example 3D model 620 of the anatomical lumen 600 shown in FIG. 6A, according to one embodiment. In FIG. 6B, the anatomical lumen 600 is visualized in 3D space by first locating the centerline coordinates 601, 602, 603, 604, 605, and 606 in 3D space based on the centerline 607. As one example, at each centerline coordinate, the lumen diameter is visualized as a 2D circular space (e.g., the 2D circular space 630) with diameters 608, 609, 610, 611, 612, and 613. By connecting those 2D circular spaces to form a 3D space, the anatomical lumen 600 is approximated and visualized as the 3D model 620. More accurate approximations may be determined by increasing the resolution of the centerline coordinates and measurements, i.e., increasing the density of centerline coordinates and measurements for a given lumen or subsection. Centerline coordinates may also include markers to indicate point of interest for the physician, including lesions.


In some embodiments, a pre-operative software package is also used to analyze and derive a navigation path based on the generated 3D model of the anatomical space. For example, the software package may derive a shortest navigation path to a single lesion (marked by a centerline coordinate) or to several lesions. This navigation path may be presented to the operator intra-operatively either in two-dimensions or three-dimensions depending on the operator's preference.



FIG. 7 shows a computer-generated 3D model 700 representing an anatomical space, according to one embodiment. As discussed above in FIGS. 6A-6B, the 3D model 700 may be generated using centerline 701 that was obtained by reviewing CT scans that were generated preoperatively. In some embodiments, computer software may be able to map the navigation path 702 within the tubular network to access an operative site 703 within the 3D model 700. In some embodiments, the operative site 703 may be linked to an individual centerline coordinate 704, which allows a computer algorithm to topologically search the centerline coordinates of the 3D model 700 for the optimum path 702 within the tubular network.


In some embodiments, the distal end of the endoscopic tool within the patient's anatomy is tracked, and the tracked location of the endoscopic tool within the patient's anatomy is mapped and placed within a computer model, which enhances the navigational capabilities of the tubular network. In order to track the distal working end of the endoscopic tool, i.e., location and orientation of the working end, a number of approaches may be employed, either individually or in combination.


In a sensor-based approach to localization, a sensor, such as an electromagnetic (EM) tracker, may be coupled to the distal working end of the endoscopic tool to provide a real-time indication of the progression of the endoscopic tool. In EM-based tracking, an EM tracker, embedded in the endoscopic tool, measures the variation in the electromagnetic field created by one or more EM transmitters. The transmitters (or field generators), may be placed close to the patient (e.g., as part of the surgical bed) to create a low intensity magnetic field. This induces small-currents in sensor coils in the EM tracker, which are correlated to the distance and angle between the sensor and the generator. The electrical signal may then be digitized by an interface unit (on-chip or PCB) and sent via cables/wiring back to the system cart and then to the command module. The data may then be processed to interpret the current data and calculate the precise location and orientation of the sensor relative to the transmitters. Multiple sensors may be used at different locations in the endoscopic tool, for instance in leader and sheath in order to calculate the individual positions of those components. Accordingly, based on readings from an artificially-generated EM field, the EM tracker may detect changes in field strength as it moves through the patient's anatomy.


V. C. On-the-Fly Electromagnetic Registration



FIGS. 8A-8D show example graphs 810-840 illustrating on-the-fly registration of an EM system to a 3D model of a path through a tubular network, according to one embodiment. The navigation configuration system described herein allows for on-the-fly registration of the EM coordinates to the 3D model coordinates without the need for independent registration prior to an endoscopic procedure. In more detail, FIG. 8A shows that the coordinate systems of the EM tracking system and the 3D model are initially not registered to each other, and the graph 810 in FIG. 8A shows the registered (or expected) location of an endoscope tip 801 moving along a planned navigation path 802 through a branched tubular network (not shown here), and the registered location of the instrument tip 801 as well as the planned path 802 are derived from the 3D model. The actual position of the tip is repeatedly measured by the EM tracking system 505, resulting in multiple measured location data points 803 based on EM data. As shown in FIG. 8A, the data points 803 derived from EM tracking are initially located far from the registered location of the endoscope tip 801 expected from the 3D model, reflecting the lack of registration between the EM coordinates and the 3D model coordinates. There may be several reasons for this, for example, even if the endoscope tip is being moved relatively smoothly through the tubular network, there may still be some visible scatter in the EM measurement, due to breathing movement of the lungs of the patient.


The points on the 3D model may also be determined and adjusted based on correlation between the 3D model itself, image data received from optical sensors (e.g., cameras) and robot data from robot commands. The 3D transformation between these points and collected EM data points will determine the initial registration of the EM coordinate system to the 3D model coordinate system.



FIG. 8B shows a graph 820 at a later temporal stage compared with the graph 810, according to one embodiment. More specifically, the graph 820 shows the expected location of the endoscope tip 801 expected from the 3D model has been moved farther along the preplanned navigation path 802, as illustrated by the shift from the original expected position of the instrument tip 801 shown in FIG. 8A along the path to the position shown in FIG. 8B. During the EM tracking between generation of the graph 810 and generation of graph 820, additional data points 803 have been recorded by the EM tracking system but the registration has not yet been updated based on the newly collected EM data. As a result, the data points 803 in FIG. 8B are clustered along a visible path 814, but that path differs in location and orientation from the planned navigation path 802 the endoscope tip is being directed by the operator to travel along. Eventually, once sufficient data (e.g., EM data) is accumulated, compared with using only the 3D model or only the EM data, a relatively more accurate estimate can be derived from the transform needed to register the EM coordinates to those of the 3D model. The determination of sufficient data may be made by threshold criteria such as total data accumulated or number of changes of direction. For example, in a branched tubular network such as a bronchial tube network, it may be judged that sufficient data have been accumulated after arriving at two branch points.



FIG. 8C shows a graph 830 shortly after the navigation configuration system has accumulated a sufficient amount of data to estimate the registration transform from EM to 3D model coordinates, according to one embodiment. The data points 803 in FIG. 8C have now shifted from their previous position as shown in FIG. 8B as a result of the registration transform. As shown in FIG. 8C, the data points 803 derived from EM data is now falling along the planned navigation path 802 derived from the 3D model, and each data point among the data points 803 is now reflecting a measurement of the expected position of endoscope tip 801 in the coordinate system of the 3D model. In some embodiments, as further data are collected, the registration transform may be updated to increase accuracy. In some cases, the data used to determine the registration transformation may be a subset of data chosen by a moving window, so that the registration may change over time, which gives the ability to account for changes in the relative coordinates of the EM and 3D models—for example, due to movement of the patient.



FIG. 8D shows an example graph 840 in which the expected location of the endoscope tip 801 has reached the end of the planned navigation path 802, arriving at the target location in the tubular network, according to one embodiment. As shown in FIG. 8D, the recorded EM data points 803 is now generally tracks along the planned navigation path 802, which represents the tracking of the endoscope tip throughout the procedure. Each data point reflects a transformed location due to the updated registration of the EM tracking system to the 3D model.


In some embodiments, each of the graphs shown in FIGS. 8A-8D can be shown sequentially on a display visible to a user as the endoscope tip is advanced in the tubular network. In some embodiments, the processor can be configured with instructions from the navigation configuration system such that the model shown on the display remains substantially fixed when the measured data points are registered to the display by shifting of the measured path shown on the display in order to allow the user to maintain a fixed frame of reference and to remain visually oriented on the model and on the planned path shown on the display.



FIGS. 8E-8F show effect of an example registration of the EM system to a 3D model of a branched tubular network, according to one embodiment. In FIGS. 8E-8F, 3D graphs showing electromagnetic tracking data 852 and a model of a patient's bronchial system 854 are illustrated without (shown in FIG. 8E) and with (shown in FIG. 8F) a registration transform. In FIG. 8E, without registration, tracking data 860 have a shape that corresponds to a path through the bronchial system 854, but that shape is subjected to an arbitrary offset and rotation. In FIG. 8F, by applying the registration, the tracking data 852 are shifted and rotated, so that they correspond to a path through the bronchial system 854.


V. D. Mathematical Analysis of Registration Transform


In terms of detailed analysis (e.g., mathematical analysis) and methods of the registration, in some embodiments, a registration matrix can be used to perform the registration between the EM tracking system and the 3D model, and as one example, the matrix may represent a translation and rotation in 6 dimensions. In alternative embodiments, a rotational matrix and a translation vector can be used for performing the registration.








M
1



(
θ
)


=

(



1


0


0




0



cos





θ




sin





θ





0




-
sin






θ




cos





θ




)









M
2



(
φ
)


=

(




cos





φ



0




-
sin






φ





0


1


0





sin





φ



0



cos





φ




)









M
3



(
ψ
)


=

(




cos





ψ




sin





ψ



0






-
sin






ψ




cos





ψ



0




0


0


1



)





From a perspective view of mathematical reasoning, as one example, applying a registration transform involves a shift from one coordinate system (x,y,z) to a new coordinate system (x′,y′,z′) that may in general have its axes rotated to a different 3D orientation as well as having its origin shifted an arbitrary amount in each dimension. For example, a rotation to an azimuthal angle of radians θ may be expressed by the matrix M1, a rotation to an inclination angle of φ radians may be expressed by the matrix M2 etc., and further rotational matrices may be written as the product of rotation matrices. Similarly, a translation vector of (Δx Δy Δz) may be chosen to represent a translation of the origin in the x, y and z axes by Δx, Δy, and Δz respectively.


The registration transform may be determined by such methods as singular value decomposition on a cross correlation matrix between measured EM positions and estimated positions in the 3D model. The transformation matrix components may then be extracted from the decomposition, e.g., by identifying the appropriate principle components. An error signal may also be generated from the residuals of the determined transform, and the size of the error signal may be used to determine a level of confidence in the position. As further data are taken and the registration transform is determined more accurately, this error signal may decrease, indicating an increasing confidence in positions estimated in this manner.


VI. Navigation Configuration System

VI. A. High-Level Overview of Navigation Configuration System



FIGS. 9A-9C show example block diagrams of a navigation configuration system 900, according to one embodiment. More specifically, FIG. 9A shows a high-level overview of an example block diagram of the navigation configuration system 900, according to one embodiment. In FIG. 9A, the navigation configuration system 900 includes multiple input data stores, a navigation module 905 that receives various types of input data from the multiple input data stores, and an output navigation data store 990 that receives output navigation data from the navigation module. The block diagram of the navigation configuration system 900 shown in FIG. 9A is merely one example, and in alternative embodiments not shown, the navigation configuration system 900 can include different and/or addition entities. Likewise, functions performed by various entities of the system 900 may differ according to different embodiments.


The input data, as used herein, refers to raw data gathered from and/or processed by input devices (e.g., command module, optical sensor, EM sensor, IDM) for generating estimated state information for the endoscope as well as output navigation data. The multiple input data stores 910-940 include an image data store 910, an EM data store 920, a robot data store 930, and a 3D model data store 940. Each type of the input data stores stores the name-indicated type of data for access and use by the navigation module 905. Image data may include one or more image frames captured by the imaging device at the instrument tip, as well as information such as frame rates or timestamps that allow a determination of the time elapsed between pairs of frames. Robot data includes data related to physical movement of the medical instrument or part of the medical instrument (e.g., the instrument tip or sheath) within the tubular network. Example robot data includes command data instructing the instrument tip to reach a specific anatomical site and/or change its orientation (e.g., with a specific pitch, roll, yaw, insertion, and retraction for one or both of a leader and a sheath) within the tubular network, insertion data representing insertion movement of the part of the medical instrument (e.g., the instrument tip or sheath), IDM data, and mechanical data representing mechanical movement of an elongate member of the medical instrument, for example motion of one or more pull wires, tendons or shafts of the endoscope that drive the actual movement of the medial instrument within the tubular network. EM data is collected by EM sensors and/or the EM tracking system as described above. 3D model data is derived from 2D CT scans as described above.


The output navigation data store 990 receives and stores output navigation data provided by the navigation module 905. Output navigation data indicates information to assist in directing the medical instrument through the tubular network to arrive at a particular destination within the tubular network, and is based on estimated state information for the medical instrument at each instant time, the estimated state information including the location and orientation of the medical instrument within the tubular network. In one embodiment, as the medical instrument moves inside the tubular network, the output navigation data indicating updates of movement and location/orientation information of the medical instrument is provided in real time, which better assists its navigation through the tubular network.


To determine the output navigation data, the navigation module 905 locates (or determines) the estimated state of the medical instrument within a tubular network. As shown in FIG. 9A, the navigation module 905 further includes various algorithm modules, such as an EM-based algorithm module 950, an image-based algorithm module 960, and a robot-based algorithm module 970, that each may consume mainly certain types of input data and contribute a different type of data to a state estimator 980. As illustrated in FIG. 9A, the different kinds of data output by these modules, labeled EM-based data, the image-based data, and the robot-based data, may be generally referred to as “intermediate data” for sake of explanation. The detailed composition of each algorithm module and of the state estimator 980 is more fully described in FIG. 9B below.


VI. B. Navigation Module



FIG. 9B shows an example block diagram of the navigation module 905 shown in FIG. 9A, according to one embodiment. As introduced above, the navigation module 905 further includes a state estimator 980 as well as multiple algorithm modules that employ different algorithms for navigating through a tubular network. For clarity of description, the state estimator 980 is described first, followed by the description of the various modules that exchange data with the state estimator 980.


VI. B. 1 State Estimator


The state estimator 980 included in the navigation module 905 receives various intermediate data and provides the estimated state of the instrument tip as a function of time, where the estimated state indicates the estimated location and orientation information of the instrument tip within the tubular network. The estimated state data are stored in the estimated data store 985 that is included in the state estimator 980.



FIG. 9C shows an example block diagram of the estimated state data store 985 included in the state estimator 980, according to one embodiment. The estimated state data store 985 may include a bifurcation data store 1086, a position data store 1087, a depth data store 1088, and an orientation data store 1089, however this particular breakdown of data storage is merely one example, and in alternative embodiments not shown, different and/or additional data stores can be included in the estimated state data store 985.


The various stores introduced above represent estimated state data in a variety of ways. Specifically, bifurcation data refers to the location of the medical instrument with respect to the set of branches (e.g., bifurcation, trifurcation or a division into more than three branches) within the tubular network. For example, the bifurcation data can be set of branch choices elected by the instrument as it traverses through the tubular network, based on a larger set of available branches as provided, for example, by the 3D model which maps the entirety of the tubular network. The bifurcation data can further include information in front of the location of the instrument tip, such as branches (bifurcations) that the instrument tip is near but has not yet traversed through, but which may have been detected, for example, based on the tip's current position information relative to the 3D model, or based on images captured of the upcoming bifurcations.


Position data indicates three-dimensional position of some part of the medical instrument within the tubular network or some part of the tubular network itself. Position data can be in the form of absolute locations or relative locations relative to, for example, the 3D model of the tubular network. As one example, position data can include the position of a specific branch.


Depth data indicates depth information of the instrument tip within the tubular network. Example depth data includes the total insertion (absolute) depth of the medical instrument into the patient as well as the (relative) depth within an identified branch. Depth data may be determined based on position data regarding both the tubular network and medical instrument.


Orientation data indicates orientation information of the instrument tip, and may include overall roll, pitch, and yaw in relation to the 3D model as well as pitch, roll, raw within an identified branch.


Turning back to FIG. 9B, the state estimator 980 provides the estimated state data back to the algorithm modules for generating more accurate intermediate data, which the state estimator uses to generate improved and/or updated estimated states, and so on forming a feedback loop. For example, as shown in FIG. 9B, the EM-based algorithm module 950 receives prior EM-based estimated state data (not shown in FIG. 9B), also referred to as data associated with timestamp “t−1.” The state estimator 980 uses this data to generate “estimated state data (prior)” that is associated with timestamp “t−1,” It then provides the data back to the EM-based algorithm module. The “estimated state data (prior)” may be based on a combination of different types of intermediate data (e.g., robotic data, image data) that is associated with timestamp “t−1” as generated and received from different algorithm modules. Next, the EM-based algorithm module 950 runs its algorithms using the estimated state data (prior) to output to the state estimator 980 improved and updated EM-based estimated state data, which is represented by “EM-based estimated state data (current)” here and associated with timestamp t. This process continues to repeat for future timestamps as well.


As the state estimator 980 may use several different kinds of intermediate data to arrive at its estimates of the state of the medical instrument within the tubular network, the state estimator 980 is configured to account for the various different kinds of errors and uncertainty in both measurement and analysis that each type of underlying data (robotic, EM, image) and each type of algorithm module might create or carry through into the intermediate data used for consideration in determining the estimated state. To address these, two concepts are discussed, that of a probability distribution and that of confidence value.


The “probability” of the “probability distribution”, as used herein, refers to a likelihood of an estimation of a possible location and/or orientation of the medical instrument being correct. For example, different probabilities may be calculated by one of the algorithm modules indicating the relative likelihood that the medical instrument is in one of several different possible branches within the tubular network. In one embodiment, the type of probability distribution (e.g., discrete distribution or continuous distribution) is chosen to match features of an estimated state (e.g., type of the estimated state, for example continuous position information vs. discrete branch choice). As one example, estimated states for identifying which segment the medical instrument is in for a trifurcation may be represented by a discrete probability distribution, and may include three discrete values of 20%, 30% and 50% representing chance as being in the location inside each of the three branches as determined by one of the algorithm modules. As another example, the estimated state may include a roll angle of the medical instrument of 40±5 degrees and a segment depth of the instrument tip within a branch may be is 4±1 mm, each represented by a Gaussian distribution which is a type of continuous probability distribution. Different methods can be used to generate the probabilities, which will vary by algorithm module as more fully described below with reference to later figures.


In contrast, the “confidence value,” as used herein, reflects a measure of confidence in the estimation of the state provided by one of the algorithms based one or more factors. For the EM-based algorithms, factors such as distortion to EM Field, inaccuracy in EM registration, shift or movement of the patient, and respiration of the patient may affect the confidence in estimation of the state. Particularly, the confidence value in estimation of the state provided by the EM-based algorithms may depend on the particular respiration cycle of the patient, movement of the patient or the EM field generators, and the location within the anatomy where the instrument tip locates. For the image-based algorithms, examples factors that may affect the confidence value in estimation of the state include illumination condition for the location within the anatomy where the images are captured, presence of fluid, tissue, or other obstructions against or in front of the optical sensor capturing the images, respiration of the patient, condition of the tubular network of the patient itself (e.g., lung) such as the general fluid inside the tubular network and occlusion of the tubular network, and specific operating techniques used in, e.g., navigating or image capturing.


For example one factor may be that a particular algorithm has differing levels of accuracy at different depths in a patient's lungs, such that relatively close to the airway opening, a particular algorithm may have a high confidence in its estimations of medical instrument location and orientation, but the further into the bottom of the lung the medical instrument travels that confidence value may drop. Generally, the confidence value is based on one or more systemic factors relating to the process by which a result is determined, whereas probability is a relative measure that arises when trying to determine the correct result from multiple possibilities with a single algorithm based on underlying data.


As one example, a mathematical equation for calculating results of an estimated state represented by a discrete probability distribution (e.g., branch/segment identification for a trifurcation with three values of an estimated state involved) can be as follows:

S1=CEM*P1,EM+CImage*P1,Image+CRobot*P1,Robot;
S2=CEM*P2,EM+CImage*P2,Image+CRobot*P2,Robot;
S3=CEM*P3,EM+CImage*P3,Image+CRobot*P3,Robot.


In the example mathematical equation above, Si(i=1, 2, 3) represents possible example values of an estimated state in a case where 3 possible segments are identified or present in the 3D model, CEM, CImage, and CRobot represents confidence value corresponding to EM-based algorithm, image-based algorithm, and robot-based algorithm and Pi,EM, PiImage, and Pi,Robot represent the probabilities for segment i.


To better illustrate the concepts of probability distributions and confidence value associated with estimate states, a detailed example is provided here. In this example, a user is trying to identify segment where a instrument tip is located in a certain trifurcation within a central airway (the predicted region) of the tubular network, and three algorithms modules are used including EM-based algorithm, image-based algorithm, and robot-based algorithm. In this example, a probability distribution corresponding to the EM-based algorithm may be 20% in the first branch, 30% in the second branch, and 50% in the third (last) branch, and the confidence value applied to this EM-based algorithm and the central airway is 80%. For the same example, a probability distribution corresponding to the image-based algorithm may be 40%, 20%, 40% for the first, second, and third branch, and the confidence value applied to this image-based algorithm is 30%; while a probability distribution corresponding to the robot-based algorithm may be 10%, 60%, 30% for the first, second, and third branch, and the confidence value applied to this image-based algorithm is 20%. The difference of confidence values applied to the EM-based algorithm and the image-based algorithm indicates that the EM-based algorithm may be a better choice for segment identification in the central airway, compared with the image-based algorithm. An example mathematical calculation of a final estimated state can be:


for the first branch: 20%*80%+40%*30%+10%*20%=30%; for the second branch: 30%*80%+20%*30%+60%*20%=42%; and for the third branch: 50%*80%+40%*30%+30%*20%=58%.


In this example, the output estimated state for the instrument tip can be the result values (e.g., the resulting 30%, 42% and 58%), or derivative value from these result values such as the determination that the instrument tip is in the third branch.


As above the estimated state may be represented in a number of different ways. For example, the estimated state may further include an absolute depth from airway to location of the tip of the instrument, as well as a set of data representing the set of branches traversed by the instrument within the tubular network, the set being a subset of the entire set of branches provided by the 3D model of the patient's lungs, for example. The application of probability distribution and confidence value on estimated states allows improved accuracy of estimation of location and/or orientation of the instrument tip within the tubular network.


VI. B. 2 Algorithm Modules


A shown in FIG. 9B, the algorithm modules include an EM-based algorithm module 950, an image-based algorithm module 960, and a robot-based algorithm module 970. The algorithm modules shown in FIG. 9B is merely one example, and in alternative embodiments, different and/additional algorithm modules involving different and/or additional navigation algorithms can also be included in the navigation module 905.


VI. B. 2. I. EM-Based Algorithm Module


The EM-based algorithm module 950 further includes an EM registration module 952 and a branch selection module 954. The EM registration module 952 performs registration of EM coordinates to 3D model coordinates. FIG. 10A shows an example block diagram of the EM registration module 952, according to one embodiment. The EM registration module 952 receives as input, estimated state data (prior) (e.g., bifurcation data) from the estimated state data store 1086, the EM data from the EM data store 920, the 3D model data from the 3D model data store 940.


As described above with respect to Section V, based on the received data, the EM registration module 952 performs on-the-fly registration of the EM tracking data to the 3D model. After the initial registration is determined, the EM registration module 952 continually updates its estimate of the registration transform based on received data, so as to increase transform accuracy as well as to compensate for changes to the navigation configuration system 900, e.g., changes due to movement of the patient. The EM registration module 952 outputs registration transform data to the registration transform data store 1053. In one embodiment, the registration transform data reflects the best fit registration transform, and it can also be sent to the state estimator 980, as well as to the branch selection module 954.



FIG. 10B shows an example block diagram of the branch selection module 954, according to one embodiment. The branch selection module 954 receives as inputs, estimated state data (prior) (e.g., bifurcation data) from the estimated state data store 985, the EM data from the EM data store 920, registration transform data from the registration transform data store 1053, as well as 3D model data from the 3D model data store 940. Based on the received data, the branch selection module 954 determines an estimate of the position and orientation of the endoscope tip relative to the 3D model of the tubular network and provides EM-based estimated state data (current) to the state estimator 980. As an example, the EM-based estimated state data may be represented as a probability distribution (e.g., a discrete distribution of 20%, 30% and 50% for three segments of a trifurcation, as described above.) Additionally, when at a bifurcation as indicated by the received bifurcation data, the branch selection module 954 may compare the pitch and yaw of the tip to the angles of each branch in the 3D model to estimate which branch has been selected by the user for traversal. The branch selection module 954 outputs the EM-based estimated state data (current) to the estimated data store 985.


VI. B. 2. II. Image-Based Algorithm Module


Turning back to FIG. 9B, the image-based algorithm module 960 uses image data to determine the estimated state of the instrument within the tubular network. The image-based algorithm module 960 further includes one or more different types of image-based algorithm modules that employ different image-based algorithms. As shown in FIG. 9B, one example including an object-based algorithm module 962 is shown. In alternative embodiments not shown, other types of image-based algorithms may be employed and corresponding algorithm modules may be included in the image-based algorithm module 960.


The object-based algorithm module 962 detects and analyzes objects present in the field of view of the image data, such as branch openings or particles, to determine estimated state. In one embodiment, it includes an object detection module 963, and object mapping module 964, a topological reasoning module 965, and a motion estimation module 966. In some embodiments, it may or may not be necessary to apply the different modules 963, 964, 965 and 966 in a fixed sequential order, and when actually executing a process of object-based algorithm described by the object-based algorithm module 962, the order of employing each module within the module 962 is a different order than shown in FIG. 9B.


Turning to FIG. 10C, the motion estimation module 963 receives as inputs image data from the image data store 910, estimated state data (prior) (specifically bifurcation data), from the estimated state data store 985 as well as the 3D model data from the 3D model data store 940. Based on the received image data, the motion estimation module 963 measures a movement of the medical instrument between multiple image frames based on the received image data. Example techniques used include optical flow and image registration techniques, among others. This measurement determines a differential movement, such as forward-backward motion or roll motion, of the instrument tip in its own local frame of reference. This movement can be combined with the prior estimated state input to calculate a new estimated state. In particular, a forward (or backward) movement can translate into an increase (or decrease) in depth relative to a prior estimated state. Similarly, a differential roll translates into a change in roll angle relative to a prior estimated state. These measurements allow an estimation of movement through the tubular network. As above, these estimations may be represented as a probability distribution (e.g., a roll angle of the medical instrument of 40±5 degrees represented by a Gaussian distribution). The output estimated state is stored in the estimated state data store 985.


In one embodiment, in a case where the estimated state and bifurcation data for a particular instant in time indicate that the instrument tip is at or near a branch point, this movement measurement may include an identification of an estimated new branch that the instrument tip is estimated to be entering or have entered. For example, if the bifurcation data indicates that the endoscope tip is at a branch point, pitch and yaw movements can be measured to determine changes in pointing angle, and the new estimated angle can be compared with the expected angles of different branches in the 3D model of the tubular network. A determination can then be made of which branch the endoscope is facing towards when it is moved into a new branch. Estimated state data reflecting each of these estimates of new position, orientation, and/or branch entry are output to the state estimator 980.



FIG. 10D shows an example block diagram of the object detection module 964, according to one example. The object detection module 964 receives as inputs image data (e.g., image frames), and outputs object data to an object data store 1063 as well as estimated state data to the estimated state data store 985. Object data indicates information about what objects were identified, as well as positions, orientations, and sizes of objects represented as probabilities.


Specifically, the object detection module 964 detects, within an image, one or more objects and one or more features of the object(s) that may indicate branch points in a tubular network, and then determines their position, size, and orientation. Objects may be calculated or represented in the object detection module 964 as being two-dimensional shapes, such as circles/ovals/ellipses for detected branch points. This corresponds to the fact that the image data used to capture the objects are images from the camera on the instrument tip pointed usually along an axis substantially parallel to the direction of the segment in which the instrument is located. As a consequence, objects such as branches in the tubular network appear as simple shapes such as ellipses in the images. In one embodiment, in a given image within a tubular network, each branch will typically appear as a dark, approximately elliptical region, and these regions may be detected automatically by a processor, using region-detection algorithms such as maximally stable extremal regions (MSER) as objects. These regions may then be fit to define an object (e.g., ellipse), with appropriate free parameters such as ellipse center, major and minor axes, and angle within the image. The roll measurement and the identified matching between model lumens and lumens in the image are also output to the state estimator 980, as well as topological reasoning module 966. An example of identified objects superimposed on an image of a bronchial network, along with a link joining their centers, is described with reference to FIGS. 11A-11B.


In one embodiment, “airway” can also be identified as an object present in the image data. The object detection module 964 may use light reflective intensity combined with other techniques to identify airways.


The object detection module 964 may further track detected objects across a set of sequential image frames to detect which branch has been entered from among a set of possible branches in the tubular network. Tracking the relative positions of the objects within the image frames may be used to determine a local, absolute measurement of roll angle within a branched network.



FIG. 10E shows an example block diagram of the object mapping module 965, according to one embodiment. The object mapping module 965 receives as inputs 3D model data from the 3D model data store 940, object data (e.g., detected objects such as shapes representing possible branches in the tubular network) from the object data store 1063, and estimated state data (prior) from the estimated state data store 985.


Based on the received input data, the object mapping module 965 outputs object mapping data to an object mapping data store 1065 as well as image-based estimated state data (current) to the estimated state data store 985. As one example, the object mapping data indicates mapping information between physical branches (lumens) shown in image data (based on the detected objects) and virtual branch information generated by 3D model. The estimated state data (current) generated by module 965 includes identification of each branch of the tubular network visible within the image as well as an estimate of the roll of the endoscope tip relative to the 3D model. As above, the estimated state data (current) can be represented as a probability distribution. The identification of the visible lumens may include coordinates in x and y of each identified lumen center within the image, for example based on object sizes correlated with the 3D model virtual image data, as well as an association of each identified lumen location with a particular branch of the tubular network.


In some embodiments, since the 3D model is generated prior to the endoscopic procedure, the virtual images of the tubular network may be pre-computed to speed up processing. In alternative embodiments not shown, the tubular network may be represented by a structure such as a tree diagram of lumen midlines, with each such midline describing a 3D path, so that an expected position of local branch centers as seen from any arbitrary perspective may be compared to the identified actual locations of branch centers based on EM data and/or robot data.



FIGS. 11A-11B, show an example object-to-lumen mapping performed by the object mapping module 965, according to one embodiment. More specifically, FIG. 11A shows two example identified objects 1101 and 1102 superimposed on an image of a bronchial network 1105 along with a link 1103 connecting centers of the two objects, according to one embodiment. In the illustrated example, the identified objects 1101 and 1102 are ellipse-shaped.



FIG. 11B shows a matching between airway lumens in an actual image 1110 of a real bronchial network and a corresponding virtual image 1120 from a 3D model of that same network, according to on embodiment. In the actual image 1110, ellipses are identified corresponding to two different branches, located with identified centers 1111 and 1112, which, in one embodiment, indicates centerline coordinates of the branches as described above in FIGS. 6A-6B. The 3D model virtual image 1120 is a simulated representation of the real bronchial network shown in the actual image 1110, and the estimated centers 1121 and 1122 of the endoscope tip as determined by the state estimator 980 are shown corresponding to the positions of the identified centers 1111 and 1112.


If both images 1110 and 1120 are presented to a user via a user interface, the 3D model image 1120 may be rotated or translated to increase the closeness of fit between actual image 1110 and virtual image 1120, and the amount of roll needed for the rotation or translation can be output as a correction to the current estimated state (e.g., roll of the instrument tip).


In one embodiment, the probability applied to a possible estimated state as generated by the object mapping module 965 is based on the closeness of fit between the identified centers 1111 and 1112 detected in the actual image 1110 and estimated centers 1121 and 1121 in the 3D model image 1120, and as one example, the probability of being in the lumen with identified center 1112 drops as the distance between the estimated center 1122 and identified center 1112 increases.



FIG. 10F shows an example block diagram of the topological reasoning module 966, according to one embodiment. The topological reasoning module 966 receives as input image data from the 3D model data from the 3D model data store 940, object mapping data from the object mapping data store 1065, and estimated state data (prior) from the estimated state data store 985.


Based on the received data, the topological reasoning module 966 determines which branch the endoscope tip is facing towards, thereby generating a prediction of which branch will be entered if the endoscope is moved forward. As above, the determination may be represented as a probability distribution. In one embodiment, when the instrument tip is moving forward, the topological reasoning module 966 determines that a new branch of the tubular network has been entered and identifies which branch the tip has moved into. The determination of which branch is being faced and which segment is entered may be made, for example, by comparing the relative sizes and locations of different identified objects (e.g., ellipses). As one example, as a particular lumen branch is entered, a corresponding detected object will grow larger in successive image frames, and will also become more centered in those frames. If this is behavior is identified for one of the objects, the topological reasoning module 966 assigns an increasingly large probability to a corresponding estimated state as the endoscope tip moves towards the lumen associated with that object. Other branches are assigned correspondingly lower probabilities, until finally their object shapes disappear from images entirely. In one embodiment, the probability of the medical instrument being in those branches depends only on the probability that the branches were misidentified by the object mapping module 964. The output of the topological reasoning module 966 is image-based estimated state data representing estimated probabilities of being in each of a set of possible branches within the branched network.


VI. B. 2. III. Robot-Based Algorithm Module


The robot-based algorithm module 970 uses robot data to provide robot-based estimated state data to the state estimator 980. FIG. 9B illustrates that the robot-based algorithm module 970 receives estimated state data (prior) and provides estimated state data (current) to state estimator 980. Robot data includes data related to physical movement of the medical instrument or part of the medical instrument (e.g., the instrument tip) within the tubular network. Example robot data includes command data instructing the instrument tip to reach a specific anatomical site and/or change its orientation (e.g., with a specific pitch, roll, yaw, insertion, and retraction for one or both of a leader and a sheath) within the tubular network, insertion data representing insertion movement of the part of the medical instrument (e.g., the instrument tip or sheath), IDM data, and mechanical data representing mechanical movement of an elongate member of the medical instrument, for example motion of one or more pull wires, tendons or shafts of the endoscope that drive the actual movement of the medical instrument within the tubular network.


Although in an ideal system, specifically input pitch, roll, yaw, insertion, and retraction commands given to the IDM to control the instrument tip would result in exactly-as-input changes in the motion of the instrument tip, in practice this is generally not the case. Friction in the system, nonlinearities in instrument motion, blockages, and other effects may cause the input motion to vary from the output motion. As such, the estimated state data provided by the raw robotic input data is just that, an estimate as to actual motion. As per the algorithms above, the estimated state data determined from the robotic data may be represented in a probabilistic manner to represent this uncertainty in actual position information.


VI. C. Probability Distribution Generation



FIG. 12 shows an example process of generating a probability distribution over multiple values to determine an estimated state as may be performed by any of the individual algorithm modules described above, according to one embodiment. For sake of example, this process is described with respect to the estimated state module 980, but in practice may be used by any algorithm module.


In FIG. 12, a process of a Bayesian estimation method is shown, and in alternative embodiments not shown, other methods of generating a probability distribution can also be employed. As shown in FIG. 12, the state estimator 980 first determines 1201 a prior probability distribution for the estimated state. As this stage, this probability distribution may be an initialized value distribution based, for example, on user input identifying a starting point near an entry point to a branched network. Subsequently, the distribution is determined from its previous output state estimate, adjusted based on the robotic, image, or EM input data.


For example, if the surgical robotic system 100 commands to move the endoscope tip forward a certain distance, e.g., 1 mm, the new or updated probability distribution may be estimated as centered 1 mm forward compared to the previous probability distribution. More generally, if a robot command is expected to change a variable x by a certain amount, represented by an expected distribution of value changes Q(Ax), the new estimated distribution P′ (x) may be expressed as a convolution of the previous distribution P(x) with Q(Ax). This new estimated state is treated as a prior probability estimate of the variable for the subsequent steps.


In the next step 1202, the state estimator 980 receives an estimated value distribution for the estimated state based on one or more algorithm modules. This value distribution may be represented in various ways, such as an expected value and an error range, or as an explicit distribution function over values, for example. In any case, the value distribution contains, implicitly or explicitly, an expected value of the variable and some estimate of a range of error. In some cases, only the expected value is transmitted and the error range is determined by the state estimator 980, using a record of past performance or pre-calibrated values of reliability. In one embodiment, when using an expected value and an error range, the state estimator 980 may treat the estimated value distribution as a normal distribution with a mean at the expected value and a standard deviation determined by the error range. In the case of a discrete variable or discrete state like branch identification, the estimated value distribution will typically comprise one or more probability values assigned to each of one or more branches, such that the total probability sums to one (or 100%). In some cases, some branches may not be assigned with explicit probabilities, and the total probability may be less than 1, in which case the remaining probability can be treated as being uniformly distributed over all other branches.


In step 1203, the state estimator 980 generates a posterior probability distribution based on the received estimated value distribution from step 1202 and the determined prior probability distribution from step 1201. As one example, this posterior probability distribution is calculated as an application of Bayes' Theorem, which states that for an observation A, the posterior probability P(x|A) of a variable having value x is given by the equation








P


(

x

A

)


=



P


(

A

x

)




P


(
x
)




P


(
A
)




,





where P(x|A) is the probability of observing A given that x is true, P(x) is the prior probability of x being true, and P(A) is the prior probability of observing A, whether x is true or false.


The state estimator 980 determines each of the quantities P(x), P(A), and P(A|x) from the inputs generated during steps 1201 and 1202, as well as from a basic model of the set of possible observations. For example, P(A), representing the prior probability of x, may simply be read from the value determined in step 1201. Likewise, P(A|x) may be read from the function determined in step 1202. P(A), may be set as a constant representing the number of possible values of A. For example, when estimating a discrete probability distribution for what branch an endoscope tip is in encountering a division into a certain number (e.g., 10) of branches, the probability, P(A), of observing the tip to be in any given branch, may be set as 1/10. Alternatively, a model may be implemented to weight the possible observations A variably, for example, where branch sizes vary, P(A) may be set proportional to the size of branch A divided by the sum of all branch sizes, representing the idea that a randomly-placed tip is more likely to be found in a large branch than a small one. For continuous distributions, such as roll angle, depth, or orientation, P(A) will be a probability density function over all possible observations A. For example, if roll angle ranges from 0 to 2π radians, P(A) may be set to 1/(2π) for all values of A to represent an equally likely probability density of any roll angle being observed. More generally, given P(x) as an estimate for the probability of x, P(A) will be given by the formula P(A)=P(A|x)P(x)+P(A|˜x)P(˜x), where ˜x means “not-x.”


In one embodiment, the result of step 1203 is a new probability distribution for values of the variable/state. In one embodiment, when each of multiple independent measurements relates to a given variable, the multiple independent measurements may be adjusted sequentially by taking the output of step 1203 as an input to step 1201, and using each new measurement as the estimated value distribution of step 1202. This generates a loop 1205 over measurements. Alternatively, step 1202 may incorporate a plurality of independent estimated value distribution which may be combined into a single updated estimate in step 1203, using Bayesian conditional updating on multiple measurements.


For example, if differential movement is being measured, the motion estimation module 963 may employ method 1200 with a process of taking the prior probability distribution of step 1201 as over an amount of movement (for example, an expected range of movement based on robot data), receiving an estimated value distribution in step 1202 over differential movement measurements, and generating a posterior probability distribution in step 1203 to estimate actual values of movement. This output may then be convolved with a prior estimated variable values (from a prior estimated state) to generate a posterior probability distribution for multiple values of the state. In some embodiments, once all measurements have been incorporated into an updated probability distribution, this new probability distribution is reported out in step 1204. The process 1200 may be applied in parallel to generate new probability distributions for a plurality of variables (states), such as position, orientation, roll, depth, and/or branch. The outputs of step 1204 for each such process may be combined together to generate a new estimated state (E) 1202, which represents the output of the motion estimation module 963.


VI. D. Error Correction


In some embodiments, the navigation module 905 allows estimates of variables even when certain input data is not available. For example, prior to registration of the EM system, the output of the branch selection module 954 is ignored by the state estimator 980. Nonetheless, states representing location and/or orientation (e.g., tip insertion depth) may still be estimated based on available input data like the robot input data. Each time the instrument tip is ordered to move deeper into the branched network, the estimate state for the tip insertion depth may be updated based on this estimated movement. Thus, prior to registration, the tip insertion depth may be estimated based on robot data, and after registration, the depth may be estimated based on data from the branch selection module 954, but also partially based on robot data, with a weighting function.


There is a possibility of over-determination/over-fitting of the location estimate for the instrument based on the many possible independent measurements introduced above, which include local measurements such as object-based image tracking, optical flow, global measurements such as EM tracking, and robotic input data based measurement. Consequently, the accuracy of estimated position within the branched network may be greater than the accuracy of estimates made using any one of the modules alone. Furthermore, in some embodiments, the navigation configuration system 900 demonstrates the ability to recover from errors by using the measurements from one module to contradict the measurements from another, allowing the system to “change its mind” about a previously-made determination. An example of how an error can be corrected is more fully described below with reference to FIG. 13.



FIG. 13 shows an example of how an error can be corrected with navigation through a tubular network by the navigation configuration system 900, according to one embodiment. In FIG. 13, a simplified model of a bronchial tree 1300 with estimated states is shown at four different temporal stages: states 1310, 1320, 1330, and 1340. For each temporal stage, an estimated position (1312, 1322, 1332, and 1342, respectively) of an instrument tip used for the navigation is illustrated, and a corresponding actual position (1311, 1321, 1331, and 1341, respectively) of the tip is also illustrated. In one embodiment, over time during the four stages, the accuracy of the estimated states (based on the underlying probabilities and confidences) may vary, e.g., the estimated states may first begin accurate, then becomes inaccurate, and then becomes accurate again.


As shown in FIG. 13, initially, in state 1310, the actual position of the tip is 1311, at the upper branch of the bronchial tree 1300, and the navigation configuration system 900 accurately estimates that location as estimated position 1312. However, when it enters one of the two branches near actual position 1311, one or more modules inside the system 900 may misidentify the branch based on probabilities provided by one or more of the algorithm modules, causing the system to conclude that the tip is entering the left branch 1345, when it is actually entering the right branch 1346. For example, the state estimator 980 initially assigns an 80% chance of being in the left branch and a 20% chance of being in the right branch.


However, as the endoscope tip proceeds down the right branch 1346 to state 1320, the estimated position 1322 will be more and more spatially distinct from the actual position 1321. In one embodiment, the branch selection module 954 may thus more and more confidently report that the tip is probably in the right branch 1346 based on the shift in the probabilities provided by the underlying modules. Accordingly, the state estimator's 980 aggregate probability estimate may also shift, thereby resulting in an increase in the probability of being in the right branch 1346 and a corresponding decreasing the probability of being in the left branch 1345.


The system 900 may proceed to a state 1330, in which the tip is at the actual position 1331, arriving at a division into three branches. However, at this point in time state estimator 980 may still be estimating that the most likely state to be at estimated position 1332.


At state 1340, based on the 3D model, the state estimator 980 may be expecting a certain distance until the next branch division, in this example a two-way division, rather than three-way branch division. Under this circumstance, both the branch selection module 954 and the object mapping module 964 may strongly estimate that the tip is located in the branch shown on the right, which further strongly adjusts the probabilities of being in the left and right branches, leading to an almost certain assignment of the tip location to the correct branch, the right branch 1346 here.


Consequently, at state 1340 the state estimator 980 correctly estimates the instrument tip be at estimated position 1342, very close to its actual location 1341. If the endoscope is along the user's desired path, the system 900 can now proceed to determine which branch of the three-way branch division is entered next. Alternately, the user can backtrack to travel down the left lumen of bronchial tree 1300. In some embodiments, this updated estimate is shown to a user on a display, so that the user can perceive that the previous estimates were in error, and that error has now been corrected.


VII. Pre-Operative Path Planning for Navigation Preparation

Navigating to a particular point in a tubular network of a patient's body requires certain steps to be taken pre-operatively in order to generate the information needed to create the 3D model of the tubular network and to determine a navigation path within it. FIGS. 14A-14C show example pre-operative steps for preparation of a surgical instrument (e.g., an instrument tip) to navigation through an example tubular network, according to various embodiments.



FIG. 14A shows an example pre-operative sequence of steps of a method 1400 for navigating the instrument tip to a particular site within the tubular network, according to one embodiment. Alongside each step of the method 1400, a corresponding image is shown to illustrate a representation of the involved data for planning a path and navigating through the tubular network.


Initially, in step 1405, a CT scan of the tubular network is obtained, and the data from the CT scan provides 3D information about the structure and connectivity of the tubular network. For example, the image in step 1405 shows a tomographic slice of a patient's lungs.


In step 1410, a 3D model is generated based on the obtained CT scan data, and the generated 3D model can be used to assign each branch of the tubular network with a unique identity, enabling convenient navigation within the network. For example, the image in step 1410 shows a 3D model of a patient's bronchial network.


In step 1415, a target 1416 is selected, and this target may be, for example, a lesion to biopsy, or a portion of organ tissue to repair surgically. In one embodiment, the user is capable of selecting the location of the target by interfacing with a computer display that can show the 3D model, such as by clicking with a mouse or touching a touchscreen. The selected target may then be displayed to the user. For example, the target 1416 is marked within the 3D bronchial model generated from step 1410.


In step 1420, a path 1421 is automatically planned from an entry point 1422 to the target 1416, and the path 1421 identifies a sequence of branches within the network to travel through, so as to reach the target 1416. In one embodiment, the tubular network may be tree-like, the path 1421 may be uniquely determined by the structure of the tubular network, while in another embodiment, the tubular network may be cyclic, and the path may be found by an appropriate algorithm such as a shortest-path algorithm.


Once the path 1421 has been determined, virtual endoscopy 1425 may be performed to give the user a preview of the endoscopic procedure. The 3D model generated from step 1410 is used to generate a sequence of 2D images as though seen by an endoscope tip while navigating the network corresponding to the 3D model. The path 1421 may be shown as a curve that may be followed to get from the entry point 1422 to the target 1416.


Once the virtual endoscope tip has arrived at the target 1416, a virtual tool alignment procedure 1430 may be performed to illustrate to the user how to manipulate endoscopic tools in order to perform a surgical procedure at the target. For example, in the illustration, a virtual endoscopic biopsy needle 1431 is maneuvered by the user in order to biopsy a lesion 1432 located beneath the surface of a bronchial tube. The lesion location is highlighted so that the user can align the needle to it, and then use the needle to pierce the surface of the bronchial tube and access the lesion underneath. This mimics the steps that will be taken during the actual surgical procedure, allowing the user to practice before performing surgery.



FIG. 14B shows an example user interface 1434 for navigation of a surgical instrument through a tubular network, according to one embodiment. The user interface 1434 allows the user to have various views of the tubular network during an endoscopic procedure. In addition to a real-time view from the imaging device (e.g., an endoscope camera), the user interface 1434 may show various navigation views to the user. For example, the location of the endoscope tip may be superimposed on a tomographic segment of the CT scan 1435, with a marker (e.g., crosshairs 1436) showing the location of the instrument. In this case, the CT image is of a patient's lungs, and the endoscope used is a bronchoscope.


In FIG. 14B, the user interface 1434 also shows a view 1440 representing a 3D model with a highlighted path 1441 and icons showing the endoscope location 1442 and the target location 1443. Some additional icons 1444 are also shown in the view 1440 for user interface controls enabling features as map pan and zoom.


View 1445 shows a virtual endoscope view from the estimated location of the tip that can be compared with a real-time view to confirm that the tip location has been estimated accurately. A path indicator 1446 and location/orientation indicator 1447 for aid in navigation is also shown in the view 1446. The upper left shows state information 1448 determined by the state estimator 980, indicating that the current distance to target “t1” is 5.4 cm, and that the calculated roll angle is −139 degrees.


View 1450 shows a virtual view of the endoscope shaft 1451, displayed from a “third-person” viewpoint to the rear of the endoscope tip. The virtual view can be generated by assuming that the endoscope shaft lies along the path already traversed by the tip, and the view of the surrounding area is generated based on the 3D model in the vicinity of the chosen viewpoint. Alternately, the view may be generated from images taken while passing through that area earlier in the procedure. In alternative embodiments, the virtual viewpoint may project ahead of the endoscope tip location, to show the next bifurcation. This view may further highlight the intended path, to inform the user in advance which way to steer when the endoscope tip reaches the next bifurcation.



FIG. 14C shows an example user interface 1480 for tool alignment and control during an endoscopic procedure, according to one embodiment. View 1455 shows a tomographic view at a later stage in the procedure than view 1435, in which the endoscope tip is near the target and an endoscopic tool—in this case, a biopsy needle—has been deployed from the endoscope's working channel. The crosshairs 1436 highlights the new position of the tip. Since the bronchoscope in the image is farther into the patient's lungs, the tomographic slice has changed to show a deeper cross-sectional segment. The icon locating the endoscope tip has been replaced with one indicating the location and orientation of the needle. View 1460 shows a map view of the 3D model, zoomed in around the target location 1443 and the tool icon 1461 representing the biopsy needle. Located at target 1443 is a biopsy location 1466 to which a biopsy needle is to be applied. As shown in this view, the endoscope tip has been navigated to nearly the end of path 1441, to arrive at a location close enough to the target location 1443 so that the needle may reach the biopsy location 1466.


View 1465 shows a virtual view in the vicinity of target location 1443, highlighting a biopsy location 1466 to help the user visualize precisely where the needle is to be inserted to collect tissue for biopsy. Additional information, such as target size and distance to target may optionally be overlaid on the image.


View 1670 shows a close-up view of a 3D icon 1471 representing a biopsy needle, superimposed on a tomographic image of the patient's lungs. The roll of the instrument is indicated by a multicolored pattern 1475 on the rear of the 3D icon 1471. As seen from state information 1473, this particular orientation represents a roll of 0 degrees, and the needle is currently 4 mm from the biopsy location 1466. A path 1474 is displayed showing how the needle should be oriented and moved in order to contact the biopsy location 1466.


VIII. Machine Configuration for the Navigation Configuration System

More generally, the navigation and tracking technique disclosed herein may be performed with an appropriately configured computer system. A processor within the computer system may comprise one or more components to process electronic signals, and may comprise one or more of a central processor unit, a video processor, logic circuitry, gate array logic, filed programmable gate array, integrated circuit, or application specific integrated circuit. The computer system includes a central processing unit (CPU, also “processor” and “computer processor” herein), which can be a single core or multi core processor, or a plurality of processors for parallel processing. The CPU can execute a sequence of machine-readable instructions, which can be embodied in a program or software. The instructions may be stored in a memory location. Examples of operations performed by the CPU can include fetch, decode, execute, and writeback. The CPU can be part of a circuit, such as an integrated circuit. One or more other components of the system can be included in the circuit. In some cases, the circuit comprises an application specific integrated circuit (ASIC).


The computer system may also include one or more of memory or memory locations (e.g., random-access memory, read-only memory, flash memory), electronic storage units (e.g., hard disk), communication interfaces (e.g., network adapters) for communicating with one or more other systems, and peripheral devices, such as caches, other memory, data storage and/or electronic display adapters. The memory, storage unit, interface, and peripheral devices are in communication with the CPU through a communication bus, such as a motherboard.


The storage unit can be a data storage unit (or data repository) for storing data. The computer system can be operatively coupled to a computer network (“network”) with the aid of the communication interface. The network can be the Internet, an internet and/or extranet, or an intranet and/or extranet that is in communication with the Internet. The network in some cases is a telecommunication and/or data network, and can include can include one or more computer servers. The storage unit can store files, such as drivers, libraries and saved programs. The storage unit can store user data, e.g., user preferences and user programs. The computer system in some cases can include one or more additional data storage units that are external to the computer system, such as located on a remote server that is in communication with the computer system through an intranet or the Internet.


Methods as described herein can be implemented by way of machine (e.g., computer processor) executable code stored on an electronic storage location of the computer system, such as, for example, on the memory or electronic storage unit. The machine executable or machine readable code can be provided in the form of software. During use, the code can be executed by the processor. In some cases, the code can be retrieved from the storage unit and stored on the memory for ready access by the processor. In some situations, the electronic storage unit can be precluded, and machine-executable instructions are stored on memory.


The code can be pre-compiled and configured for use with a machine have a processer adapted to execute the code, or can be compiled during runtime. The code can be supplied in a programming language that can be selected to enable the code to execute in a pre-compiled or as-compiled fashion.


Methods and systems of the present disclosure can be implemented by way of one or more methods. A method can be implemented with a processor as described herein, for example by way of software upon execution by one or more computer processors.


IX. Additional Considerations

Alternative views and embodiments of the surgical robotics system 1100, the surgical robotics system 1200, and other surgical robotics systems including the above mentioned components are further illustrated and described at least in U.S. Provisional Application No. 62/162,486 filed May 15, 2015, U.S. Provisional Application No. 62/162,467 filed May 15, 2015, U.S. Provisional Application No. 62/193,604 filed Jul. 17, 2015, U.S. Provisional Application No. 62/201,518 filed Aug. 5, 2015, U.S. Provisional Application No. 62/203,530 filed Aug. 11, 2015, and U.S. Provisional Application No. 62/235,394 filed Sep. 30, 2015.


Upon reading this disclosure, those of skill in the art will appreciate still additional alternative structural and functional designs through the disclosed principles herein. Thus, while particular embodiments and applications have been illustrated and described, it is to be understood that the disclosed embodiments are not limited to the precise construction and components disclosed herein. Various modifications, changes and variations, which will be apparent to those skilled in the art, may be made in the arrangement, operation and details of the method and apparatus disclosed herein without departing from the spirit and scope defined in the appended claims.


As used herein any reference to “one embodiment” or “an embodiment” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.


Some embodiments may be described using the expression “coupled” and “connected” along with their derivatives. For example, some embodiments may be described using the term “coupled” to indicate that two or more elements are in direct physical or electrical contact. The term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other. The embodiments are not limited in this context unless otherwise explicitly stated.


As used herein, the terms “comprises,” “comprising,” “includes,” “including,” “has,” “having” or any other variation thereof, are intended to cover a non-exclusive inclusion. For example, a process, method, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. Further, unless expressly stated to the contrary, “or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).


In addition, use of the “a” or “an” are employed to describe elements and components of the embodiments herein. This is done merely for convenience and to give a general sense of the invention. This description should be read to include one or at least one and the singular also includes the plural unless it is obvious that it is meant otherwise.

Claims
  • 1. A method comprising: displaying a model of a bronchial network of a patient;accessing robotic data, the robotic data including insertion data regarding robotic insertion of an elongated medical instrument into the bronchial network;accessing sensor data captured using a sensor located at least within a distal portion of the elongated medical instrument;determining a robot-based estimated state for the elongated medical instrument based on the insertion data of the robotic data;determining a sensor-based estimated state for the elongated medical instrument based on the sensor data, the sensor-based estimated state associated with a confidence value;based on the confidence value, determining a position of the elongated medical instrument that is at least weighted towards the robot-based estimated state; anddisplaying the determined position of the elongated medical instrument relative to the displayed model of the bronchial network.
  • 2. The method of claim 1, wherein the elongated medical instrument is a flexible endoscope comprising an endoluminal structure and a plurality of cables that may be variously retracted or related to change a direction of the elongated medical instrument, the flexible endoscope coupled to an instrument device manipulator (IDM) to at least one of insert, withdraw, or roll the flexible endoscope from or within the bronchial network.
  • 3. The method of claim 1, wherein the robotic data includes at least one of: a pitch, a roll, or a yaw of the elongated medical instrument, the pitch, the roll, or the yaw being based on a retraction of at least one of a plurality of cables of the elongated medical instrument.
  • 4. The method of claim 1, wherein the sensor-based estimated state indicates a location of the elongated medical instrument within the bronchial network, including at least one of: a position in three-dimensional (3D) space, an orientation in 3D space, an absolute depth of the elongated medical instrument within the bronchial network, a relative depth of the elongated medical instrument within a branch of the bronchial network, and a branch position with respect to a corresponding 3D model of the bronchial network.
  • 5. The method of claim 1, wherein the confidence value represents a degree of confidence in the determination of the sensor-based estimated state, and wherein the confidence value is based on at least one of: a process used to generate the sensor-based estimated state, received data used to generate the sensor-based estimated state, or a possible area where the elongated medical instrument is located within the bronchial network.
  • 6. The method of claim 1, further comprising: accessing a prior estimated state for the elongated medical instrument based on data captured at a prior instant in time, wherein determining the robot-based estimated state is based on the prior estimated state.
  • 7. The method of claim 1, wherein determining the sensor-based estimated state further comprises: performing a registration of a sensor system to a 3D model, the sensor system including coordinates based on received sensor data and the 3D model including coordinates based on a 3D model of the bronchial network; andgenerating the sensor-based estimated state based on the registration.
  • 8. The method of claim 7, wherein the 3D model of the bronchial network is generated based on computerized axial tomography (CT) scans of the bronchial network.
  • 9. The method of claim 1, wherein determining the sensor-based estimated state further comprises: determining an estimate of position and orientation of the elongated medical instrument relative to possible branches within the bronchial network.
  • 10. The method of claim 9, wherein the sensor-based estimated state is represented as a probability distribution, each of value of the probability distribution indicating a likelihood of the elongated medical instrument being inside a corresponding branch among possible branches.
  • 11. The method of claim 1, further comprises determining an image-based estimated state, wherein determining the image-based estimated state further comprises: accessing image data captured by an imaging device located proximal to an instrument tip of the elongated medical instrument;measuring movement of the elongated medical instrument within the bronchial network based on the accessed image data; andgenerating the image-based estimated state based on the measured movement.
  • 12. The method of claim 11, wherein the image-based estimated state is represented as a continuous probability distribution of at least one of: an absolute depth of the elongated medical instrument within the bronchial network,a depth of the elongated medical instrument relative to a corresponding branch, anda roll of the elongated medical instrument relative to the bronchial network.
  • 13. The method of claim 11, wherein determining the image-based estimated state further comprises: mapping between a physically detected object in an actual image and a virtual object generated by a 3D model of the bronchial network,the virtual object corresponding to the physically detected object; andgenerating the image-based estimated state based on the mapped physically detected object and the virtual object.
  • 14. The method of claim 1, further comprising determining an image-based estimated state, wherein determining the image-based estimated state further comprises: determining a topology of an area where the elongated medical instrument is located within the bronchial network; andgenerating image-based estimated state based on the determined topology.
  • 15. The method of claim 14, wherein the determined topology is a division into multiple branches faced by the elongated medical instrument.
  • 16. The method of claim 1, further comprising: affecting the confidence value based on a movement of the patient.
  • 17. The method of claim 1, wherein the confidence value is affected by respiration of the patient.
  • 18. The method of claim 7, further comprising: updating the registration due to movement of the patient.
  • 19. The method of claim 1, further comprising: ordering movement of the elongated medical instrument deeper into the bronchial network; andupdating the robot-based estimated state based on the ordered movement.
  • 20. A robotic medical system for bronchoscopy, the robotic medical system comprising: a robotic;a robotically-controllable bronchoscope removably coupled to the robotic, the bronchoscope configured for insertion into a bronchial network of a patient, wherein a distal end of the bronchoscope is articulable and the bronchoscope includes a sensor;a display;at least one computer-readable medium having stored thereon instructions that, when executed, cause one or more processors to: cause the display to render a model of the bronchial network of the patient;access robotic data, the robotic data including insertion data regarding robotic insertion of the bronchoscope, caused by the robotic, into the bronchial network;access sensor data derived from the sensor of the bronchoscope;determine a robot-based estimated state for the bronchoscope based on the insertion data;determine a sensor-based estimated state for the bronchoscope based on the sensor data, the sensor-based estimated state being associated with a confidence value;based on the confidence value, determine a position of the bronchoscope within the bronchial network based on the robot-based estimated state; anddisplay the determined position of the bronchoscope relative to the displayed model of the bronchial network.
  • 21. The robotic medical system of claim 20, wherein the instructions, when executed, further cause the one or more processors to affect the confidence value based on a movement of the patient.
  • 22. The robotic medical system of claim 20, wherein the instructions, when executed, further cause the one or more processors to perform a registration between a coordinate system of the sensor and a 3D model of the bronchial network, wherein the sensor-based estimated state is further based on the registration.
  • 23. The robotic medical system of claim 22, wherein the instructions, when executed, further cause the one or more processors to update the registration due to a movement of the patient.
  • 24. The robotic medical system of claim 20, wherein the confidence value is affected by respiration of the patient.
  • 25. A robotic medical system for bronchoscopy, the robotic medical system comprising: an instrument device manipulator configured to be coupled with a bronchoscope, the bronchoscope configured to be inserted into a bronchial network of a patient, wherein a distal end of the bronchoscope is articulable and the bronchoscope includes a sensor;a display;at least one computer-readable medium having stored thereon instructions that, when executed, cause one or more processors to: cause the display to render a model of the bronchial network of the patient;access robotic data, the robotic data including insertion data regarding robotic insertion of the bronchoscope into the bronchial network;access sensor data derived from the sensor of the bronchoscope;determine a robot-based estimated state for the bronchoscope based on the insertion data;determine a sensor-based estimated state for the bronchoscope based on the sensor data, the sensor-based estimated state associated with a confidence value;based on the confidence value, determine a position of the bronchoscope that is at least weighted towards the robot-based estimated state; anddisplay the determined position of the bronchoscope relative to the displayed model of the bronchial network.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a continuation of U.S. application Ser. No. 16/222,686, filed Dec. 17, 2018, which is a continuation of U.S. application Ser. No. 15/669,258, filed Aug. 4, 2017, now U.S. Pat. No. 10,169,875, which is a continuation of U.S. application Ser. No. 15/268,238, filed Sep. 16, 2016, now U.S. Pat. No. 9,727,963, which claims the benefit of and priority to U.S. Provisional Application No. 62/220,770 filed Sep. 18, 2015, entitled “NAVIGATION OF TUBULAR NETWORKS,” the entire disclosure of each of which is incorporated herein by reference.

US Referenced Citations (473)
Number Name Date Kind
4745908 Wardle May 1988 A
5273025 Sakiyam et al. Dec 1993 A
5526812 Dumoulin et al. Jun 1996 A
5550953 Seraji Aug 1996 A
5831614 Tognazzini et al. Nov 1998 A
5893045 Kusama et al. Apr 1999 A
5935075 Casscells Aug 1999 A
6038467 De Bliek et al. Mar 2000 A
6047080 Chen Apr 2000 A
6059718 Taniguchi et al. May 2000 A
6063095 Wang et al. May 2000 A
6167292 Badano Dec 2000 A
6203493 Ben-Haim Mar 2001 B1
6246784 Summers Jun 2001 B1
6246898 Vesely Jun 2001 B1
6332089 Acker Dec 2001 B1
6425865 Salcudean et al. Jul 2002 B1
6466198 Feinstein Oct 2002 B1
6490467 Bucholz Dec 2002 B1
6553251 Lahdesmaki Apr 2003 B1
6580938 Acker Jun 2003 B1
6665554 Charles Dec 2003 B1
6690963 Ben-Haim Feb 2004 B2
6690964 Beiger et al. Feb 2004 B2
6775404 Pagoulatos et al. Aug 2004 B1
6812842 Dimmer Nov 2004 B2
6899672 Chin May 2005 B2
6926709 Beiger et al. Aug 2005 B2
7180976 Wink Feb 2007 B2
7206627 Abovitz Apr 2007 B2
7233820 Gilboa Jun 2007 B2
7386339 Strommer et al. Jun 2008 B2
7756563 Higgins Jul 2010 B2
7789874 Yu et al. Sep 2010 B2
7850642 Moll et al. Dec 2010 B2
7901348 Soper et al. Mar 2011 B2
7972298 Wallace et al. Jul 2011 B2
8146874 Yu Apr 2012 B2
8155403 Tschirren Apr 2012 B2
8190238 Moll et al. May 2012 B2
8298135 Ito et al. Oct 2012 B2
8317746 Sewell et al. Nov 2012 B2
8394054 Wallace et al. Mar 2013 B2
8460236 Roelle Jun 2013 B2
8672837 Roelle et al. Mar 2014 B2
8801601 Prisco et al. Aug 2014 B2
8821376 Tolkowsky Sep 2014 B2
8858424 Hasegawa et al. Oct 2014 B2
8929631 Pfister et al. Jan 2015 B2
8968333 Yu et al. Mar 2015 B2
9014851 Wong et al. Apr 2015 B2
9125639 Mathis Sep 2015 B2
9138129 Diolaiti Sep 2015 B2
9183354 Baker et al. Nov 2015 B2
9186046 Ramamurthy et al. Nov 2015 B2
9271663 Walker et al. Mar 2016 B2
9272416 Hourtash et al. Mar 2016 B2
9289578 Walker et al. Mar 2016 B2
9314306 Yu Apr 2016 B2
9326822 Lewis et al. May 2016 B2
9408669 Kokish et al. Aug 2016 B2
9452018 Yu Sep 2016 B2
9452276 Duindam et al. Sep 2016 B2
9459087 Dunbar Oct 2016 B2
9504604 Alvarez Nov 2016 B2
9561083 Yu et al. Feb 2017 B2
9566201 Yu Feb 2017 B2
9603668 Weingarten et al. Mar 2017 B2
9622827 Yu et al. Apr 2017 B2
9629682 Wallace et al. Apr 2017 B2
9636184 Lee et al. May 2017 B2
9710921 Wong et al. Jul 2017 B2
9713509 Schuh et al. Jul 2017 B2
9717563 Tognaccini Aug 2017 B2
9727963 Mintz Aug 2017 B2
9737371 Romo et al. Aug 2017 B2
9737373 Schuh Aug 2017 B2
9744335 Jiang Aug 2017 B2
9763741 Alvarez et al. Sep 2017 B2
9788910 Schuh Oct 2017 B2
9844412 Bogusky et al. Dec 2017 B2
9867635 Alvarez et al. Jan 2018 B2
9918681 Wallace et al. Mar 2018 B2
9931025 Graetzel et al. Apr 2018 B1
9949749 Noonan et al. Apr 2018 B2
9955986 Shah May 2018 B2
9962228 Schuh et al. May 2018 B2
9980785 Schuh May 2018 B2
9993313 Schuh et al. Jun 2018 B2
10016900 Meyer et al. Jul 2018 B1
10022192 Ummalaneni Jul 2018 B1
10046140 Kokish et al. Aug 2018 B2
10080576 Romo et al. Sep 2018 B2
10123755 Walker et al. Nov 2018 B2
10130345 Wong et al. Nov 2018 B2
10136950 Schoenefeld Nov 2018 B2
10136959 Mintz et al. Nov 2018 B2
10143360 Roelle et al. Dec 2018 B2
10143526 Walker et al. Dec 2018 B2
10145747 Lin et al. Dec 2018 B1
10149720 Romo Dec 2018 B2
10159532 Ummalaneni et al. Dec 2018 B1
10159533 Moll et al. Dec 2018 B2
10169875 Mintz et al. Jan 2019 B2
10219874 Yu et al. Mar 2019 B2
10231793 Romo Mar 2019 B2
10231867 Alvarez et al. Mar 2019 B2
10244926 Noonan et al. Apr 2019 B2
10278778 State May 2019 B2
10285574 Landey et al. May 2019 B2
10299870 Connolly et al. May 2019 B2
10314463 Agrawal et al. Jun 2019 B2
10383765 Alvarez et al. Aug 2019 B2
10398518 Yu et al. Sep 2019 B2
10405939 Romo et al. Sep 2019 B2
10405940 Romo Sep 2019 B2
10426559 Graetzel et al. Oct 2019 B2
10426661 Kintz Oct 2019 B2
10434660 Meyer Oct 2019 B2
10492741 Walker et al. Oct 2019 B2
10464209 Ho et al. Nov 2019 B2
10470830 Hill Nov 2019 B2
10482599 Mintz et al. Nov 2019 B2
10493241 Jiang Dec 2019 B2
10500001 Yu et al. Dec 2019 B2
10517692 Eyre et al. Dec 2019 B2
10524866 Srinivasan Jan 2020 B2
10531864 Wong et al. Jan 2020 B2
10539478 Lin Jan 2020 B2
10543048 Noonan et al. Jan 2020 B2
10555778 Ummalaneni et al. Feb 2020 B2
10631949 Schuh et al. Apr 2020 B2
10639108 Romo et al. May 2020 B2
10639109 Bovay et al. May 2020 B2
10639114 Schuh May 2020 B2
10667871 Romo et al. Jun 2020 B2
10667875 DeFonzo Jun 2020 B2
10682189 Schuh et al. Jun 2020 B2
10702348 Moll et al. Jul 2020 B2
10716461 Jenkins Jul 2020 B2
10743751 Landey et al. Aug 2020 B2
10744035 Alvarez et al. Aug 2020 B2
10751140 Wallace et al. Aug 2020 B2
10765303 Graetzel et al. Sep 2020 B2
10765487 Ho Sep 2020 B2
11067387 Marell Jul 2021 B2
20010021843 Bosselmann et al. Sep 2001 A1
20010039421 Heilbrun Nov 2001 A1
20020065455 Ben-Haim et al. May 2002 A1
20020077533 Bieger et al. Jun 2002 A1
20020120188 Brock et al. Aug 2002 A1
20030105603 Hardesty Jun 2003 A1
20030125622 Schweikard Jul 2003 A1
20030181809 Hall et al. Sep 2003 A1
20030195664 Nowlin et al. Oct 2003 A1
20040047044 Dalton Mar 2004 A1
20040072066 Cho et al. Apr 2004 A1
20040186349 Ewers Sep 2004 A1
20040249267 Gilboa Dec 2004 A1
20040263535 Birkenbach et al. Dec 2004 A1
20050027397 Niemeyer Feb 2005 A1
20050060006 Pflueger Mar 2005 A1
20050085714 Foley et al. Apr 2005 A1
20050107679 Geiger May 2005 A1
20050143649 Minai et al. Jun 2005 A1
20050143655 Satoh Jun 2005 A1
20050182295 Soper et al. Aug 2005 A1
20050193451 Quistgaard et al. Sep 2005 A1
20050222554 Wallace et al. Oct 2005 A1
20050256398 Hastings Nov 2005 A1
20050272975 McWeeney et al. Dec 2005 A1
20060004286 Chang Jan 2006 A1
20060015096 Hauck et al. Jan 2006 A1
20060025668 Peterson Feb 2006 A1
20060058643 Florent Mar 2006 A1
20060058647 Strommer et al. Mar 2006 A1
20060084860 Geiger Apr 2006 A1
20060095066 Chang May 2006 A1
20060098851 Shoham May 2006 A1
20060149134 Soper et al. Jul 2006 A1
20060173290 Lavallee et al. Aug 2006 A1
20060184016 Glossop Aug 2006 A1
20060189891 Waxman et al. Aug 2006 A1
20060209019 Hu Sep 2006 A1
20060258935 Pile-Spellman et al. Nov 2006 A1
20060258938 Hoffman et al. Nov 2006 A1
20070032826 Schwartz Feb 2007 A1
20070055128 Glossop Mar 2007 A1
20070055144 Neustadter Mar 2007 A1
20070073136 Metzger Mar 2007 A1
20070083193 Werneth Apr 2007 A1
20070106147 Altmann et al. May 2007 A1
20070123748 Meglan May 2007 A1
20070135886 Maschke Jun 2007 A1
20070156019 Larkin et al. Jul 2007 A1
20070167743 Honda Jul 2007 A1
20070167801 Webler et al. Jul 2007 A1
20070197896 Moll et al. Aug 2007 A1
20070203396 McCutcheon et al. Aug 2007 A1
20070208252 Makower Sep 2007 A1
20070253599 White et al. Nov 2007 A1
20070269001 Maschke Nov 2007 A1
20070293721 Gilboa Dec 2007 A1
20070299353 Harlev et al. Dec 2007 A1
20080071140 Gattani Mar 2008 A1
20080079421 Jensen Apr 2008 A1
20080103389 Begelman et al. May 2008 A1
20080118118 Berger May 2008 A1
20080118135 Averbach May 2008 A1
20080123921 Gielen et al. May 2008 A1
20080147089 Loh Jun 2008 A1
20080183064 Chandonnet Jul 2008 A1
20080183068 Carls et al. Jul 2008 A1
20080183073 Higgins et al. Jul 2008 A1
20080183188 Carls et al. Jul 2008 A1
20080201016 Finlay Aug 2008 A1
20080207997 Higgins et al. Aug 2008 A1
20080212082 Froggatt et al. Sep 2008 A1
20080218770 Moll et al. Sep 2008 A1
20080243142 Gildenberg Oct 2008 A1
20080245946 Yu Oct 2008 A1
20080262297 Gilboa Oct 2008 A1
20080275349 Halperin Nov 2008 A1
20080287963 Rogers et al. Nov 2008 A1
20080306490 Lakin et al. Dec 2008 A1
20080312501 Hasegawa et al. Dec 2008 A1
20090030307 Govari Jan 2009 A1
20090054729 Mori Feb 2009 A1
20090076476 Barbagli et al. Mar 2009 A1
20090149867 Glozman Jun 2009 A1
20090227861 Ganatra Sep 2009 A1
20090248036 Hoffman et al. Oct 2009 A1
20090259230 Khadem Oct 2009 A1
20090262109 Markowitz et al. Oct 2009 A1
20090292166 Ito Nov 2009 A1
20090295797 Sakaguchi Dec 2009 A1
20100008555 Trumer Jan 2010 A1
20100039506 Sarvestani et al. Feb 2010 A1
20100041949 Tolkowsky Feb 2010 A1
20100054536 Huang Mar 2010 A1
20100113852 Sydora May 2010 A1
20100121139 OuYang May 2010 A1
20100160733 Gilboa Jun 2010 A1
20100161022 Tolkowsky Jun 2010 A1
20100161129 Costa et al. Jun 2010 A1
20100225209 Goldberg Sep 2010 A1
20100240989 Stoianovici Sep 2010 A1
20100290530 Huang et al. Nov 2010 A1
20100292565 Meyer Nov 2010 A1
20100298641 Tanaka Nov 2010 A1
20100328455 Nam et al. Dec 2010 A1
20110054303 Barrick Mar 2011 A1
20110092808 Shachar Apr 2011 A1
20110184238 Higgins Jul 2011 A1
20110234780 Ito Sep 2011 A1
20110238082 Wenderow Sep 2011 A1
20110245665 Nentwick Oct 2011 A1
20110248987 Mitchell Oct 2011 A1
20110249016 Zhang Oct 2011 A1
20110276179 Banks et al. Nov 2011 A1
20110319714 Roelle et al. Dec 2011 A1
20110319815 Roelle et al. Dec 2011 A1
20110319910 Roelle et al. Dec 2011 A1
20120046521 Hunter et al. Feb 2012 A1
20120056986 Popovic Mar 2012 A1
20120062714 Liu Mar 2012 A1
20120065481 Hunter Mar 2012 A1
20120069167 Liu et al. Mar 2012 A1
20120071782 Patil et al. Mar 2012 A1
20120082351 Higgins Apr 2012 A1
20120120305 Takahashi May 2012 A1
20120165656 Montag Jun 2012 A1
20120191079 Moll et al. Jul 2012 A1
20120209069 Popovic Aug 2012 A1
20120215094 Rahimian et al. Aug 2012 A1
20120219185 Hu Aug 2012 A1
20120241576 Yu Sep 2012 A1
20120289777 Chopra Nov 2012 A1
20120289783 Duindam et al. Nov 2012 A1
20120302869 Koyrakh Nov 2012 A1
20130060146 Yang et al. Mar 2013 A1
20130090530 Ramamurthy et al. Apr 2013 A1
20130144116 Cooper et al. Jun 2013 A1
20130165945 Roelle Jun 2013 A9
20130204124 Duindam Aug 2013 A1
20130225942 Holsing Aug 2013 A1
20130243153 Sra Sep 2013 A1
20130246334 Ahuja Sep 2013 A1
20130259315 Angot et al. Oct 2013 A1
20130303892 Zhao Nov 2013 A1
20130345718 Crawford Dec 2013 A1
20140058406 Tsekos Feb 2014 A1
20140058428 Christopher et al. Feb 2014 A1
20140094648 Eno et al. Apr 2014 A1
20140107390 Brown Apr 2014 A1
20140114180 Jain Apr 2014 A1
20140148808 Inkpen et al. Apr 2014 A1
20140142591 Alvarez et al. May 2014 A1
20140180063 Zhao Jun 2014 A1
20140235943 Paris Aug 2014 A1
20140243849 Saglam et al. Aug 2014 A1
20140257746 Dunbar et al. Sep 2014 A1
20140264081 Walker et al. Sep 2014 A1
20140275988 Walker et al. Sep 2014 A1
20140276033 Brannan Sep 2014 A1
20140276647 Yu Sep 2014 A1
20140276935 Yu Sep 2014 A1
20140276937 Wong et al. Sep 2014 A1
20140277333 Lewis et al. Sep 2014 A1
20140277334 Yu et al. Sep 2014 A1
20140296655 Akhbardeh et al. Oct 2014 A1
20140309527 Namati et al. Oct 2014 A1
20140309649 Alvarez et al. Oct 2014 A1
20140343416 Panescu Nov 2014 A1
20140350391 Prisco et al. Nov 2014 A1
20140357984 Wallace et al. Dec 2014 A1
20140364739 Liu Dec 2014 A1
20140364870 Alvarez et al. Dec 2014 A1
20150025539 Alvarez et al. Jan 2015 A1
20150051482 Liu et al. Feb 2015 A1
20150054929 Ito Feb 2015 A1
20150057498 Akimoto Feb 2015 A1
20150066053 Itkowitz et al. Mar 2015 A1
20150073266 Brannan Mar 2015 A1
20150119637 Alvarez et al. Apr 2015 A1
20150141808 Elhawary May 2015 A1
20150141858 Razavi May 2015 A1
20150142013 Tanner et al. May 2015 A1
20150223725 Engel Aug 2015 A1
20150223897 Kostrzewski et al. Aug 2015 A1
20150223902 Walker et al. Aug 2015 A1
20150255782 Kim et al. Sep 2015 A1
20150265087 Park Sep 2015 A1
20150265368 Chopra et al. Sep 2015 A1
20150275986 Cooper Oct 2015 A1
20150287192 Sasaki Oct 2015 A1
20150297133 Jouanique-Dubuis et al. Oct 2015 A1
20150305650 Hunter Oct 2015 A1
20150313503 Seibel et al. Nov 2015 A1
20150374641 Kim et al. Dec 2015 A1
20160000302 Brown Jan 2016 A1
20160000414 Brown Jan 2016 A1
20160000520 Lachmanovich Jan 2016 A1
20160001038 Romo et al. Jan 2016 A1
20160008033 Hawkins et al. Jan 2016 A1
20160100896 Yu Apr 2016 A1
20160111192 Suzara Apr 2016 A1
20160128992 Hudson May 2016 A1
20160183841 Duindam et al. Jun 2016 A1
20160184032 Romo et al. Jun 2016 A1
20160199134 Brown et al. Jul 2016 A1
20160206389 Miller Jul 2016 A1
20160213432 Flexman Jul 2016 A1
20160228032 Walker et al. Aug 2016 A1
20160270865 Landey Sep 2016 A1
20160287279 Bovay et al. Oct 2016 A1
20160287346 Hyodo et al. Oct 2016 A1
20160314710 Jarc Oct 2016 A1
20160331469 Hall et al. Nov 2016 A1
20160338785 Kokish et al. Nov 2016 A1
20160360947 Iida Dec 2016 A1
20160372743 Cho et al. Dec 2016 A1
20160374541 Agrawal et al. Dec 2016 A1
20170007337 Dan Jan 2017 A1
20170007343 Yu Jan 2017 A1
20170055851 Al-Ali Mar 2017 A1
20170065363 Schuh et al. Mar 2017 A1
20170065364 Schuh et al. Mar 2017 A1
20170071504 Wang Mar 2017 A1
20170079725 Hoffman Mar 2017 A1
20170079726 Hoffman Mar 2017 A1
20170084027 Mintz et al. Mar 2017 A1
20170119481 Romo et al. May 2017 A1
20170189118 Chopra Jul 2017 A1
20170202627 Sramek et al. Jul 2017 A1
20170209073 Sramek et al. Jul 2017 A1
20170215808 Shimoi et al. Aug 2017 A1
20170215969 Zhai et al. Aug 2017 A1
20170238807 Veritkov et al. Aug 2017 A9
20170258366 Tupin Sep 2017 A1
20170265956 Carlson et al. Sep 2017 A1
20170290631 Lee et al. Oct 2017 A1
20170296032 Li Oct 2017 A1
20170296202 Brown Oct 2017 A1
20170303941 Eisner Oct 2017 A1
20170325896 Donhowe Nov 2017 A1
20170340241 Yamada Nov 2017 A1
20170340396 Romo et al. Nov 2017 A1
20170348067 Krimsky Dec 2017 A1
20170360508 Germain et al. Dec 2017 A1
20170365055 Mintz et al. Dec 2017 A1
20170367782 Schuh et al. Dec 2017 A1
20180025666 Ho et al. Jan 2018 A1
20180055582 Krimsky Mar 2018 A1
20180098690 Iwaki Apr 2018 A1
20180214011 Graetzel et al. Aug 2018 A1
20180217734 Koenig et al. Aug 2018 A1
20180221038 Noonan et al. Aug 2018 A1
20180221039 Shah Aug 2018 A1
20180225884 Yamada Aug 2018 A1
20180240237 Donhowe et al. Aug 2018 A1
20180271616 Schuh et al. Sep 2018 A1
20180279852 Rafii-Tari et al. Oct 2018 A1
20180280660 Landey Oct 2018 A1
20180286108 Hirakawa Oct 2018 A1
20180289431 Draper et al. Oct 2018 A1
20180308247 Gupta Oct 2018 A1
20180325499 Landey et al. Nov 2018 A1
20180360435 Romo Dec 2018 A1
20180368920 Ummalaneni Dec 2018 A1
20190000559 Berman et al. Jan 2019 A1
20190000560 Berman et al. Jan 2019 A1
20190000576 Mintz et al. Jan 2019 A1
20190008595 Popovic Jan 2019 A1
20190046814 Senden et al. Feb 2019 A1
20190066314 Abhari Feb 2019 A1
20190086349 Nelson Mar 2019 A1
20190110839 Rafii-Tari et al. Apr 2019 A1
20190151148 Alvarez et al. Apr 2019 A1
20190125164 Roelle et al. May 2019 A1
20190167366 Ummalaneni Jun 2019 A1
20190175009 Mintz Jun 2019 A1
20190175062 Rafii-Tari et al. Jun 2019 A1
20190175799 Hsu Jun 2019 A1
20190183585 Rafii-Tari et al. Jun 2019 A1
20190183587 Rafii-Tari et al. Jun 2019 A1
20190216548 Ummalaneni Jul 2019 A1
20190216576 Eyre Jul 2019 A1
20190220976 Holsing et al. Jul 2019 A1
20190223974 Romo Jul 2019 A1
20190228525 Mintz et al. Jul 2019 A1
20190262086 Connolly et al. Aug 2019 A1
20190269468 Hsu et al. Sep 2019 A1
20190274764 Romo Sep 2019 A1
20190287673 Michihata Sep 2019 A1
20190290109 Agrawal et al. Sep 2019 A1
20190298160 Ummalaneni et al. Oct 2019 A1
20190298460 Al-Jadda Oct 2019 A1
20190298465 Chin Oct 2019 A1
20190336238 Yu Nov 2019 A1
20190365209 Ye et al. Dec 2019 A1
20190365479 Rafii-Tari Dec 2019 A1
20190365486 Srinivasan et al. Dec 2019 A1
20190375383 Alvarez Dec 2019 A1
20190380787 Ye Dec 2019 A1
20190380797 Yu Dec 2019 A1
20200000533 Schuh Jan 2020 A1
20200022767 Hill Jan 2020 A1
20200039086 Meyer Feb 2020 A1
20200046434 Graetzel Feb 2020 A1
20200054408 Schuh et al. Feb 2020 A1
20200060516 Baez Feb 2020 A1
20200078103 Duindam Mar 2020 A1
20200093549 Chin Mar 2020 A1
20200093554 Schuh Mar 2020 A1
20200100845 Julian Apr 2020 A1
20200100855 Leparmentier Apr 2020 A1
20200101264 Jiang Apr 2020 A1
20200107894 Wallace Apr 2020 A1
20200121502 Kintz Apr 2020 A1
20200146769 Eyre May 2020 A1
20200155084 Walker May 2020 A1
20200170630 Wong Jun 2020 A1
20200170720 Ummalaneni Jun 2020 A1
20200188043 Yu Jun 2020 A1
20200197112 Chin Jun 2020 A1
20200206472 Ma Jul 2020 A1
20200217733 Lin Jul 2020 A1
20200222134 Schuh Jul 2020 A1
20200237458 DeFonzo Jul 2020 A1
20200261172 Romo Aug 2020 A1
20200268459 Noonan et al. Aug 2020 A1
20200268460 Tse Aug 2020 A1
Foreign Referenced Citations (46)
Number Date Country
101147676 Mar 2008 CN
101222882 Jul 2008 CN
101222882 Jul 2008 CN
102316817 Jan 2012 CN
102458295 May 2012 CN
102973317 Mar 2013 CN
103417184 Dec 2013 CN
103607959 Feb 2014 CN
103735313 Apr 2014 CN
103874525 Jun 2014 CN
104853799 Aug 2015 CN
105559850 May 2016 CN
105559850 May 2016 CN
105559886 May 2016 CN
105611881 May 2016 CN
106821498 Jun 2017 CN
104931059 Sep 2018 CN
109077699 Dec 2018 CN
1543766 Jun 2005 EP
3 025 630 Jun 2016 EP
3246135 Nov 2017 EP
2007527296 Sep 2007 JP
10-2014-0009359 Jan 2014 KR
2569699 Nov 2015 RU
1991009375 Jun 1991 WO
WO 05087128 Sep 2005 WO
2007039905 Apr 2007 WO
WO 09097461 Jun 2007 WO
2008076910 Jun 2008 WO
2009097461 Aug 2009 WO
2008065600 Nov 2009 WO
2009100147 Nov 2009 WO
2009148317 Dec 2009 WO
2008111070 Feb 2010 WO
2010124285 Oct 2010 WO
2011063266 May 2011 WO
2012131550 Oct 2012 WO
2013134782 Sep 2013 WO
2014058838 Apr 2014 WO
2014138652 Sep 2014 WO
2015061756 Apr 2015 WO
WO 15089013 Jun 2015 WO
2016001782 Jan 2016 WO
WO 17048194 Mar 2017 WO
WO 17066108 Apr 2017 WO
WO 17167754 Oct 2017 WO
Non-Patent Literature Citations (59)
Entry
Devin V. Amin et al., Ultrasound Registration of the Bone Surface for Surgical Navigation, Computer Aided Surgery, 8:1-16, 2003, 17 pages.
Heinz-Theo Luebbers et al., Comparison of different registration methods for surgical navigation in cranio-maxillofacial surgery, Journal of Cranio-Maxillofacial Surgery, 36:109-116, 2008, 8 pages.
Intuitive, System, Instruments, and Accessories User Manual, 91 pages.
Ion by Intuitive, available at https://www.intuitive.com/en-us/products-and-services/ion, last accessed Aug. 12, 2021, 6 pages.
Jeffrey H. Shuhaiber, Augmented Reality in Surgery, Archive of Surgery, 139:170-174, Feb. 2004, 5 pages.
Matthias Baumhauer et al., Navigation in Endoscopic Soft Tissue Surgery—Perspectives and Limitations, Journal of Endourology, 22(4):1-15, 2008, 16 pages.
MicroBIRD Product Brochure, Ascension Technology Corporation, available at http://www.ascension-tech.com/products/microbird.php, Jun. 12, 2019, 3 pages.
Robert Galloway & Terry Peters, Chapter 1: Overview and History of Image-Guided Interventions; David Holmes III et al, Chapter 3: Visualization in Image-Guided Interventions; Ziv Yaniv, Chapter 6: Rigid Registration, in Image-Guided Interventions: Technology and Applications, Terry Peters & Kevin Cleary eds., 2008, 95 pages.
Sargent, Dusty & Chen, Chao-I & Wang, Yuanfang, Cross Modality Registration of Video and Magnetic Tracker Data for 3D Appearance and Structure Modeling. Proceedings of SPIE—The International Society for Optical Engineering, 2010, 8 pages.
CN Office action dated for appl No. 201680061053, dated Jun. 1, 2021, 10 pages.
Ciuti et al., 2012, Intra-operative monocular 30 reconstruction for image-guided navigation in active locomotion capsule endoscopy. Biomedical Robotics and Biomechatronics (Biorob), 4th IEEE Ras & Embs International Conference on IEEE.
Fallavollita et al., 2010, Acquiring multiview C-arm images to assist cardiac ablation procedures, EURASIP Journal on Image and Video Processing, vol. 2010, Article ID 871408, pp. 1-10.
Haigron et al., 2004, Depth-map-based scene analysis for active navigation in virtual angioscopy, IEEE Transactions on Medical Imaging, 23(11):1380-1390.
Kiraly et al, 2002, Three-dimensional Human Airway Segmentation Methods for Clinical Virtual Bronchoscopy, Acad Radiol, 9:1153-1168.
Kiraly et al., Sep. 2004, Three-dimensional path planning for virtual bronchoscopy, IEEE Transactions on Medical Imaging, 23(9):1365-1379.
Konen et al., 1998, The VN-project: endoscopic image processing for neurosurgery, Computer Aided Surgery, 3:1-6.
Kumar et al., 2014, Stereoscopic visualization of laparoscope image using depth information from 3D model, Computer methods and programs in biomedicine 113(3):862-868.
Livatino et al., 2015, Stereoscopic visualization and 3-D technologies in medical endoscopic teleoperation, IEEE.
Luo et al., 2010, Modified hybrid bronchoscope tracking based on sequential monte carlo sampler: Dynamic phantom validation, Asian Conference on Computer Vision. Springer, Berlin, Heidelberg.
Mayo Clinic, Robotic Surgery, https://www.mayoclinic.org/tests-procedures/robotic-surgery/about/pac-20394974?p=1, downloaded from the internet on Jul. 12, 2018, 2 pp.
Mourgues et al., 2002, Flexible calibration of actuated stereoscopic endoscope for overlay in robot assisted surgery, International Conference on Medical Image Computing and Computer-Assisted Intervention. Springer, Berlin, Heidelberg.
Nadeem et al., 2016, Depth Reconstruction and Computer-Aided Polyp Detection in Optical Colonoscopy Video Frames, arXiv preprint arXiv:1609.01329.
Point Cloud, Sep. 10, 2010, Wikipedia, 2 pp.
Racadio et al., Dec. 2007, Live 3D guidance in the interventional radiology suite, AJR, 189:W357-W364.
Sato et al., 2016, Techniques of stapler-based navigational thoracoscopic segmentectomy using virtual assisted lung mapping (VAL-MAP), Journal of Thoracic Disease, 8(Suppl 9):S716.
Shen et al., 2015, Robust camera localisation with depth reconstruction for bronchoscopic navigation. International Journal of Computer Assisted Radiology and Surgery, 10(6):801-813.
Shi et al., Sep. 14-18, 2014, Simultaneous catheter and environment modeling for trans-catheter aortic valve implantation, IEEE/RSJ International Conference on Intelligent Robots and Systems, pp. 2024-2029.
Solheim et al., May 14, 2009, Navigated resection of giant intracranial meningiomas based on intraoperative 3D ultrasound, Acta Neurochir, 151:1143-1151.
Solomon et al., Dec. 2000, Three-dimensional CT-Guided Bronchoscopy With a Real-Time Electromagnetic Position Sensor A Comparison of Two Image Registration Methods, Chest, 118(6):1783-1787.
Song et al., 2012, Autonomous and stable tracking of endoscope instrument tools with monocular camera, Advanced Intelligent Mechatronics (AIM), 2012 IEEE-ASME International Conference on. IEEE.
Vemuri et al., Dec. 2015, Inter-operative biopsy site relocations in endoluminal surgery, IEEE Transactions on Biomedical Engineering, Institute of Electrical and Electronics Engineers, <10.1109/TBME.2015.2503981>. <hal-01230752>.
Verdaasdonk et al., Jan. 23, 2012, Effect of microsecond pulse length and tip shape on explosive bubble formation of 2.78 μm Er,Cr;YSGG and 2.94 μm Er:YAG laser, Proceedings of SPIE, vol. 8221, 12.
Wilson et al., 2008, a buyer's guide to electromagnetic tracking systems for clinical applications, Proc. of SPCI, 6918:69182B-1 p. 6918B-11.
Yip et al., 2012, Tissue tracking and registration for image-guided surgery, IEEE transactions on medical imaging 31(11):2169-2182.
Zhou et al., 2010, Synthesis of stereoscopic views from monocular endoscopic videos, Computer Vision and Pattern Recognition Workshops (CVPRW), 2010 IEEE Computer Society Conference on IEEE.
Extended European Search Report dated Apr. 8, 2019 in patent application No. 16847447.6.
International Search Report and Written Opinion for PCT Application No. PCT/US16/52257, dated Nov. 29, 2016, 13 pages.
Al-Ahmad et al., dated 2005, Early experience with a computerized robotically controlled catheter system, Journal of Interventional Cardiac Electrophysiology, 12:199-202.
Gutierrez et al., Mar. 2008, A practical global distortion correction method for an image intensifier based x-ray fluoroscopy system, Med. Phys, 35(3):997-1007.
Hansen Medical, Inc. 2005, System Overview, product brochure, 2 pp., dated as available at http://hansenmedical.com/system.aspx on Jul. 14, 2006 (accessed Jun. 25, 2019 using the internet archive way back machine).
Hansen Medical, Inc. Bibliography, product brochure, 1 p., dated as available at http://hansenmedical.com/bibliography.aspx on Jul. 14, 2006 (accessed Jun. 25, 2019 using the internet archive way back machine).
Hansen Medical, Inc. dated 2007, Introducing the Sensei Robotic Catheter System, product brochure, 10 pp.
Hansen Medical, Inc. dated 2009, Sensei X Robotic Catheter System, product brochure, 5 pp.
Hansen Medical, Inc. Technology Advantages, product brochure, 1 p., dated as available at http://hansenmedical.com/advantages.aspx on Jul. 13, 2006 (accessed Jun. 25, 2019 using the internet archive way back machine).
Marrouche et al., dated May 6, 2005, AB32-1, Preliminary human experience using a novel robotic catheter remote control, Heart Rhythm, 2(5):S63.
Oh et al., dated May 2005, P5-75, Novel robotic catheter remote control system: safety and accuracy in delivering RF Lesions in all 4 cardiac chambers, Heart Rhythm, 2(5):S277-S278.
Reddy et al., May 2005, P1-53. Porcine pulmonary vein ablation using a novel robotic catheter control system and real-time integration of CT imaging with electroanatomical mapping, Hearth Rhythm, 2(5):S121.
Slepian, dated 2010, Robotic Catheter Intervention: the Hansen Medical Sensei Robot Catheter System, PowerPoint presentation, 28 pp.
Office Action for appl No. 2021003293, dated Jan. 21, 2022, 2 pages.
AU Examination report for appl No. 2021203525, dated Feb. 25, 2022, 3 pages.
International Search Report for PCT Application No. PCT/US2016/052257, dated Nov. 29, 2016, 3 pages.
International Written Opinion for PCT Application No. PCT/US2016/052257, dated Nov. 29, 2016, 5 pages.
Non-Final Rejection for U.S. Appl. No. 15/669,258, dated Oct. 19, 2017, 6 pages.
Notice of Allowance for U.S. Appl. No. 15/268,238, dated Apr. 6, 2017, 8 pages.
Notice of Allowance for U.S. Appl. No. 15/669,258, dated Apr. 30, 2018, 8 pages.
Notice of Allowance for U.S. Appl. No. 15/669,258, dated Aug. 28, 2018 11 pages.
Otice of Allowance for U.S. Appl. No. 15/669,258, dated May 24, 2018, 8 pages.
PCT International Search Report and Written Opinion, PCT Application No. PCT/US2016/052257, dated Nov. 29, 2016, 13 pages.
U.S. Appl. No. 62,185,135, filed Jun. 26, 2015, Inventors: Varun Agrawal et al., 93 pages.
Related Publications (1)
Number Date Country
20210049762 A1 Feb 2021 US
Provisional Applications (1)
Number Date Country
62220770 Sep 2015 US
Continuations (3)
Number Date Country
Parent 16222686 Dec 2018 US
Child 17004669 US
Parent 15669258 Aug 2017 US
Child 16222686 US
Parent 15268238 Sep 2016 US
Child 15669258 US