2014 dxdy logo

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

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


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


Посмотреть правила форума



Начать новую тему Ответить на тему На страницу Пред.  1, 2, 3, 4  След.
 
 Re: Пересечение отрезка с окружностью
Сообщение31.12.2017, 22:42 
Заслуженный участник
Аватара пользователя


23/07/08
10910
Crna Gora
Geen
А что?

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение31.12.2017, 23:47 
Заслуженный участник
Аватара пользователя


01/09/13
4699
svv в сообщении #1280450 писал(а):
Geen
А что?

Отодвинем отрезок от окружности в десять раз (вдоль перпендикуляра из центра окружности на отрезок) - знаки не изменяться...

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 00:28 
Заслуженный участник


27/04/09
28128
Чтобы уж наверняка работало, там должна быть не $O$, а интересующая точка пересечения прямой и окружности $C$. Правда, если хотя бы одно из произведений нулевое, это должно считаться как разные знаки (правильнее сформулировать так: первое и минус второе (или наоборот) произведения неотрицательны; это выражает, что точка пересечения лежит по ту же сторону (нестрого) от каждого конца отрезка, что и другой конец).

Geen в сообщении #1280458 писал(а):
Отодвинем отрезок от окружности в десять раз (вдоль перпендикуляра из центра окружности на отрезок)
Это как раз ничего не портит:
    svv в сообщении #1280426 писал(а):
    Допустим, мы уже знаем, что прямая, на которой лежит отрезок $AB$, пересекает окружность с центром в $O$ и радиусом $r$.
(Или я не понял.)

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 00:38 
Заслуженный участник
Аватара пользователя


23/07/08
10910
Crna Gora
arseniiv, именно.

Geen
Наш язык таков, что возможности ещё теснее придвинуть предположения к их следствиям я не нашёл... :-)

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 06:11 
Аватара пользователя


21/09/12

1871
Упростим постановку: перенесём центр окружности в $(0;0)$.
Тогда координаты концов отрезка перейдут в $x_1=x_1-x_0$ и т.д.
Проверяем концы отрезка на $L_{1,2}<R$, - если выполняется для одного конца и не выполняется для другого, то пересечение.
Если оба конца отрезка на $L_{1,2}>R$, то проверяем, меньше ли расстояние до центра от середины отрезка, чем от каждого из концов. Если да, то находим минимальное расстояние до прямой, заданной точками $(x_1, y_1), (x_2, y_2)$:
$L_{\min}=\frac{x_2y_1-x_1y_2}{\sqrt{(y_2-y_1)^2+(x_2-x_1)^2}}$
Если $L_{\min}<R$, то имеем две точки пересечения отрезка с окружностью.

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 08:51 
Аватара пользователя


21/09/12

1871
Переложил вышеизложенное на Паскаль:
Код:
program okr_otr; //Пересекает ли отрезок окружность?
var x0, y0, x1, y1, x2, y2, r, l1, l2, lsr, lmin :real;
begin
write('x0 центра окружности:'); readln(x0);
write('y0 центра окружности:'); readln(y0);
write('радиус r окружности:'); readln(r);
write('x1 отрезка:'); readln(x1);
write('y1 отрезка:'); readln(y1);
write('x2 отрезка:'); readln(x2);
write('y2 отрезка:'); readln(y2);
x1:=x1-x0; x2:=x2-x0; y1:=y1-y0; y2:=y2-y0;
l1:=sqrt(x1*x1+y1*y1); l2:=sqrt(x2*x2+y2*y2);
if ((l1<r) AND (l2>r)) OR ((l1>r) AND (l2<r)) then writeln('Одно пересечение')
else
  if (l1<r) AND (l2<r) then writeln('Пересечений нет')
  else
    begin
      lsr:=sqrt(power((x1+x2)/2,2)+power((y1+y2)/2,2));
      if (lsr>l1) OR (lsr>l2) then writeln('Пересечений нет')
      else
        begin
          lmin:=(x2*y1-x1*y2)/sqrt(power((y2-y1),2)+power((x2-x1),2));
          if lmin>r then writeln('Пересечений нет')
          else writeln('Два пересечения');
        end;
    end;
end.

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 18:28 
Заслуженный участник


27/04/09
28128
Начнём разбор:
atlakatl в сообщении #1280479 писал(а):
$L_{\min}=\frac{x_2y_1-x_1y_2}{\sqrt{(y_2-y_1)^2+(x_2-x_1)^2}}$
Модуль забыли. И нет чтобы по-человечески написать $\lVert\mathrm r_1\wedge\mathrm r_2\rVert/\lVert\mathrm r_2-\mathrm r_1\rVert$ ($\wedge$ здесь понимается как внешнее или псевдоскалярное по желанию; во втором случае будет, конечно, модуль скаляра, а не норма бивектора).

-- Пн янв 01, 2018 20:30:03 --

atlakatl в сообщении #1280479 писал(а):
Если оба конца отрезка на $L_{1,2}>R$, то проверяем, меньше ли расстояние до центра от середины отрезка, чем от каждого из концов. Если да <…>
А если нет, чего? Возможны разные случаи.

-- Пн янв 01, 2018 20:33:51 --

Ну и код (и его вывод: введённые числа будут идти после двоеточий сразу без пробела) тоже можно было сделать красивее, и это не говоря о [syntax lang="pascal"] вместо [code]. Кроме того, код, вроде, никто и не просил. Или код программы целиком, а не отдельной функции.

-- Пн янв 01, 2018 20:36:01 --

Вообще же всё было устроено выше, и дальше там уже ничего не получится сократить. В одном из случаев придётся честно сравнивать, лежат точки пересечения на отрезке или нет. (А если нужно не только количество или факт пересечений, то тем более незачем срезать.)

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 18:49 
Заслуженный участник
Аватара пользователя


09/09/14
6328
arseniiv в сообщении #1280534 писал(а):
...ничего не получится сократить. В одном из случаев придётся честно сравнивать, лежат точки пересечения на отрезке или нет.
Всё же чуть проще, кажется, смотреть не точки пересечения прямой с окружностью, а точку пересечения прямой с перпендикуляром к ней, восстановленным из центра окружности.

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 19:09 
Аватара пользователя


21/09/12

1871
Про модуль да, забыл.
"По-человечески" написать можно, но в Паскале таких функций нет, всё равно придётся переходить к расчётной формуле.
Про "разные случаи" дошло:
Изображение
Случай 3 я не учёл.
Надо проще. Если оба конца отрезка дальше $R$, то просто находим $L_{\min}$, сравнивая её с $R$

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 19:14 
Заслуженный участник


27/04/09
28128
grizzly
Это подходит только для случая, когда оба конца отрезка вне окружности, а для нахождения точек пересечения это, в принципе, можно не проверять.

-- Пн янв 01, 2018 21:21:05 --

atlakatl в сообщении #1280550 писал(а):
но в Паскале таких функций нет
Так написали бы. :wink: Код от этого станет длиннее в строках, но кому нужно число строк?

atlakatl в сообщении #1280550 писал(а):
Если оба конца отрезка дальше $R$, то просто находим $L_{\min}$, сравнивая её с $R$
Вы точно учли случай ниже?

Изображение

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 19:36 
Аватара пользователя


21/09/12

1871
arseniiv в сообщении #1280555 писал(а):
Вы точно учли случай ниже?
Этот случай я пытался учесть вначале.
Надо подумать. Праздник ещё.

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 20:03 


04/07/15
137
Все случаи. Прямая через две точки: пересекает, не пересекает, касается окружности.
Нам надо касается, пересекает.
Проверка на: точка отрезку принадлежит, не принадлежит через “гомотопическое” уравнение отрезка. Если параметр в переделах от 0 до 1, то принадлежит.

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение01.01.2018, 21:36 
Заслуженный участник


27/04/09
28128
Или через скалярные, как svv предлагал. Ничего нового не получится. :-(

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение02.01.2018, 04:05 
Аватара пользователя


21/09/12

1871
Сделал по svv. Ну и в паскалевский тег обрамил:
код: [ скачать ] [ спрятать ]
Используется синтаксис Pascal
program okr_otr; //Пересекает ли отрезок окружность?
var x0, y0, x1, y1, x2, y2, r, l1, l2 :real;
var per :boolean;
begin
x0:=0; y0:=0; r:=2; //координаты центра и радиус окружности
x1:=2.3; y1:=-10; x2:=1.995; y2:=10; //координаты концов отрезка
x1:=x1-x0; x2:=x2-x0; y1:=y1-y0; y2:=y2-y0;
l1:=sqrt(x1*x1+y1*y1); l2:=sqrt(x2*x2+y2*y2);
if ((l1<=r) AND (l2>=r)) OR ((l1>=r) AND (l2<=r)) then per:=TRUE
else if (l1<r) AND (l2<r) then per:=FALSE //Оба конца внутри окружности
  else //Оба конца за окружностью
    begin
      var p1:=x1*(x2-x1)+y1*(y2-y1); var p2:=x2*(x2-x1)+y2*(y2-y1);
      if ((p1>=0) AND (p2<=0) OR (p1<=0) AND (p2>=0)) AND (abs((x2*y1-x1*y2)/sqrt((power((y2-y1),2)+power((x2-x1),2))))<=r) then per:=TRUE
      else per:=FALSE;
    end;
if per then writeln('Пересекает') else writeln('Пересечений нет');
end.
 

 Профиль  
                  
 
 Re: Пересечение отрезка с окружностью
Сообщение02.01.2018, 11:51 
Заслуженный участник
Аватара пользователя


26/02/14
586
so dna
Igor2323 только не вздумайте вставлять вот это:
atlakatl в сообщении #1280622 писал(а):
Сделал по svv. Ну и в паскалевский тег обрамил:
код: [ скачать ] [ спрятать ]
Используется синтаксис Pascal
program okr_otr; //Пересекает ли отрезок окружность?
var x0, y0, x1, y1, x2, y2, r, l1, l2 :real;
var per :boolean;
begin
x0:=0; y0:=0; r:=2; //координаты центра и радиус окружности
x1:=2.3; y1:=-10; x2:=1.995; y2:=10; //координаты концов отрезка
x1:=x1-x0; x2:=x2-x0; y1:=y1-y0; y2:=y2-y0;
l1:=sqrt(x1*x1+y1*y1); l2:=sqrt(x2*x2+y2*y2);
if ((l1<=r) AND (l2>=r)) OR ((l1>=r) AND (l2<=r)) then per:=TRUE
else if (l1<r) AND (l2<r) then per:=FALSE //Оба конца внутри окружности
  else //Оба конца за окружностью
    begin
      var p1:=x1*(x2-x1)+y1*(y2-y1); var p2:=x2*(x2-x1)+y2*(y2-y1);
      if ((p1>=0) AND (p2<=0) OR (p1<=0) AND (p2>=0)) AND (abs((x2*y1-x1*y2)/sqrt((power((y2-y1),2)+power((x2-x1),2))))<=r) then per:=TRUE
      else per:=FALSE;
    end;
if per then writeln('Пересекает') else writeln('Пересечений нет');
end.
 

себе в код, иначе (даже после исправления всех синтаксических ошибок) ваша прога вылетит, например при x0=0, y0=0, x1=2, y1=2, x2=2, y2=2, r=1 (и при большом множестве других значений). Лучше сами аккуратно оформите все случаи.

 Профиль  
                  
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 56 ]  На страницу Пред.  1, 2, 3, 4  След.

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



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

Сейчас этот форум просматривают: katzenelenbogen


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

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