mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0025717: Non reentrant (and hence non-thread-safe) math_RealRandom / _IntegerRandom
Classes math_IntegerRandom and math_RealRandom, and method Random2 in math_Recipes, removed. Class math_BullardGenerator is used instead.
This commit is contained in:
parent
0bb09048e2
commit
fd3ba7a1d9
@ -30,7 +30,7 @@
|
|||||||
#include <ElCLib.hxx>
|
#include <ElCLib.hxx>
|
||||||
#include <Geom_Surface.hxx>
|
#include <Geom_Surface.hxx>
|
||||||
#include <BRep_Tool.hxx>
|
#include <BRep_Tool.hxx>
|
||||||
#include <math_RealRandom.hxx>
|
#include <math_BullardGenerator.hxx>
|
||||||
#include <BRepTopAdaptor_FClass2d.hxx>
|
#include <BRepTopAdaptor_FClass2d.hxx>
|
||||||
|
|
||||||
static
|
static
|
||||||
@ -98,7 +98,7 @@ void BRepClass3d_SClassifier::PerformInfinitePoint(BRepClass3d_SolidExplorer& aS
|
|||||||
gp_Pnt aPoint;
|
gp_Pnt aPoint;
|
||||||
gp_Dir aDN;
|
gp_Dir aDN;
|
||||||
|
|
||||||
math_RealRandom RandomGenerator(0.1, 0.9);
|
math_BullardGenerator aRandomGenerator;
|
||||||
myFace.Nullify();
|
myFace.Nullify();
|
||||||
myState=2;
|
myState=2;
|
||||||
|
|
||||||
@ -114,10 +114,10 @@ void BRepClass3d_SClassifier::PerformInfinitePoint(BRepClass3d_SolidExplorer& aS
|
|||||||
TopoDS_Face MinFace = aF;
|
TopoDS_Face MinFace = aF;
|
||||||
for (;;)
|
for (;;)
|
||||||
{
|
{
|
||||||
aParam = RandomGenerator.Next();
|
aParam = 0.1 + 0.8 * aRandomGenerator.NextReal(); // random number in range [0.1, 0.9]
|
||||||
bFound = aSE.FindAPointInTheFace(aF, aPoint, aU, aV, aParam);
|
bFound = aSE.FindAPointInTheFace(aF, aPoint, aU, aV, aParam);
|
||||||
if (!bFound)
|
if (!bFound)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!FaceNormal(aF, aU, aV, aDN))
|
if (!FaceNormal(aF, aU, aV, aDN))
|
||||||
continue;
|
continue;
|
||||||
|
@ -55,7 +55,6 @@ is
|
|||||||
imported PSO;
|
imported PSO;
|
||||||
imported PSOParticlesPool;
|
imported PSOParticlesPool;
|
||||||
imported BullardGenerator;
|
imported BullardGenerator;
|
||||||
class IntegerRandom;
|
|
||||||
class Gauss;
|
class Gauss;
|
||||||
class GaussLeastSquare;
|
class GaussLeastSquare;
|
||||||
class SVD;
|
class SVD;
|
||||||
@ -77,7 +76,6 @@ is
|
|||||||
class GaussSingleIntegration;
|
class GaussSingleIntegration;
|
||||||
class GaussMultipleIntegration;
|
class GaussMultipleIntegration;
|
||||||
class GaussSetIntegration;
|
class GaussSetIntegration;
|
||||||
class RealRandom;
|
|
||||||
class FunctionSample;
|
class FunctionSample;
|
||||||
class FunctionAllRoots;
|
class FunctionAllRoots;
|
||||||
class Householder;
|
class Householder;
|
||||||
|
@ -1,47 +0,0 @@
|
|||||||
-- Created on: 1991-05-27
|
|
||||||
-- Created by: Laurent PAINNOT
|
|
||||||
-- Copyright (c) 1991-1999 Matra Datavision
|
|
||||||
-- Copyright (c) 1999-2014 OPEN CASCADE SAS
|
|
||||||
--
|
|
||||||
-- This file is part of Open CASCADE Technology software library.
|
|
||||||
--
|
|
||||||
-- This library is free software; you can redistribute it and/or modify it under
|
|
||||||
-- the terms of the GNU Lesser General Public License version 2.1 as published
|
|
||||||
-- by the Free Software Foundation, with special exception defined in the file
|
|
||||||
-- OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
||||||
-- distribution for complete text of the license and disclaimer of any warranty.
|
|
||||||
--
|
|
||||||
-- Alternatively, this file may be used under the terms of Open CASCADE
|
|
||||||
-- commercial license or contractual agreement.
|
|
||||||
|
|
||||||
class IntegerRandom from math
|
|
||||||
---Purpose:
|
|
||||||
-- This class implements an integer random number generator.
|
|
||||||
|
|
||||||
is
|
|
||||||
|
|
||||||
Create(Lower, Upper: Integer)
|
|
||||||
---Purpose:
|
|
||||||
-- creates a Integer random generator between the values Lower and Upper.
|
|
||||||
|
|
||||||
returns IntegerRandom;
|
|
||||||
|
|
||||||
|
|
||||||
Reset(me:in out)
|
|
||||||
---Purpose: reinitializes the random generator
|
|
||||||
|
|
||||||
is static;
|
|
||||||
|
|
||||||
Next(me: in out)
|
|
||||||
---Purpose: returns the next random number.
|
|
||||||
|
|
||||||
returns Integer
|
|
||||||
is static;
|
|
||||||
|
|
||||||
fields
|
|
||||||
|
|
||||||
Low: Integer;
|
|
||||||
Up: Integer;
|
|
||||||
Dummy: Integer;
|
|
||||||
|
|
||||||
end IntegerRandom;
|
|
@ -1,40 +0,0 @@
|
|||||||
// Copyright (c) 1997-1999 Matra Datavision
|
|
||||||
// Copyright (c) 1999-2014 OPEN CASCADE SAS
|
|
||||||
//
|
|
||||||
// This file is part of Open CASCADE Technology software library.
|
|
||||||
//
|
|
||||||
// This library is free software; you can redistribute it and/or modify it under
|
|
||||||
// the terms of the GNU Lesser General Public License version 2.1 as published
|
|
||||||
// by the Free Software Foundation, with special exception defined in the file
|
|
||||||
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
||||||
// distribution for complete text of the license and disclaimer of any warranty.
|
|
||||||
//
|
|
||||||
// Alternatively, this file may be used under the terms of Open CASCADE
|
|
||||||
// commercial license or contractual agreement.
|
|
||||||
|
|
||||||
#include <math_IntegerRandom.ixx>
|
|
||||||
|
|
||||||
#include <math_Recipes.hxx>
|
|
||||||
|
|
||||||
math_IntegerRandom::math_IntegerRandom(const Standard_Integer Lower,
|
|
||||||
const Standard_Integer Upper) {
|
|
||||||
|
|
||||||
Low = Lower;
|
|
||||||
Up = Upper;
|
|
||||||
Dummy=-1;
|
|
||||||
Random2(Dummy);
|
|
||||||
}
|
|
||||||
|
|
||||||
void math_IntegerRandom::Reset() {
|
|
||||||
|
|
||||||
Dummy=-1;
|
|
||||||
Random2(Dummy);
|
|
||||||
}
|
|
||||||
|
|
||||||
Standard_Integer math_IntegerRandom::Next() {
|
|
||||||
|
|
||||||
Standard_Real value=Random2(Dummy);
|
|
||||||
Standard_Integer Result=(Standard_Integer)(Standard_Real((Up-Low))*value + Low);
|
|
||||||
return (Result) ;
|
|
||||||
}
|
|
||||||
|
|
@ -1,49 +0,0 @@
|
|||||||
-- Created on: 1991-05-14
|
|
||||||
-- Created by: Laurent PAINNOT
|
|
||||||
-- Copyright (c) 1991-1999 Matra Datavision
|
|
||||||
-- Copyright (c) 1999-2014 OPEN CASCADE SAS
|
|
||||||
--
|
|
||||||
-- This file is part of Open CASCADE Technology software library.
|
|
||||||
--
|
|
||||||
-- This library is free software; you can redistribute it and/or modify it under
|
|
||||||
-- the terms of the GNU Lesser General Public License version 2.1 as published
|
|
||||||
-- by the Free Software Foundation, with special exception defined in the file
|
|
||||||
-- OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
||||||
-- distribution for complete text of the license and disclaimer of any warranty.
|
|
||||||
--
|
|
||||||
-- Alternatively, this file may be used under the terms of Open CASCADE
|
|
||||||
-- commercial license or contractual agreement.
|
|
||||||
|
|
||||||
class RealRandom from math
|
|
||||||
---Purpose:
|
|
||||||
-- This class implements a real random generator.
|
|
||||||
|
|
||||||
|
|
||||||
is
|
|
||||||
|
|
||||||
Create(Lower, Upper: Real)
|
|
||||||
---Purpose:
|
|
||||||
-- creates a real random generator between the values Lower and Upper.
|
|
||||||
|
|
||||||
returns RealRandom;
|
|
||||||
|
|
||||||
|
|
||||||
Reset(me: in out)
|
|
||||||
---Purpose: reinitializes the random generator
|
|
||||||
|
|
||||||
is static;
|
|
||||||
|
|
||||||
Next(me: in out)
|
|
||||||
---Purpose: returns the next random number.
|
|
||||||
|
|
||||||
returns Real
|
|
||||||
is static;
|
|
||||||
|
|
||||||
|
|
||||||
fields
|
|
||||||
|
|
||||||
Dummy: Integer;
|
|
||||||
Low: Real;
|
|
||||||
Up: Real;
|
|
||||||
|
|
||||||
end RealRandom;
|
|
@ -1,39 +0,0 @@
|
|||||||
// Copyright (c) 1997-1999 Matra Datavision
|
|
||||||
// Copyright (c) 1999-2014 OPEN CASCADE SAS
|
|
||||||
//
|
|
||||||
// This file is part of Open CASCADE Technology software library.
|
|
||||||
//
|
|
||||||
// This library is free software; you can redistribute it and/or modify it under
|
|
||||||
// the terms of the GNU Lesser General Public License version 2.1 as published
|
|
||||||
// by the Free Software Foundation, with special exception defined in the file
|
|
||||||
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
||||||
// distribution for complete text of the license and disclaimer of any warranty.
|
|
||||||
//
|
|
||||||
// Alternatively, this file may be used under the terms of Open CASCADE
|
|
||||||
// commercial license or contractual agreement.
|
|
||||||
|
|
||||||
#include <math_RealRandom.ixx>
|
|
||||||
#include <math_Recipes.hxx>
|
|
||||||
|
|
||||||
math_RealRandom::math_RealRandom(const Standard_Real Lower,
|
|
||||||
const Standard_Real Upper) {
|
|
||||||
|
|
||||||
Low = Lower;
|
|
||||||
Up = Upper;
|
|
||||||
Dummy = -1;
|
|
||||||
Random2(Dummy);
|
|
||||||
}
|
|
||||||
|
|
||||||
void math_RealRandom::Reset() {
|
|
||||||
|
|
||||||
Dummy = -1;
|
|
||||||
Random2(Dummy);
|
|
||||||
}
|
|
||||||
|
|
||||||
Standard_Real math_RealRandom::Next() {
|
|
||||||
|
|
||||||
Standard_Real value = Random2(Dummy);
|
|
||||||
Standard_Real Result = (Up - Low)*value + Low;
|
|
||||||
return Result;
|
|
||||||
|
|
||||||
}
|
|
@ -562,33 +562,6 @@ void SVD_Solve(const math_Matrix& u,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Standard_Real Random2(Standard_Integer& idum) {
|
|
||||||
|
|
||||||
static Standard_Integer iy, ir[98];
|
|
||||||
static Standard_Integer iff = 0;
|
|
||||||
|
|
||||||
Standard_Integer j;
|
|
||||||
|
|
||||||
if(idum < 0 || iff == 0) {
|
|
||||||
iff = 1;
|
|
||||||
if((idum = (IC - idum) % M) < 0) idum = -idum;
|
|
||||||
for(j = 1; j <= 97; j++) {
|
|
||||||
idum = (IA * idum + IC) % M;
|
|
||||||
ir[j] = idum;
|
|
||||||
}
|
|
||||||
idum = (IA * idum + IC) % M;
|
|
||||||
iy = idum;
|
|
||||||
}
|
|
||||||
j = (Standard_Integer)(1 + 97.0 * iy / M);
|
|
||||||
if(j > 97 || j < 1) Standard_Failure::Raise();
|
|
||||||
iy = ir[j];
|
|
||||||
idum = (IA * idum + IC) % M;
|
|
||||||
ir[j] = idum;
|
|
||||||
return Standard_Real(iy) / Standard_Real(M);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Standard_Integer DACTCL_Decompose(math_Vector& a,
|
Standard_Integer DACTCL_Decompose(math_Vector& a,
|
||||||
const math_IntegerVector& indx,
|
const math_IntegerVector& indx,
|
||||||
const Standard_Real MinPivot) {
|
const Standard_Real MinPivot) {
|
||||||
|
@ -151,13 +151,6 @@ __math_API Standard_Integer Jacobi(math_Matrix& a, math_Vector& d, math_Matrix&
|
|||||||
// Eigenvalues are sorted into descending order, and eigenvectors are
|
// Eigenvalues are sorted into descending order, and eigenvectors are
|
||||||
// arranges correspondingly.
|
// arranges correspondingly.
|
||||||
|
|
||||||
__math_API Standard_Real Random2(Standard_Integer& idum);
|
|
||||||
|
|
||||||
// returns a uniform random deviate betwween 0.0 and 1.0. Set idum to any
|
|
||||||
// negative value to initialize or reinitialize the sequence.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user