The present invention relates to a method and a system for computing a path for a minimally invasive device to reach a target while avoiding critical structures and minimizing damage to structures. This path may be used to either control a device (e.g., a bronchoscope or a beveled needle) or may be used to construct a device (e.g., a nested cannula).
Such path planning applications may be performed using the framework taught by Karen I. Trovato, A*Planning in Discrete Configuration Spaces of Autonomous System, University of Amsterdam, 1996.
Specifically, a path planning application must be characterized by a set of key parameters. Each parameter has one or more ranges of valid parameter values that are discretized for easier computer calculation. A combination of all the possible parameter ranges is called the configuration space, and each state of the configuration space provides a unique setting for each of these parameters. Since the configuration space is a discretized space, each state of the configuration space may be considered a ‘node’ in an N-dimensional graph (frequently N=2 or 3, but sometimes much higher). ‘State’ and ‘node’ are used interchangeably herein.
A neighborhood encapsulates a set of potential transitions based on the core capabilities of the system or device, typically within a certain range. A transition from one state in the configuration space to another ‘neighboring’ state may be caused by an event or physical motion. The ‘neighbors’ may also be determined based upon physics or ‘rules of the game’. Thus, a neighborhood may include all positions for a knight within one move on an empty chessboard.
Assigned to each transition is a cost imposed for changing between a ‘home’ state and a neighboring state. Therefore, the combination of the states in configuration space with the neighborhood transitions between them may be imagined as a graph with the states as nodes and transitions as cost-weighted, directed edges. For many path-planning applications, constraints exist that define illegal states, often because of mechanical limitations, interaction with obstacles, or imposed rules. Thus, there may be identifiable forbidden region(s) of nodes in the configuration space. This can be achieved in many ways. For example, the transitions into a forbidden configuration node may be removed, indicating an illegal move. Alternatively, the nodes may be marked as illegal, or transitions into the node may have infinite (unattainable and high) cost, denoted by ∞. Each technique causes the path to avoid obstacles.
Illegal states also have a downstream effect. For example, the neighborhood of motions for a car might be an arc of travel forward, in a quarter turn. If a state along the curve is blocked by a corner (an obstacle), then not only is the transition into the corner forbidden, but the transitions beyond the corner are also forbidden.
A ‘goal’ (or target) position may be mapped to one or more equivalent ‘goal’ nodes in the discretized configuration space. Multiple ‘goal’ nodes may exist because the formulation of parameters expressing the system may have more than one solution describing the system ‘goal’. For example, both left-handed and right-handed configurations of your arm can reach the same location. The system ‘start’ is simply transformed to a specific starting node, which is often the current state (i.e. status) of the system or device.
Finding the most desirable series of events leading from a current system node (start) to a desired ‘goal’ is analogous to finding an optimal path of transitions from the current node to the ‘goal’ node that incurs a minimum cost while avoiding all illegal nodes. It is also taught that the path may be computed from either the start to the goal, or from the goal to the start. In both cases, the connection of transitions forms a resulting path. Path planning often has a criterion for success sometimes called a space variant metric, a cost metric, or an objective function (e.g., a fastest, shortest, least expensive, etc.). The desirable series of events therefore may be found by planning a path using the configuration space nodes, neighborhood of transitions, costs, forbidden regions, and ‘goal’, and by defining or setting a ‘starting node’. A graph search method such as A* provides an efficient mechanism to determine the optimal path.
As will be further explained herein, the present invention provides a structural damage quantification metric (measure) and a target node geometric expansion that expands the utilization of the subject framework taught by Trovato. For example, a kinematically feasible set of nested cannulas can be computed based on an optimal path for the device that minimizes damage to critical structures during a minimally invasive surgery.
One form of the present invention is a method for planning a path according to a surgical application incorporating a structural damage assessment technique. The method involves a construction of a configuration space structure within a data storage medium, the configuration space structure representing a discretized configuration space of an anatomical region of a body, including free-space configuration nodes and forbidden configuration nodes. The method further involves a generation of a structural damage assessment for each free-space configuration node, the structural damage assessment being indicative of a damage assessment of potential damage to one or more anatomical areas of the anatomical region represented by the forbidden configuration node(s) having an infinite structural assessment cost.
In a second form of the present invention, the planning method incorporates the geometric expansion technique. Specifically, the method further involves an augmentation of the configuration space node structure as constructed within the data storage medium with parameter values quantifying each node of the configuration space node structure, wherein the augmentation of the configuration space node structure includes a geometric expansion of a target node involving one or more free-space configuration nodes geometrically neighboring the target node serving as surrogate seed node(s).
The foregoing forms and other forms of the present invention as well as various features and advantages of the present invention will become further apparent from the following detailed description of various embodiments of the present invention read in conjunction with the accompanying drawings. The detailed description and drawings are merely illustrative of the present invention rather than limiting, the scope of the present invention being defined by the appended claims and equivalents thereof.
The present invention is premised on three (3) primary inventive principles.
First, a discretized configuration space for path planning applications as related to minimally invasive surgeries may be enhanced by creating a ‘structural damage assessment’ that provides a cost estimate or penalty accrued by traversing specific anatomical areas (e.g., critical anatomical structures within an anatomical region and fragile entry points into the anatomical region). This might be stored in the configuration space itself, or is preferably stored in a separate structure or as a function. The structural damage assessment will facilitate path planning within the anatomical region that minimizes overall damage.
For example, as related to brain surgery, travel through fragile entry points along the skull (e.g., the temple) is undesirable since this path will require subsequent reconstructive surgery. Furthermore, any damage to critical structures of the brain (e.g., blood vessels, ventricles, pituitary glands, pons and optic nerves) may mean loss of life or of key life functions. Even if they are small areas, they could have a very high cost. The utilization of a structural damage assessment aids minimally invasive surgery planning by minimizing, if not preventing, any damage to the critical structures and fragile entry points. As will be further explained, for an A* algorithm, structural damage assessment values may be used in conjunction with the cost metric and heuristic parameter values to search through a discretized configuration space that avoid obstacles, but also maintains a safe spacing from such obstacles.
Second, a preferred entry point or area may be highlighted, given the target and structural damage assessment, such as, for example, the Brodmann areas of brain chart 100 shown in
Third, prior path planning applications have been defined for devices including nested cannulas, steerable needles and bronchoscopes. Nested cannulas extend sequentially, from largest to smallest, and are curved in different directions to reach far into the anatomy. The method for configuring these devices is described in International Publication WO 2008/032230 entitled “Active Cannula Configuration for Minimally Invasive Surgery” by Karen I. Trovato. Since nested cannulas do not have motorized joints along their length, nor ‘marionette wires’ for control, they may be made very small, which is useful for brain applications as well as many other minimally invasive procedures. The steering of other devices such as a bronchoscope and beveled needle is described in International Publication WO 2007/042986 entitled “3D Tool Path Planning, Simulation and Control System” of Karen I. Trovato et al. For some devices and applications, the approach orientation to a target may not be easily identifiable or selectable.
A common problem is how to create multiple approach orientations to a target, for example, the center of a tumor, without tedious manual entry, while maintaining a 3D configuration space for 6D planning. In a simple example, the approach orientation may be formed by the direction from adjacent neighbors to a seed node. The search direction is therefore set to the opposite direction (from seed to adjacent neighbors). This “geometric expansion” provides a simple, achievable variety of orientations while covering all surrounding directions. If these neighbors are within acceptable accuracy to represent the target, they may be used as surrogate ‘seeds’, having zero cost and the defined orientation for initiating the A* search, as long as they are not in a forbidden or infinite cost location. Clearly, geometric neighborhoods of many shapes and sizes may be used, not just those that are immediately adjacent, however they must define viable final motions or actions. Finally, the geometric neighborhood used to set the orientation of surrogate seeds does not necessarily have to match the neighborhood used during the A* search.
For example,
It is to be understood by persons of ordinary skill in the art that the following description of
The present invention introduces a structural damage assessment technique 112 and a geometric expansion technique 113 that may individually or collectively be incorporated in setup phase 110 and path planning phase 111 of the path planning application. In general terms, a configuration space node structure includes a plurality of nodes with each node being at a different discrete location in the discretized configuration space as characterized by the parameter(s), and technique 112 provides for the use of structural damage assessment values explicitly quantifying a damage assessment of potential damage to anatomical structures of the anatomical region of the body while technique 113 provides for the use of one or more geometrically neighboring free-space neighbors of a target node as surrogate seed nodes during an execution of a search through the free-space of the discretized configuration space.
Exemplary embodiment of techniques 112 and 113 as shown in
A. Path Planning Method Incorporating a Structural Risk Assessment and Geometric Expansion
Referring to
Stage 121 encompasses a detection of anatomical areas within an anatomical region of a body for which it is critical to minimize or prevent any damage to the structures. These critical areas include, but are not limited to, fragile entry points into the anatomical region and fragile structures within the anatomical region susceptible to damage from an instrument used during a minimally invasive surgery in the region, such as, for example, the brain vasculature/brain ventricles 130 shown in
Conversely, for critical areas not detectable from imaging, a registration between segmented patient specific data and an anatomical/functional atlas may be used.
Stage S122 encompasses a structural damage assessment for each free-space configuration node representing non-critical areas of the anatomical region as being safe or risky. In general terms, the cost of each forbidden configuration node representing the detected critical areas (obstacle and fragile entry points) of the anatomical region corresponds to a critical anatomical area having an infinite risk cost. Conversely, the risk cost of each safe free-space configuration node has a zero risk of structural damage while each risky free-space configuration node has an estimated risk of structural damage ranging from a non-zero, finite cost to an infinite cost. In summary, a forbidden configuration node cost is C=∞, a safe free-space configuration node cost is C=0, and a risky free-space configuration node cost is C≦∞.
In one embodiment of stage S122, the costs associated with each free-space configuration node, may be set by a user, derived from forbidden configuration nodes or a combination of individual set costs and the forbidden configuration nodes, or may be set by a computer program, for example from an automatic segmentation process. For example, for a neurosurgical application, joint costs might be formed by combining (e.g. adding or averaging): a) a cost for nearby critical points or areas (e.g. distance from critical anatomical areas) and b) a non-forbidden, risky cost.
A stage S154 of flowchart 150 encompasses a generation of an empirical data map from the labeled image with the empirical data being indicative of the physical sensitivity of each critical anatomical area (obstacles and fragile entry points) to an external stimuli (surgical instruments/tools). For example, an empirical weight map 163 shown in
A stage S155 of flowchart 150 encompasses a combination of the obstacle distance map and the empirical data map based on a combination (e.g., a summation and/or an averaging) of matching nodes. For example, in
While those having ordinary skill in the art will appreciate flowchart 150 as shown will facilitate a very high safety to forbidden points and areas, the following is a description of alternative embodiments of flowchart 150 that may be implemented in practice.
In a first alternative embodiment of flowchart 150, dilated obstacle mapping stage S152 may be omitted as indicated by the dashed arrow leading from base obstacle mapping stage S151 to obstacle distance mapping stage S153.
In a second alternative embodiment of flowchart 150, obstacle distance mapping stage S153 may be omitted as indicated by the dashed arrow leading from dilated obstacle mapping stage S152 to mapping combination stage S155.
In a third alternative embodiment of flowchart 150, both dilated obstacle mapping stage S152 and obstacle distance mapping stage S153 may be omitted as indicated by the dashed arrow leading from base obstacle mapping stage S151 to mapping combination stage S155.
In a fourth alternative embodiment of flowchart 150, obstacle mapping stages S151-S153 may be omitted whereby empirical weighted mapping stage S154 is exclusively utilized for structural damage assessment cost computation.
In a fifth alternative embodiment of flowchart 150, empirical weighted mapping stage S154 may be omitted individually or with one or more of the obstacle mapping stages S151-S153 whereby the remaining obstacle mapping stage(s) is(are) utilized for structural damage assessment cost computation.
Referring again to
Stage S123 encompasses a user or computer identified target point, such as a tumor centroid, and a user or computer-identified set of one or more acceptable tool-insertion points/areas for the applicable surgical procedure. For example, a single insertion area for a surgical instrument (e.g., a nested cannula) in the lung might be the cross-section of the trachea at a specific CT slice. Alternatively, one or more insertion areas may be selected for entrance of the surgical instrument from any non-fragile area of the skull. A viable path only exists if it is possible to reach from the entrance to the target, with acceptable overall cost. A physician, who weighs the risk and the benefit, must determine the limits of ‘acceptability’.
Stage S124 encompasses a propagation from the target point to the insertion point(s) and/or insertion area(s) via an A* algorithm. In one embodiment of stage S124, a flowchart 170 as shown in
Referring to
Referring to
In execution, a first expanded ‘seed’ node is placed into the heap in order to begin cost wave propagation, or A*. The heap is a balanced binary tree that maintains the lowest cost value at the root. The lowest cost node taken from the heap is called ‘home’, in step S191 of flowchart 190. In earlier robotics and path planning applications, the path was often generated using goals as the seed nodes. In those applications, the cost of a node (g(n), described later) was called ‘cost_to_goal’. In this application, we revise the terminology to the more general ‘cost_to_seed’, but they should be considered equivalently. There are well-known algorithms for managing sort structures, including heaps.
Step S191 further encompasses the acquisition of the detailed configuration space information of the ‘home’ node, preferably the explicit discrete parameter values of the home node. This will provide the precession desired for the cost wave propagation without any negative impact on the speed and memory capacities of a system executing flowchart 190.
A step S192 of flowchart 190 encompasses a testing of a “stopping criterion”. There are many tests that may be performed to determine if the process may stop. The “stopping criterion” may include, but not limited to, (1) a test of whether the heap is empty and (2) a test of whether the current ('home') node's is one of identified insertion points or belongs to one of insertion areas. This stopping criterion assures that there a viable connection between the insertion and target, and that value is a minimum for that location. This enables the search to terminate before the entire space is filled, yet nonetheless it does give the optimal path between the ‘start’ and ‘goal’. A third stopping criterion customized for the present invention involves a presentation of a colored coded surface of a reached insertion point or insertion area previously selected by a user based on the cost to reach the insertion point or insertion area whereby a selection of an entrance point by a user is considered a selection of an optimal path between the ‘start’ and ‘goal’.
If the ‘stopping criterion’ is met, then flowchart 190 is terminated. Otherwise, if the “stopping criterion’ is not met, then a step S193 of flowchart 190 encompasses a generation of the neighborhood of permissible transitions. The neighbors of the ‘home’ node are calculated based on the ‘home’ node's orientations given by its alpha, theta and phi as well as its ‘home’ x, y, z location. The neighborhood results from rotating the nominal neighborhood by alpha, theta and phi, and then translating the already rotated neighborhood relative to the ‘home’ node's x, y, z location. Methods for rotation and translation of points are well known to those skilled in the art.
The resulting neighborhood is then translated and rotated to the location of the current expanding node.
Once the neighbors for the current ‘home’ node are computed, flowchart 190 proceeds to a step S194 where the next thread (T) of the neighborhood is chosen, if any. If there are no more threads, then flowchart 190 returns to step S191. Otherwise, if there is a thread (T), then flowchart 190 proceeds to a step S195 to chose next neighbor (n′) along the thread (T) if any. The position and orientation of neighbor n′ is computed relative to the ‘home’ node's position and orientation for the current given thread.
If there are no more neighbors along this thread (T), then flowchart 190 returns to step S194. If there is another neighbor (n), then flowchart 190 proceeds to a step 196 to test the cost value of the neighbor. If the cost is infinite, or there is another indication that the neighbor is not passable, then flowchart 190 returns to step S194. Another indication might be that the neighbor has a cost value higher than some pre-determined threshold, which is less than infinity, but too high to pass. This threshold may be a function of the current distance traveled (at the ‘home’ node), for example.
If the neighbor does not have infinite cost and is passable, the flowchart 190 proceeds to step S197 to calculate the proposed new cost g(n′) for the new neighbor, n′. In the A* algorithm, two costs are computed. The first is called ‘g(n′)’. This is the cost of the best path (so far) to node n′, that arrives from a ‘home node’ or ‘parent node’, often denoted as n, without a prime (′). The function g(n′) includes the cost to reach the home node, plus the transition cost from the home node to n′, plus any structural damage that might arise from transitioning from home to n′. When planning a path for the nested cannula, the length of the path is often the transition cost. The structural damage incurred from travelling from home to n′ may be calculated as the sum of each interim state's structural damage cost, counting states beyond n (since n has already been counted), through and including n′. This can also be computed in an alternative way, where the overall structural damage considers the size of the tube as it traverses each voxel (volume element), such that the integral volume swept by the tube is weighted by the various structural damage regions, for example. Therefore, a 3 mm diameter tube may be expected to generate twice the damage of a 1.5 mm diameter tube. Another alternative may occur when the over-riding cost is the total structural damage regardless of distance. In this case, the transition cost may be only an estimate of structural damage with no cost incurred for distance.
The second value computed in A* is f(n′), which in simplest terms is the ‘best case scenario’ for a path that first travels through ‘home’ (by whichever path it arrives from the seed), then travels through n′ (including penalties), and finally proceeds optimistically (directly) to the entry point using a heuristic function, h(n′). As is known to those skilled in the art, there are many possible heuristics. An optimistic cost for the heuristic might be zero, for example, however this uninformed heuristic does not provide guidance for the search. Another commonly used heuristic is the straight-line, or Euclidean distance ‘as the crow flies’, or in other words, the ‘distance to go’. Yet another estimate might be the total structural damage cost over the remaining distance with the current sized tube. By choosing a heuristic that is optimistic, the overall cost of f(n′) then represents the net desire-ability of a path that goes through n′. In summary,
g(n′)=g(‘home’)+transition(‘home’, n′)+C(‘home’, n′)
f(n′)=g(n′)+h(n′)
The costs for g(n′) and f(n′) are often stored with other data for node n′.
Flowchart 190 thereafter proceeds to a step S198 to compare the newly calculated cost F(n′) with the pre-existing cost at n′, F(n′). If the newly calculated F(n′) is greater than pre-existing cost F(n′), then it is more costly to reach n via the ‘home’ node than whatever was determined previously (i.e., there is no improvement), and flowchart 190 returns to step S195. If the calculated cost, F(n′) is less than pre-existing cost F(n′), then this value is an improvement over the prior directions whereby flowchart 190 proceeds from step S198 to step S199. Step S199 adds the neighbor node to the set of possible nodes for opening (expanding) next. This set may be stored in a heap, for example, and the set sorted via a heap sort. If the neighbor node is already on the heap, then the values of the node are updated and the heap is re-sorted. The node x, which has the lowest cost f(x) therefore identifies the most desirable node to explore (expand) next.
Step S199 further encompasses assigning the new cost_to_seed to n, as well as the specific position (e.g. x, y, z) and orientation (e.g. alpha, theta and phi). In a 6D space, position and orientation are represented with a 3D position (x, y, z) and 3 angles (alpha, theta, phi). If a set of permissible motions is captured in a neighborhood structure with discrete angular displacement (for example
Referring back to
Sekhar, Fessler. Atlas of Neurosurgical Techniques. Chapter 33: Stereotactic Biopsy (Schwartz and Sisti), pp. 422-429. For example, the planned path may provide between a target and 4 equivalent minimum-cost entry points on the skull. There also may be 10 other locations highlighted, along with their respective higher costs. The doctor may choose one of these points, which must be on a suitable stopping location or subject to a stopping criterion.
Based on the selected point, the path will be extracted that determines the set of control parameters, or the configuration of the device, or the intended path from the selected point to the target. Optionally, this path may be presented within a 3D image of the anatomical region during stage S126.
B. Path Planning System Incorporating a Structural Risk Assessment and/or Geometric Expansion
Referring now to
The method or system are used to create a path. This path may be used in several ways. The path can either control a device, such as a bronchoscope or beveled needle. Alternatively, it may be used to construct a device such as a nested cannula. Finally, it may be displayed on a screen, or superimposed in a 3D image and displayed within 3D goggles.
While various embodiments of the present invention have been illustrated and described, it will be understood by those skilled in the art that the methods and the system as described herein are illustrative, and various changes and modifications may be made and equivalents may be substituted for elements thereof without departing from the true scope of the present invention. In addition, many modifications may be made to adapt the teachings of the present invention to entity path planning without departing from its central scope. Therefore, it is intended that the present invention not be limited to the particular embodiments disclosed as the best mode contemplated for carrying out the present invention, but that the present invention include all embodiments falling within the scope of the appended claims.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB2009/054993 | 11/10/2009 | WO | 00 | 6/15/2011 |
Number | Date | Country | |
---|---|---|---|
61141070 | Dec 2008 | US |