1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

0023552: Projection algorithm produces wrong results with default tolerance value.

Add TKShHealing to TKFillet/EXTERNLIB
Adding test case
This commit is contained in:
pkv 2013-01-18 13:39:21 +04:00
parent b8ddfc2f5d
commit cfb6776ec0
5 changed files with 34 additions and 8 deletions

View File

@ -64,7 +64,9 @@
#include <ChFi3d_Builder_0.hxx>
#include <TopOpeBRepDS_ListOfInterference.hxx>
#include <BRepLib.hxx>
#include <ShapeFix.hxx>
#include <Precision.hxx>
#ifdef DRAW
#include <TestTopOpeTools.hxx>
@ -73,6 +75,8 @@
#ifdef DEB
#include <OSD_Chronometer.hxx>
// variables for performances
@ -557,6 +561,27 @@ void ChFi3d_Builder::Compute()
cout<<"-temps ChFi3d_sameparameter "<<t_sameparam<<"s"<<endl<<endl;
}
#endif
//
// Inspect the new faces to provide sameparameter
// if it is necessary
if (IsDone())
{
Standard_Real SameParTol = Precision::Confusion();
Standard_Integer aNbSurfaces, iF;
TopTools_ListIteratorOfListOfShape aIt;
//
aNbSurfaces=myDS->NbSurfaces();
for (iF=1; iF<=aNbSurfaces; ++iF) {
const TopTools_ListOfShape& aLF=myCoup->NewFaces(iF);
aIt.Initialize(aLF);
for (; aIt.More(); aIt.Next()) {
const TopoDS_Shape& aF=aIt.Value();
BRepLib::SameParameter(aF, SameParTol, Standard_True);
ShapeFix::SameParameter(aF, Standard_False, SameParTol);
}
}
}
}
//=======================================================================

View File

@ -558,7 +558,7 @@ static void Project(ProjLib_Projector& P, Handle(Adaptor3d_HCurve)& C)
ProjLib_ProjectedCurve::ProjLib_ProjectedCurve()
{
myTolerance = Precision::PApproximation();
myTolerance = Precision::Confusion();
}
@ -570,7 +570,7 @@ ProjLib_ProjectedCurve::ProjLib_ProjectedCurve()
ProjLib_ProjectedCurve::ProjLib_ProjectedCurve
(const Handle(Adaptor3d_HSurface)& S)
{
myTolerance = Precision::PApproximation();
myTolerance = Precision::Confusion();
Load(S);
}
@ -584,7 +584,7 @@ ProjLib_ProjectedCurve::ProjLib_ProjectedCurve
(const Handle(Adaptor3d_HSurface)& S,
const Handle(Adaptor3d_HCurve)& C)
{
myTolerance = Precision::PApproximation();
myTolerance = Precision::Confusion();
Load(S);
Load(C);
}
@ -600,7 +600,7 @@ ProjLib_ProjectedCurve::ProjLib_ProjectedCurve
const Handle(Adaptor3d_HCurve)& C,
const Standard_Real Tol)
{
myTolerance = Max(Tol, Precision::PApproximation());
myTolerance = Max(Tol, Precision::Confusion());
Load(S);
Load(C);
}
@ -624,7 +624,7 @@ void ProjLib_ProjectedCurve::Load(const Handle(Adaptor3d_HSurface)& S)
void ProjLib_ProjectedCurve::Load(const Handle(Adaptor3d_HCurve)& C)
{
myTolerance = Max(myTolerance,Precision::PApproximation());
myTolerance = Max(myTolerance, Precision::Confusion());
myCurve = C;
Standard_Real FirstPar = C->FirstParameter();
Standard_Real LastPar = C->LastParameter();

View File

@ -7,3 +7,4 @@ TKG2d
TKTopAlgo
TKG3d
TKBool
TKShHealing

View File

@ -3,7 +3,7 @@
## Test : K7
## Comment : from cts21020
## ====================================
puts "TODO OCC22817 All:Faulty shapes in variables faulty_1 to faulty_14"
puts "TODO OCC22817 All:Faulty shapes in variables faulty_1 to faulty_"
restore [locate_data_file CFI_cts21020.rle] a
explode a e

View File

@ -13,6 +13,6 @@ if { [string compare $command chamf] == 0 } {
set os $env(os_type)
}
if {[string compare $group dist_angle] == 0} {
puts "TODO OCC22909 All:Faulty shapes in variables faulty_1 to faulty_12"
puts "TODO OCC22909 All:Faulty shapes in variables faulty_1 to faulty_"
}
}