mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
1. Cylinders are tangent to each other indeed. Fix processes this case. 2. Algorithm of intersection line computing (in case of cylinders with two parallel axes) has been changed. Test cases for issue CR25782
69 lines
1.5 KiB
Plaintext
Executable File
69 lines
1.5 KiB
Plaintext
Executable File
puts "========"
|
|
puts "OCC25782"
|
|
puts "========"
|
|
puts ""
|
|
######################################################
|
|
# The result of intersection between two cylinders is incorrect
|
|
######################################################
|
|
|
|
set GoodNbCurv 2
|
|
|
|
cylinder s1 0 0 0 12 35 47 5
|
|
cylinder s2 3 2 8 12 35 47 4
|
|
|
|
set bug_info [intersect res s1 s2]
|
|
|
|
set che [whatis res]
|
|
set ind [string first "3d curve" $che]
|
|
if {${ind} >= 0} {
|
|
#Only variable "res" exists
|
|
|
|
copy res res_1
|
|
}
|
|
|
|
if {[llength ${bug_info}] != $GoodNbCurv} {
|
|
puts "Error: The result of intersection between two cylinders is incorrect"
|
|
}
|
|
|
|
set Tolerance 1.e-7
|
|
set D_good 0.
|
|
set Limit_Tol 1.0e-7
|
|
|
|
set ic 1
|
|
set AllowRepeate 1
|
|
while { $AllowRepeate != 0 } {
|
|
set che [whatis res_$ic]
|
|
set ind [string first "3d curve" $che]
|
|
if {${ind} < 0} {
|
|
set AllowRepeate 0
|
|
} else {
|
|
if { [regexp {\*\*\nLine} [dump res_$ic]] } {
|
|
#puts "OK : Correct intersection"
|
|
} else {
|
|
puts "Error : Bad intersection"
|
|
}
|
|
|
|
dlog reset
|
|
dlog on
|
|
xdistcs res_$ic s1 0 100 10
|
|
set Log1 [dlog get]
|
|
set List1 [split ${Log1} {TD= \t\n}]
|
|
set Tolerance 1.0e-7
|
|
set Limit_Tol 1.0e-7
|
|
set D_good 0.
|
|
checkList ${List1} ${Tolerance} ${D_good} ${Limit_Tol}
|
|
|
|
dlog reset
|
|
dlog on
|
|
xdistcs res_$ic s2 0 100 10
|
|
set Log1 [dlog get]
|
|
set List1 [split ${Log1} {TD= \t\n}]
|
|
set Tolerance 1.0e-7
|
|
set Limit_Tol 1.0e-7
|
|
set D_good 0.
|
|
checkList ${List1} ${Tolerance} ${D_good} ${Limit_Tol}
|
|
|
|
incr ic
|
|
}
|
|
}
|