1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +03:00
occt/tests/bugs/moddata_3/bug25782_2
nbv b70d2b0999 0025782: The result of intersection between two cylinders is incorrect
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
2015-02-12 11:52:54 +03:00

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
}
}