mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-05-01 10:26:12 +03:00
Removing pPotentially uninitialized local variable Got rid of most of warnings C4701: Potentially uninitialized local variable Removed redundant variable definitions. Refactored a part of AppParCurves_ResolConstraint CTOR. Replaced 0. to Precision::Confusion for tolerance vars; Changed values for min and max parameter vars; Got rid of redundant variables' initialization.
354 lines
11 KiB
Plaintext
Executable File
354 lines
11 KiB
Plaintext
Executable File
// Copyright (c) 1995-1999 Matra Datavision
|
|
// Copyright (c) 1999-2012 OPEN CASCADE SAS
|
|
//
|
|
// The content of this file is subject to the Open CASCADE Technology Public
|
|
// License Version 6.5 (the "License"). You may not use the content of this file
|
|
// except in compliance with the License. Please obtain a copy of the License
|
|
// at http://www.opencascade.org and read it completely before using this file.
|
|
//
|
|
// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
|
|
// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
|
|
//
|
|
// The Original Code and all software distributed under the License is
|
|
// distributed on an "AS IS" basis, without warranty of any kind, and the
|
|
// Initial Developer hereby disclaims all such warranties, including without
|
|
// limitation, any warranties of merchantability, fitness for a particular
|
|
// purpose or non-infringement. Please see the License for the specific terms
|
|
// and conditions governing the rights and limitations under the License.
|
|
|
|
|
|
#include <NCollection_IncAllocator.hxx>
|
|
|
|
void IntWalk_IWalking::ComputeCloseLine(const TColStd_SequenceOfReal& Umult,
|
|
const TColStd_SequenceOfReal& Vmult,
|
|
const ThePOPIterator& Pnts1,
|
|
const ThePOLIterator& Pnts2,
|
|
TheIWFunction& Func,
|
|
Standard_Boolean& Rajout )
|
|
// *********** Processing of closed line **********************
|
|
//
|
|
// for any interior non-processed point
|
|
// calculate the step of advancement=step depending on the arrow and max step
|
|
// calculate a point of approach (this point is on the tangent to the section
|
|
// of distance = no interior point)
|
|
// conditions
|
|
// (all calculated points do not form a closed loop)
|
|
// or
|
|
// (all points do not form an open line going from
|
|
// one border of the domain to the other or from a point tangent
|
|
// to the border or from 2 tangent points : single cases)
|
|
//
|
|
// frame the point of approach on borders if necessary
|
|
// calculate the point
|
|
// if point not found divide the step
|
|
// test of stop
|
|
// calculate step depending on the arrow and the max step (stop possible)
|
|
//
|
|
// ********************************************************************
|
|
{
|
|
|
|
Standard_Integer I,N = 0;
|
|
Standard_Real aBornInf[2], aBornSup[2], aUVap[2];
|
|
math_Vector BornInf(aBornInf,1,2), BornSup(aBornSup,1,2);
|
|
math_Vector Uvap(aUVap,1,2);// parameters of current approach
|
|
Standard_Real PasC; // rate of advancement on the tangent
|
|
Standard_Real PasCu; // rate of advancement current by U
|
|
Standard_Real PasCv; // step of advancement current by V
|
|
Standard_Real PasSav; // save first step of advancement
|
|
Standard_Boolean Arrive;// show if line ends
|
|
Standard_Boolean Cadre; // show if on border of the domains
|
|
Standard_Boolean ArretAjout; // show if on the added point
|
|
IntSurf_PntOn2S Psol;
|
|
Handle(IntWalk_TheIWLine) CurrentLine; //line under construction
|
|
ThePointOfPath PathPnt;
|
|
ThePointOfLoop LoopPnt;
|
|
|
|
Standard_Boolean Tgtbeg,Tgtend;
|
|
|
|
Standard_Integer StepSign;
|
|
|
|
IntWalk_StatusDeflection Status,StatusPrecedent;
|
|
Standard_Integer NbDivision ; // number of divisions of step
|
|
// during calculation of 1 section
|
|
|
|
Standard_Integer Ipass ;
|
|
//index in the iterator of points on edge of point of passage
|
|
|
|
|
|
BornInf(1) = Um;
|
|
BornSup(1) = UM;
|
|
BornInf(2) = Vm;
|
|
BornSup(2) = VM;
|
|
|
|
math_FunctionSetRoot Rsnld(Func,tolerance);
|
|
Standard_Integer nbLoop = Pnts2.Length();
|
|
|
|
for (I = 1;I<=nbLoop;I++) {
|
|
if (wd2[I].etat > 12) { // start point of closed line
|
|
|
|
LoopPnt = Pnts2.Value(I);
|
|
previousPoint.SetValue(ThePointOfLoopTool::Value3d(LoopPnt),reversed,
|
|
wd2[I].ustart,wd2[I].vstart);
|
|
previousd3d = ThePointOfLoopTool::Direction3d(LoopPnt);
|
|
previousd2d = ThePointOfLoopTool::Direction2d(LoopPnt);
|
|
|
|
CurrentLine = new IntWalk_TheIWLine (new NCollection_IncAllocator());
|
|
CurrentLine->AddPoint(previousPoint);
|
|
CurrentLine->SetTangentVector(previousd3d,1);
|
|
Tgtbeg = Standard_False;
|
|
Tgtend = Standard_False;
|
|
Uvap(1) = wd2[I].ustart;
|
|
Uvap(2) = wd2[I].vstart;
|
|
|
|
StepSign = 1;
|
|
|
|
// first step of advancement
|
|
|
|
Standard_Real d2dx = Abs(previousd2d.X());
|
|
Standard_Real d2dy = Abs(previousd2d.Y());
|
|
if (d2dx < tolerance(1)) {
|
|
PasC = pas * (VM-Vm)/d2dy;
|
|
}
|
|
else if (d2dy < tolerance(2)) {
|
|
PasC = pas * (UM-Um)/d2dx;
|
|
}
|
|
else {
|
|
PasC = pas * Min((UM-Um)/d2dx,(VM-Vm)/d2dy);
|
|
}
|
|
|
|
PasSav = PasC;
|
|
|
|
Arrive = Standard_False;
|
|
ArretAjout = Standard_False;
|
|
NbDivision = 0;
|
|
StatusPrecedent = IntWalk_OK;
|
|
while (!Arrive) { // as no test of stop is passed
|
|
Cadre=Cadrage(BornInf,BornSup,Uvap,PasC, StepSign); // border?
|
|
#ifdef CHRONO
|
|
Chronrsnld.Start();
|
|
#endif
|
|
|
|
Rsnld.Perform(Func,Uvap,BornInf,BornSup);
|
|
|
|
#ifdef CHRONO
|
|
Chronrsnld.Stop();
|
|
#endif
|
|
|
|
if (Cadre) { // update of limits.
|
|
BornInf(1) = Um;BornSup(1) = UM;BornInf(2) = Vm;BornSup(2) = VM;
|
|
}
|
|
if (Rsnld.IsDone()) {
|
|
if (Abs(Func.Root()) > Func.Tolerance()) { // no solution for the tolerance
|
|
PasC = PasC/2.;
|
|
PasCu = Abs(PasC*previousd2d.X());
|
|
PasCv = Abs(PasC*previousd2d.Y());
|
|
|
|
if (PasCu <= tolerance(1) && PasCv <= tolerance(2)) {
|
|
if (CurrentLine->NbPoints()==1) break;
|
|
Arrive = Standard_True;
|
|
CurrentLine->AddStatusFirstLast(Standard_False,
|
|
Standard_False,Standard_False);
|
|
Rajout = Standard_True;
|
|
seqAjout.Append(lines.Length()+1);
|
|
Tgtend = Standard_True;
|
|
}
|
|
}
|
|
else { // there is a solution
|
|
Rsnld.Root(Uvap);
|
|
Arrive = TestArretPassage(Umult,Vmult,Uvap,I,Ipass);
|
|
if (Arrive) {//reset proper parameter to test the arrow.
|
|
Psol = CurrentLine->Value(1);
|
|
if (!reversed) {
|
|
Psol.ParametersOnS2(Uvap(1),Uvap(2));
|
|
}
|
|
else {
|
|
Psol.ParametersOnS1(Uvap(1),Uvap(2));
|
|
}
|
|
Cadre=Standard_False;
|
|
//in case if there is a frame and arrival at the same time
|
|
}
|
|
else { // modif jag 940615
|
|
|
|
if (Rajout) { // test on added points
|
|
ArretAjout =TestArretAjout(Func,Uvap,N,Psol);
|
|
if (ArretAjout) {
|
|
if (N >0) {
|
|
Tgtend = lines.Value(N)->IsTangentAtEnd();
|
|
N = -N;
|
|
}
|
|
else {
|
|
Tgtend = lines.Value(-N)->IsTangentAtBegining();
|
|
}
|
|
Arrive = (wd2[I].etat == 12);
|
|
}
|
|
}
|
|
|
|
if (!ArretAjout&& Cadre) { // test on already marked points
|
|
if (CurrentLine->NbPoints() == 1) break; // cancel the line
|
|
TestArretCadre(Umult,Vmult,CurrentLine,Func,Uvap,N);
|
|
// if (N==0) {
|
|
if (N <= 0) { // jag 941017
|
|
MakeWalkingPoint(2,Uvap(1),Uvap(2),Func,Psol);
|
|
Tgtend = Func.IsTangent(); // jag 940616
|
|
N = -N;
|
|
}
|
|
Arrive = (wd2[I].etat == 12); // the line is open
|
|
}
|
|
}
|
|
Status = TestDeflection(Func, Arrive,Uvap,StatusPrecedent,
|
|
NbDivision,PasC,StepSign);
|
|
StatusPrecedent = Status;
|
|
if (Status == IntWalk_PasTropGrand) {// division of the step
|
|
Arrive = Standard_False;
|
|
ArretAjout = Standard_False;
|
|
Tgtend = Standard_False; // jag 940616
|
|
if (!reversed) {
|
|
previousPoint.ParametersOnS2(Uvap(1),Uvap(2));
|
|
}
|
|
else {
|
|
previousPoint.ParametersOnS1(Uvap(1),Uvap(2));
|
|
}
|
|
}
|
|
else if (ArretAjout || Cadre) {
|
|
|
|
if (Arrive) { // line s is open
|
|
CurrentLine->AddStatusLast(Standard_False);
|
|
if (Status != IntWalk_ArretSurPointPrecedent) {
|
|
CurrentLine->AddPoint(Psol);
|
|
}
|
|
if (Cadre && N==0) {
|
|
Rajout = Standard_True;
|
|
seqAjout.Append(lines.Length()+1);
|
|
}
|
|
|
|
}
|
|
else { // open
|
|
wd2[I].etat = 12; // declare it open
|
|
Tgtbeg = Tgtend;
|
|
Tgtend = Standard_False;
|
|
ArretAjout = Standard_False;
|
|
StepSign = -1;
|
|
StatusPrecedent = IntWalk_OK;
|
|
PasC = PasSav;
|
|
if (Status == IntWalk_ArretSurPointPrecedent) {
|
|
OpenLine(0,Psol,Pnts1,Func,CurrentLine);
|
|
}
|
|
else {
|
|
OpenLine(-lines.Length()-1,Psol,Pnts1,Func,CurrentLine);
|
|
}
|
|
if (Cadre && N==0) {
|
|
Rajout = Standard_True;
|
|
seqAjout.Append(-lines.Length()-1);
|
|
}
|
|
}
|
|
}
|
|
|
|
else if ( Status == IntWalk_ArretSurPointPrecedent) {
|
|
if (CurrentLine->NbPoints() == 1) { //cancel the line
|
|
Arrive = Standard_False;
|
|
break;
|
|
}
|
|
if (wd2[I].etat >12) { //the line should become open
|
|
wd2[I].etat = 12; //declare it open
|
|
ArretAjout = Standard_False;
|
|
OpenLine(0,Psol,Pnts1,Func,CurrentLine);
|
|
StepSign = -1;
|
|
StatusPrecedent = IntWalk_OK;
|
|
Arrive = Standard_False;
|
|
PasC = PasSav;
|
|
Rajout = Standard_True;
|
|
seqAjout.Append(-lines.Length()-1);
|
|
}
|
|
else { // line s is open
|
|
Arrive =Standard_True;
|
|
CurrentLine->AddStatusLast(Standard_False);
|
|
Rajout = Standard_True;
|
|
seqAjout.Append(lines.Length()+1);
|
|
}
|
|
}
|
|
else if (Arrive) {
|
|
if (wd2[I].etat > 12) { //line closed good case
|
|
CurrentLine->AddStatusFirstLast(Standard_True,
|
|
Standard_False,Standard_False);
|
|
CurrentLine->AddPoint(CurrentLine->Value(1));
|
|
}
|
|
else if (N >0) { //point of stop given at input
|
|
PathPnt = Pnts1.Value(N);
|
|
CurrentLine->AddStatusLast(Standard_True,N,PathPnt);
|
|
AddPointInCurrentLine(N,PathPnt,CurrentLine);
|
|
}
|
|
}
|
|
else if (Status == IntWalk_ArretSurPoint) {
|
|
if (wd2[I].etat >12) { //line should become open
|
|
wd2[I].etat = 12; //declare it open
|
|
Tgtbeg = Standard_True;
|
|
Tgtend = Standard_False;
|
|
N= -lines.Length()-1;
|
|
Psol.SetValue(Func.Point(),reversed,Uvap(1),Uvap(2));
|
|
OpenLine(N,Psol,Pnts1,Func,CurrentLine);
|
|
StepSign = -1;
|
|
Rajout = Standard_True;
|
|
seqAjout.Append(N);
|
|
StatusPrecedent = IntWalk_OK;
|
|
Arrive = Standard_False;
|
|
PasC = PasSav;
|
|
}
|
|
else {
|
|
Arrive = Standard_True;
|
|
if (Ipass!=0) { //point of passage, point of stop
|
|
PathPnt = Pnts1.Value(Ipass);
|
|
CurrentLine->AddStatusLast(Standard_True,Ipass,PathPnt);
|
|
AddPointInCurrentLine(Ipass,PathPnt,CurrentLine);
|
|
}
|
|
else {
|
|
CurrentLine->AddStatusLast(Standard_False);
|
|
IntSurf_PntOn2S newP;
|
|
newP.SetValue(Func.Point(),reversed,Uvap(1),Uvap(2));
|
|
CurrentLine->AddPoint(newP);
|
|
Rajout = Standard_True;
|
|
seqAjout.Append(lines.Length()+1);
|
|
}
|
|
}
|
|
}
|
|
else if (Status == IntWalk_OK) {
|
|
if (Ipass!=0) CurrentLine->AddIndexPassing(Ipass);
|
|
previousPoint.SetValue(Func.Point(),reversed,Uvap(1),Uvap(2));
|
|
previousd3d = Func.Direction3d();
|
|
previousd2d = Func.Direction2d();
|
|
CurrentLine->AddPoint(previousPoint);
|
|
}
|
|
}
|
|
}
|
|
else { //no numerical solution NotDone
|
|
PasC = PasC/2.;
|
|
PasCu = Abs(PasC*previousd2d.X());
|
|
PasCv = Abs(PasC*previousd2d.Y());
|
|
|
|
if (PasCu <= tolerance(1) && PasCv <= tolerance(2)) {
|
|
if (CurrentLine->NbPoints() == 1) break; // cancel the line
|
|
Arrive = Standard_True;
|
|
CurrentLine->AddStatusFirstLast(Standard_False,Standard_False,
|
|
Standard_False);
|
|
Tgtend = Standard_True;
|
|
Rajout = Standard_True;
|
|
seqAjout.Append(lines.Length()+1);
|
|
}
|
|
}
|
|
}// end of started line
|
|
if (Arrive) {
|
|
CurrentLine->SetTangencyAtBegining(Tgtbeg);
|
|
CurrentLine->SetTangencyAtEnd(Tgtend);
|
|
|
|
lines.Append(CurrentLine);
|
|
wd2[I].etat=-wd2[I].etat; //mark point as processed
|
|
}
|
|
} //end of processing of start point
|
|
} //end of all start points
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|