/*!

\page shape_processing_operation_page Shape Processing

\n To produce a <b>Shape Processing</b> operation in the <b>Main Menu</b> 
   select <b>Repair - > Shape Processing</b>.
\n This operation processes one or more shapes using various operators.

\n The \b Result will be a \b GEOM.GEOM_Object.

\n <b>TUI Command:</b> <em>geompy.ProcessShape(Shape, Operators,
Parameters, Values),</em> where \em Shape is a processed shape, \em Operators
is a list of operators ("FixShape", "SplitClosedFaces", etc.),
\em Parameters is a list of parameters ("FixShape.Tolerance3d",
etc), \em Values is a list of values of parameters placed in the same
order as in the list of Parameters.

\note <b>Shape Processing</b> is useful not only on invalid shapes,
      but also on the shapes, that are classified as valid by
      the <b>Check</b> functionality. Use it, if an operation (for
      example, <b>Partition</b>) fails.
      Example of usage:
      <ol>
      <li>Try to partition objects obj1 and obj2.</li>
      <li>Partition fails.</li>
      <li>Perform Shape Processing on objects obj1 and obj2.</li>
      <li>Try to partition them again.</li>
      </ol>
      See also \ref tui_limit_tolerance "TUI example".

\n In this dialog box you can select the object that you need to
process, define its name and operators applied to it during
processing.

\image html repair1.png

<b>Operators and Parameters</b> (TUI names are given in brackets):

<ul>
<li><b>Fix Shape</b> (FixShape) - corrects invalid shapes.</li>
<ul>
<li><b>3D Tolerance</b> (FixShape.Tolerance3d) - work tolerance for
detection of the problems and correction of them.</li>
<li><b>Max 3D Tolerance</b> (FixShape.MaxTolerance3d)  - maximal
possible tolerance of the shape after correction.</li>
</ul>
<li><b>Fix Face Size</b> (FixFaceSize) - removes small faces, such as
spots and strips.</li>
<ul>
<li><b>Tolerance</b> (FixFaceSize.Tolerance) - defines minimum
possible face size.</li>
</ul>
<li><b>Drop Small Edges</b> (DropSmallEdges) - removes edges, which
merge with neighbouring edges.</li>
<ul>
<li><b>3D Tolerance</b> (DropSmallEdges.Tolerance3d) - defines minimum
possible distance between two parallel edges.</li>
</ul>
<li><b>Split Angle</b> (SplitAngle) - splits faces based on conical
surfaces, surfaces of revolution and cylindrical surfaces in segments
using a certain angle.</li>
<ul>
<li><b>Angle</b> (SplitAngle.Angle) - the central angle of the
resulting segments (i.e. we obtain two segments if Angle=180, four if
Angle=90, etc).</li>
<li><b>Max. Tolerance</b> (SplitAngle.MaxTolerance) - maximum possible
tolerance among the resulting segments.</li>
</ul>
<li><b>Split Closed Faces</b> (SplitClosedFaces) - splits closed faces
in segments. The number of segments depends on the number of splitting
points.</li>
<ul>
<li><b>Number of splitting points</b> (SplitClosedFaces.NbSplitPoints) - the number of splitting points.</li>
</ul>
<li><b>Split Continuity</b> (SplitContinuity) - splits shapes to
reduce continuities of curves and surfaces.</li>
<ul>
<li><b>3D Tolerance</b> (SplitContinuity.Tolerance3d) - 3D tolerance for correction of geometry.</li>
<li><b>Surface Continuity</b> (SplitContinuity.SurfaceContinuity) - required continuity for surfaces.</li>
<li><b>Curve Continuity</b> (SplitContinuity.CurveContinuity) - required continuity for curves.</li>
</ul>
\n This and the previous parameters can take the following values:
\par
<b>Parametric Continuity</b>
\n \b C0 (Positional Continuity): curves are joined (the end positions
of curves or surfaces are coincidental. The curves or surfaces may
still meet at an angle, giving rise to a sharp corner or edge).
\n \b C1 (Tangential Continuity): first derivatives are equal (the end
vectors of curves or surfaces are parallel, ruling out sharp edges).
\n \b C2 (Curvature Continuity): first and second derivatives are
equal (the end vectors of curves or surfaces are of the same
magnitude).
\n \b CN N-th derivatives are equal (both the direction and the
magnitude of the Nth derivatives of curves or surfaces (d/du C(u)) are
the same at junction.
\par
<b>Geometric Continuity</b>
\n \b G1: first derivatives are proportional at junction.
\n The curve tangents thus have the same direction, but not necessarily
the same magnitude. i.e., C1'(1) = (a,b,c) and C2'(0) = (k*a, k*b,
k*c).
\n \b G2: first and second derivatives are proportional at junction.
\n As the names imply, geometric continuity requires the geometry to
be continuous, while parametric continuity requires that the
underlying parameterization was continuous as well.
\n Parametric continuity of order n implies geometric continuity of
order n, but not vice-versa. 

<li><b>Bspline Restriction</b> (BsplineRestriction) - converts curves
and surfaces to Bsplines and processes them with the following
parameters:</li>
<ul>
<li><b>Surface Mode</b> (BSplineRestriction.SurfaceMode) -
approximation of surfaces if restriction is necessary.</li>
<li><b>3D Curve Mode</b> (BSplineRestriction.Curve3dMode) - conversion
of any 3D curve to BSpline and approximation.</li>
<li><b>2D Curve Mode</b> (BSplineRestriction.Curve2dMode) - conversion
of any 2D curve to BSpline and approximation.</li>
<li><b>3D Tolerance</b> (BSplineRestriction.Tolerance3d) - defines the
possibility of surfaces and 3D curves approximation with the specified
parameters.</li>
<li><b>2D Tolerance</b> (BSplineRestriction.Tolerance2d) - defines the
possibility of surfaces and 2D curves approximation with the specified
parameters.</li>
<li><b>Required Degree</b> (BSplineRestriction.RequiredDegree) -
required degree of the resulting BSplines.</li>
<li><b>Required number of segments</b>
(BSplineRestriction.RequiredNbSegments) - required maximum number of
segments of resultant BSplines.</li>
<li><b>3D Continuity</b> (BSplineRestriction.Continuity3d) -
continuity of the resulting surfaces and 3D curves.</li>
<li><b>2D Continuity</b> (BSplineRestriction.Continuity2d) -
continuity of the resulting 2D curves.</li>
</ul>
<li><b>To Bezier</b> (ToBezier) - converts curves and surfaces of any
type to Bezier curves and surfaces.</li>
<ul>
<li><b>Surface Mode</b> (ToBezier.SurfaceMode) - if checked in, allows
conversion of surfaces.</li>
<li><b>3D Curve Mode</b> (ToBezier.Curve3dMode) - if checked in,
allows conversion of 3D curves.</li>
<li><b>2D Curve Mode</b> (ToBezier.Curve2dMode) - if checked in,
allows conversion of 2D curves.</li>
<li><b>Max Tolerance</b> (ToBezier.MaxTolerance) - defines tolerance
for detection and correction of problems.</li>
</ul>
<li><b>Same Parameter</b> (SameParameter) - fixes edges of 2D and 3D
curves not having the same parameter.</li>
<ul>
<li><b>3D Tolerance</b> (SameParameter.Tolerance3d) - defines tolerance for fixing of edges.</li>
</ul>
</ul>

\n <b>Example:</b>

\image html image154.png
<center><em>Shape before applying Shape Processing (FixShape
operator). View # 1.</em></center>

\image html image156.png
<center><em>Shape before applying Shape Processing (FixShape
operator). View # 2.</em></center>

\image html image160.png
<center><em>The same shape after applying Shape
Processing.</em></center>

Our <b>TUI Scripts</b> provide you with useful examples of the use of
\ref tui_shape_processing "Repairing Operations".

*/