Skip to content

Commit

Permalink
[doc] Fix doxygen links using absolute path for images
Browse files Browse the repository at this point in the history
  • Loading branch information
epernod committed Jan 12, 2024
1 parent 09ada06 commit 67678b8
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 11 deletions.
6 changes: 3 additions & 3 deletions doc/modeling/implementation.md
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ This components are placed under the node named « topoLines_cath » and allow t

This component is one of the main important to simulate interventional radiology instruments. It inherits from the class adapt the parameters of the simulation.

<img src="./CatheterModeling.jpg" align="left" width="700"/>
<img src="https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/CatheterModeling.jpg" align="left" width="700"/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>

- angleMax: gives the maximum angle of bending of the catheter
Expand Down Expand Up @@ -163,7 +163,7 @@ Inside the component, the geometric support of each beams is a cubic spline. Fro

### AdaptiveBeamForceFieldAndMass
This component computes the Force and the mass using a beam formulation. The computation is based on a « corotational approach ».
<img src="./BeamModeling.jpg" align="left" width="700"/>
<img src="https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/BeamModeling.jpg" align="left" width="700"/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>

From the two 6DOF position of the nodes of the beam, we extract 4 points for defining a spline. Using this spline, we can find one central frame for the beam (in red in the figure). There is only one rotation that is not determined (along the axis of the spline). To find this twiting orientation, we use a slerp.
Expand Down Expand Up @@ -229,7 +229,7 @@ In the opposite direction, the Mapping also allows to transfer the forces and th

The hypothesis of beam FEM is based on interpolation function. This why this MultiAdpativeBeamMapping will rely on the interpolation defined in the WireBeamInterpolations. However, for the specific case of catheter instruments, several concentric instruments can be inserted. Then the mapping has to be done with the good interpolation functions

<img src="./BeamMapping.jpg" align="left" width="700"/>
<img src="https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/BeamMapping.jpg" align="left" width="700"/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>

Consequently the MultiAdaptiveBeamMapping is directly « controlled » by the InterventionalRadiologyController and has to be linked to this component
Expand Down
16 changes: 8 additions & 8 deletions doc/modeling/theory.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,12 @@ rod or beam, we use a representation based on three-dimensional beam theory *see
elementary stiffness matrix Ke is a 12 × 12 symmetric matrix that relates angular and spacial positions of each end
of a beam element to the forces and torques applied to them:

<img src="./Matrix.jpg" align="left" width="700"/>
<img src="https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/Matrix.jpg" align="left" width="700"/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>

parameters:

<img src="./Matrix_param.jpg" align="left" width="700"/> <br/>
<img src="https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/Matrix_param.jpg" align="left" width="700"/> <br/>
<br/><br/><br/><br/><br/>

The assumption of the corotational model is that the deformations remain ”small” at the level of each element.
Expand All @@ -41,7 +41,7 @@ We need a matrix relationship between the variation of the position δ **u** in
δ **q** in the global coordinates.


<img src="./BeamFrames.jpg" align="left" width="700"/>
<img src="https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/BeamFrames.jpg" align="left" width="700"/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>

This relationship is expressed by the matrix equation:
Expand Down Expand Up @@ -81,7 +81,7 @@ $(1 − t)^3.P_0 + 3.(1 − t)^2.t.P_1 + 3.t^2.(1 − t).P_3 + t^3.P_3$

# Implementation
In the following, we describe the main components of the implementation of BeamAdapter Plugin.
For a full description of a BeamAdapter scene, check the [implementation documentation](./implementation.md) and here is the documentation of the [API C++ code](https://sofa-framework.github.io/BeamAdapter/)
For a full description of a BeamAdapter scene, check the [implementation documentation](https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/implementation.md) and here is the documentation of the [API C++ code](https://sofa-framework.github.io/BeamAdapter/)

One of the central component of the beams is the shape function.
The description of the shape function relies on:
Expand All @@ -92,10 +92,10 @@ The description of the shape function relies on:
## WireRestShape
This component allows to define the rest shape of Wire instrument such as a catheter (modeled with a set of beams), the numerical parameters used in the simulation, and the topology used for the visualisation.

<img src="./CatheterModeling.jpg" align="left" width="700"/>
<img src="https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/CatheterModeling.jpg" align="left" width="700"/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>

Several physical and geometry parameters can be defined using SOFA Data such as the **densityOfBeams**, **straightLength**, **youngModulus**, **numEdges**, etc. See [implementation documentation](./implementation.md) for the full list.
Several physical and geometry parameters can be defined using SOFA Data such as the **densityOfBeams**, **straightLength**, **youngModulus**, **numEdges**, etc. See [implementation documentation](https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/implementation.md) for the full list.

## WireBeamInterpolation

Expand All @@ -105,7 +105,7 @@ This component is one of the most important in the modeling of catheter devices:

This component computes the Force and the mass using a beam formulation. The computation is based on a « corotational approach ».

<img src="./BeamModeling.jpg" align="left" width="700"/>
<img src="https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/BeamModeling.jpg" align="left" width="700"/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>

From the two 6DOF position of the nodes of the beam, we extract 4 points for defining a spline. Using this spline, we can find one central frame for the beam (in red in the figure). There is only one rotation that is not determined (along the axis of the spline). To find this twiting orientation, we use a slerp. The computation of the deformations of the beams are done in this frame and suppose linear deformations using beam elements (Timoshenko beams) .
Expand All @@ -115,7 +115,7 @@ From the two 6DOF position of the nodes of the beam, we extract 4 points for def
This mapping allows to drive the Mechanical Object of the collision object thanks to the position and velocity of the Mechanical Object of the parent node. In the opposite direction, the Mapping also allows to transfer the forces and the constraints from the collision model to the DOFs (the nodes of the beam).
The hypothesis of beam FEM is based on interpolation function. This why this MultiAdpativeBeamMapping will rely on the interpolation defined in the WireBeamInterpolations. However, for the specific case of catheter instruments, several concentric instruments can be inserted. Then the mapping has to be done with the good interpolation functions

<img src="./BeamMapping.jpg" align="left" width="700"/>
<img src="https://github.com/sofa-framework/BeamAdapter/blob/master/doc/modeling/BeamMapping.jpg" align="left" width="700"/>
<br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>

<br>
Expand Down

0 comments on commit 67678b8

Please sign in to comment.