2014 dxdy logo

Научный форум dxdy

Математика, Физика, Computer Science, Machine Learning, LaTeX, Механика и Техника, Химия,
Биология и Медицина, Экономика и Финансовая Математика, Гуманитарные науки


Правила форума


В этом разделе нельзя создавать новые темы.

Если Вы хотите задать новый вопрос, то не дописывайте его в существующую тему, а создайте новую в корневом разделе "Помогите решить/разобраться (М)".

Если Вы зададите новый вопрос в существующей теме, то в случае нарушения оформления или других правил форума Ваше сообщение и все ответы на него могут быть удалены без предупреждения.

Не ищите на этом форуме халяву, правила запрещают участникам публиковать готовые решения стандартных учебных задач. Автор вопроса обязан привести свои попытки решения и указать конкретные затруднения.

Обязательно просмотрите тему Правила данного раздела, иначе Ваша тема может быть удалена или перемещена в Карантин, а Вы так и не узнаете, почему.



Начать новую тему Ответить на тему
 
 Пересечение прямой и параллелепипеда
Сообщение14.07.2006, 10:47 


20/11/05
12
Москва
Дана плоскость OXYZ. Известны координаты двух точек на прямой в этой плоскости, а также координаты всех восьми вершин параллелепипеда. Как узнать, пересекает эта прямая параллелепипед или нет. Точка пресечения не нужна, нужно установить сам факт пересечения.

 Профиль  
                  
 
 Re: Пересечение прямой и параллелепипеда
Сообщение14.07.2006, 13:50 


11/07/06
201
myf писал(а):
Дана плоскость OXYZ. Известны координаты двух точек на прямой в этой плоскости, а также координаты всех восьми вершин параллелепипеда. Как узнать, пересекает эта прямая параллелепипед или нет. Точка пресечения не нужна, нужно установить сам факт пересечения.


Что значит плоскость OXYZ? - это не понял.
Задача я так понимаю в пространстве.
Я бы нашел параметрическое уравнение прямой. Нашел уравнения всех 6 плоскостей, ограничивающих параллелепипед. Затем составил бы систему неравенств на основе следующего принципа:

Отклонение точки прямой от плоскости, в которой лежит грань параллелепипеда и отклонение от противоположной плоскости должно иметь противоположные знаки.

Получится система трех квадратныхнеравенств. Если система совместна - пересечение есть.

Вроде правильно. Как короче не знаю.

 Профиль  
                  
 
 
Сообщение14.07.2006, 15:41 
Заслуженный участник
Аватара пользователя


01/03/06
13626
Москва
Может, так будет проще:1) Совершить афинное преобразование пространства, переводящее параллелепипед в единичный куб с началом координат в его центре и пересчитать уравнение прямой в новых координатах..
2) Найти решение задачи в этом случае, что совсем просто.
И, конечно, афинное преобразование сохраняет отношение "прямая пересекает параллелепипед"

 Профиль  
                  
 
 
Сообщение14.07.2006, 16:10 
Заслуженный участник


09/02/06
4401
Москва
Это только кажущееся упрощение. На самом деле всё равно надо найти точки пересечения плоскостями, образованными гранями параллелепида, и проверить принадлежит ли точка пересечения грани. Должно найтись по крайней мере 2 грани с этим свойством.
Соответственно записываем уравнение прямой
(1)$r=r_0+at$, r,r0,a векторы и уравнение плоскостей:
(2) $((r-r_A),(r_B-r_A),(r_C-r_A))=0$ (здесь используется смешанное произведение).
Подставив (1) в (2) находим t и координаты точки пересечения. Далее с помощью вычисления значений
$V=((r_D-r_A)(r_B-r_A),(r_C-r_A)),C_*=((r_*-r_A)(r_B-r_A)(r_D-r_A)$
проверяем находится ли точка пересечения между плоскостями ABD и параллельнем к нему через точку С. В случае нахождения число $C_*$ должно находится в интервале от нуля до V. И так проводя все проверки узнаем о пересечении.

 Профиль  
                  
 
 
Сообщение14.07.2006, 16:45 
Заслуженный участник
Аватара пользователя


01/03/06
13626
Москва
Руст писал(а):
... В случае нахождения число $C_*$ должно находится в интервале от нуля до V. И так проводя все проверки узнаем о пересечении.

Алгоритм не годится, если прямая проходит через вершину параллелепипеда.

 Профиль  
                  
 
 
Сообщение14.07.2006, 16:59 
Заслуженный участник


09/02/06
4401
Москва
Если проходит через вершину, то для трёх граней выполняется крайнее значение 0 или V (если уравнения выражены через координаты именно этой вершины, то трижды 0).

 Профиль  
                  
 
 
Сообщение14.07.2006, 22:56 


20/11/05
12
Москва
Спасибо большое за ответы. Мне просто нужно как бы написать программу по определению этого факта. Системку такую не просто будет решить на компе.

 Профиль  
                  
 
 
Сообщение15.07.2006, 00:15 


20/11/05
12
Москва
А может просто проверить, пересекает ли прямая каждый многоугольник??? Это ведь по идее проще, как мне кажется.

 Профиль  
                  
 
 
Сообщение16.07.2006, 14:54 
Заслуженный участник
Аватара пользователя


21/12/05
5931
Новосибирск
Мне больше по душе то, что написал Brukvalub, возможно потому, что и сам подумал то же самое.
А реализация здесь очень простая.
1) Пересчёт параметров прямой при аффинном преобразовании (которое и находить не обязательно)
требует решения двух линейных систем с тремя неизвестными.
Это и есть простая, но самая трудоёмкая часть. :D Остальное ещё проще - это просто логика, которая на компе производится
наиболее быстро.
2) Просто давайте распишем то "совсем просто", о котором говорил Brukvalub. Итак пусть дан единичный куб,
одна вершина которого в начале координат, а три ей смежные - на осях. Прямая пусть проходит через
точку (a,b,c) с направляющим вектором (m,n,k).
Положим $P(a,b,c, m,n,k) \equiv (m\ne 0) \& $
$((0\le b-\frac{a}{m}n\le 1)\&(0\le c-\frac{a}{m}k\le 1)\vee $
$((0\le b+\frac{1-a}{m}n\le 1)\&(0\le c+\frac{1-a}{m}k\le 1))$

Тогда условие пересечения прямой с кубом равносильно истинности формулы:
$P(a,b,c, m,n,k)\vee P(b,c, a, n,k,m)\vee P(c,a,b, k,m,n)$

Содержательно здесь просто написано, что если прямая пересекает куб, то она пересекает
некоторую грань под ненулевым углом - этим и объясняется отсутстве в формуле дизъюнктов, содержащих m=0, n=0 и k=0.

Разумеется в успешном случае вычисляются и точки пересечения с гранями, но это для этого надо
явно выписать аффинный переход, что впрочем тоже просто.

 Профиль  
                  
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 9 ] 

Модераторы: Модераторы Математики, Супермодераторы



Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group