![]() |
|
|
|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
|
Опции темы | Поиск в этой теме | Опции просмотра |
|
#1
|
|||
|
|||
|
Здравствуйте! Есть две таблицы значений (x1,y1),(x2,y2),..., (x10;y10) и вторая (x1,y1*),(x2,y2*),....,(x10,y10*). Подскажите как найти точку в которой эти кривые пересекаются. Пересекаются они в тот момент когда разница (y1-y1*), (y2-y2*),..., (y10-y10*) меняет знак либо с плюса на минус либо наоборот. Подскажите, как это написать через цикл?
|
|
#2
|
|||
|
|||
|
Ну так и писать.
Как я понимаю, иксы в массивах одинаковые. Соотв.: Код:
uses
System.Math;
type
TPointItem = record
x, y : Integer;
end;
var
A, B : array [1..10] Of TPointItem;
var
I : Integer;
sgn : Integer;
Idx : Integer;
begin
Idx := 0;
sgn := sign(A[1].y - B[1].y);
For I := 2 To 10 Do
Begin
If sign(A[i].y - B[i].y) <> sgn Then
Begin
Idx := I;
Break;
End;
End;
If Idx > 0
Then ShowMessage('Intersect at Index = ' + IntToStr(I))
Else ShowMessage('Intersection not found');
end; |
|
#3
|
|||
|
|||
|
Да иксы одинаковые. А как можно задать точность вычисления? Например,когда разница двух ординат меньше 0,001, то и считать пересечением.
В вышеприведенном алгоритме находиться индекс, а как найти абсциссу пересечения? Может получиться, что пересекается не в конкретном шаге, а между ними. Последний раз редактировалось Maks19, 01.09.2022 в 09:20. |
|
#4
|
|||
|
|||
|
1. Ну, например, как-то так:
Код:
if abs(y1-y2) < 0.001 Then ... 3. Ну тут тогда сложнее. Тогда берем, например, аппроксимацию прямыми и проверяем пересекаются ли 2 соотв. прямые. Лень писать код, но там достаточно все просто - пересечение 2х прямых - задачка класса так 5-6го, уравнение прямой по 2м точкам где-то так же. Решаешь уравнение относительно x и смотришь - попадает ли этот x в границы отрезка. |
|
#5
|
|||
|
|||
|
Цитата:
|
|
#6
|
|||
|
|||
|
О, господя!!!
Ты знаешь все точки. Они у тебя в массиве... Код:
For I := 1 To 9 Do If IsIntersect(A[i], A[I+1], B[i], B[I+1]) Then ... |