mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
1. Earlier we could not put any IntPatch_Point to the intersection curve. The fix makes the algorithm of IntPatch_Points searching more precise. It is achieved by redetermination of earlier found vertices with help of minimization the distance between boundary of one intersection argument and another intersection argument (surface). 2. Additional check has been added, if IntPatch_Point adjusted to the domain boundary is true intersection point. 3. Method Contap_ArcFunction::Surface() has been added. 4. Method LastComputedPoint() has been added for IntPatch_ArcFunction and Contap_ArcFunction classes. 5. Correction in FindMaxDistance() method (see IntTools_FaceFace.cxx file) according to pure Golden-ratio minimization algorithm. Earlier this function worked wrong with small searching intervals. 6. Insignificant correction in math_BrentMinimum.cxx file (elimination of "defines"). Creation of test case for issues #27221 an #27252. Adjusting some test cases according to their new behavior. Correction according to the last remarks. Small correction of shape names for issue CR27252 Test case for issue 28210 Small correction of test case for issue 28210
63 lines
1.4 KiB
Plaintext
Executable File
63 lines
1.4 KiB
Plaintext
Executable File
puts "========"
|
|
puts "OCC569"
|
|
puts "========"
|
|
puts ""
|
|
##################################
|
|
## Can not intersect trimmed plane and cone surfaces
|
|
##################################
|
|
|
|
set GoodNbCurv 1
|
|
|
|
restore [locate_data_file OCC569a.draw] s1
|
|
restore [locate_data_file OCC569b.draw] s2
|
|
|
|
smallview
|
|
don s1 s2
|
|
fit
|
|
|
|
if { [catch {intersect result s1 s2 } catch_result] } {
|
|
puts "Faulty OCC569 exception: function intersection works wrongly with trimmed plane and cone surfaces "
|
|
} else {
|
|
checkview -screenshot -2d -path ${imagedir}/${test_image}.png
|
|
|
|
set che [whatis result]
|
|
set ind [string first "3d curve" $che]
|
|
if {${ind} >= 0} {
|
|
#Only variable "res" exists
|
|
copy result result_1
|
|
}
|
|
|
|
trim s1 s1
|
|
trim s2 s2
|
|
|
|
set ic 1
|
|
set AllowRepeate 1
|
|
while { $AllowRepeate != 0 } {
|
|
set che [whatis result_$ic]
|
|
set ind [string first "3d curve" $che]
|
|
if {${ind} < 0} {
|
|
set AllowRepeate 0
|
|
break
|
|
}
|
|
|
|
bounds result_$ic U1 U2
|
|
dump U1 U2
|
|
|
|
if {[dval U2-U1] < 1.0e-9} {
|
|
puts "Error: Wrong curve's range!"
|
|
}
|
|
|
|
xdistcs result_$ic s1 U1 U2 10 1e-7
|
|
xdistcs result_$ic s2 U1 U2 10 1e-7
|
|
|
|
incr ic
|
|
}
|
|
}
|
|
|
|
if {[expr {$ic - 1}] == $GoodNbCurv} {
|
|
puts "OCC569 OK: function intersection works with trimmed plane and cone surfaces"
|
|
} else {
|
|
puts "Faulty OCC569: function intersection works wrongly with trimmed plane and cone surfaces"
|
|
}
|
|
|