1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00
emv b7cd7c2b7c 0029322: Unify faces classification procedures in Boolean Operations
1. Unify the faces classification procedure of the methods BOPAlgo_BuilderSolid::PerformInternalShapes() and BOPAlgo_Builder::FillIn3DParts() using the latter as a base.
The new method BOPAlgo_Tools::ClassifyFaces() has been created for that. Both methods mentioned above have been updated to use the new one.

2. Forced intersection of the edges after enlarge of the tolerance values of their vertices during the operation has been added into BOP's intersection algorithm (BOPAlgo_PaveFiller).
BOPAlgo_Tools::PerformCommonBlocks() method has been updated to avoid loosing faces of the already created Common blocks.

As a result the case "boolean gdml_private ZF6" became more stable, because the intermediate result is no longer invalid.
Additional test cases have been added to verify this improvement (bugs modalg_7 bug29322_*)

3. When building PCurves for edges on faces, check the existing PCurves on its validity for periodic surfaces and adjust PCurves if necessary.
The improvement helps to produce the valid result in the test case "bugs moddata_1 bug152".

4. Avoid creation of empty Edge-Edge interference if the intersection point is lying close to a shared vertex.
The improvement helps obtain the valid result of the "bopcheck" operation in the test case "bugs modalg_7 bug27683".

Adjustment of the test case to current behavior:
- Avoid usage of the self-intersecting torus in the test case "boolean gdml_public A9".
- Fix the input shape in the test case "boolean bopfuse_complex H1" to provide valid result.
- Test cases "bugs moddata_1 bug152_1 bug152_2" have been unified into single test case "bugs moddata_1 bug152". Now, the case rebuilds invalid input data and performs all types of Boolean operations.
- Change the test case "bugs modalg_7 bug22750" to produce valid intermediate results used in subsequent operations as arguments.
- The following test cases are improvements:
- "boolean volumemaker D8"
- "boolean volumemaker G1"
- "bugs modalg_7 bug27683"
2017-11-23 13:04:52 +03:00

68 lines
2.6 KiB
Plaintext

# test script on make volume operation
# cylinder plane
# planar face
plane pln_f1 -335.23319463083521 698.25 1031.741684575172 0.95105651629515375 3.3306690738754676e-016 0.30901699437494723
erase pln_f1
mkface f1 pln_f1 -1000000 1000000 -1000000 1000000
# planar face
plane pln_f2 -361.48545975741939 698.25 1112.3677894628579 0.94413350938426932 -2.7755575615628914e-017 0.32956322072971667
erase pln_f2
mkface f2 pln_f2 -1000000 1000000 -1000000 1000000
# planar face
plane pln_f3 -377.03714595623018 -18.500000000000256 1080.1369248570181 -0.32956322072971639 -2.2204460492503131e-016 0.94413350938426943
erase pln_f3
mkface f3 pln_f3 -1000000 1000000 -1000000 1000000
# planar face
plane pln_f4 -379.81702109239041 -18.500000000000014 1016.6899885855038 0.93679437761793805 -2.2204460492503121e-016 0.34988039965596873
erase pln_f4
mkface f4 pln_f4 -1000000 1000000 -1000000 1000000
# planar face
plane pln_f5 -409.2680104425807 698.25 1095.6886109971422 0.94413350938426932 -2.7755575615628914e-017 0.32956322072971667
erase pln_f5
mkface f5 pln_f5 -1000000 1000000 -1000000 1000000
# planar face
plane pln_f6 -382.41124430916489 698.25 1016.4126070048281 0.95105651629515375 3.3306690738754676e-016 0.30901699437494723
erase pln_f6
mkface f6 pln_f6 -1000000 1000000 -1000000 1000000
# planar face
plane pln_f7 -863.07307891000005 156.50000000000011 -657.71745162000002 4.4909464723405365e-017 1 3.2628636031510525e-017
erase pln_f7
mkface f7 pln_f7 -1000000 1000000 -1000000 1000000
# planar face
plane pln_f8 -415.13750551487595 698.25 939.25789966596847 -0.34988039965596873 5.5511151231257827e-016 0.93679437761793805
erase pln_f8
mkface f8 pln_f8 -1000000 1000000 -1000000 1000000
# planar face
plane pln_f9 -340.44108716728596 698.25 967.50583750729675 -0.30901699437494723 -3.3306690738754691e-016 0.95105651629515375
erase pln_f9
mkface f9 pln_f9 -1000000 1000000 -1000000 1000000
# planar face
plane pln_f10 -377.03714596623058 698.24999999999989 1080.1369248570184 0.32956322072971667 1.1102230246251565e-016 -0.94413350938426932
erase pln_f10
mkface f10 pln_f10 -1000000 1000000 -1000000 1000000
# planar face
plane pln_f11 0 1240 6.0146332359067856e-014 0 -1 -1.1102230246251565e-016
erase pln_f11
mkface f11 pln_f11 -1000000 1000000 -1000000 1000000
# cylindrical face
cylinder cyl_f12 0 0 2.0539125955565396e-015 0 1 1.1102230246251565e-016 1026.3199999999999
erase cyl_f12
mkface f12 cyl_f12 0 6.2831853071795862 -1000000 1000000
# make volume operation
mkvolume result f1 f2 f3 f4 f5 f6 f7 f8 f9 f10 f11 f12
checkprops result -s 6.84902e+007 -v 4.35234e+009
checknbshapes result -wire 129 -face 129 -shell 31 -solid 31