Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
0 / 0 / 1
Регистрация: 19.06.2014
Сообщений: 2

Пересечение эллипса и окружности

14.12.2014, 21:32. Показов 2725. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Собственно нужно написать алгоритм пересечения эллипса и окружности. Фигуры задаются координатами центров и радиусами. Самое первое что пришло в голову это решить систему уравнений, состоящую из уравнения эллипса и окружности.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
float alpha, beta, gamma, D, y1, y2, x1, x2, X_c, Y_c, X_e, Y_e; //X_c Y_c точка центра окружности 
    alpha = pow(Rx,2)-pow(Ry,2); //Коэф А                                 //X_e Y_e точка центра эллипса 
    beta = 2*Y_c*pow(Ry,2) - 2*Y_e*pow(Rx,2); // B
    gamma = pow(Y_e,2)*pow(Rx,2)-pow(Rx,2)*pow(Ry,2)+pow(R,2)*pow(Ry,2)-pow(Y_c,2)*pow(Ry,2); //C
    D = pow(beta,2)-4*alpha*gamma;
    if(D>0) { 
        y1 = (-beta+sqrt(D))/(2*alpha); 
        y2 = (-beta-sqrt(D))/(2*alpha); 
        x1 = sqrt(fabs(pow(R,2)-pow(y1-Y_c,2)))+X_c;
        x2 = sqrt(fabs(pow(R,2)-pow(y2-Y_c,2)))+X_c; 
        bool i1,i2,i3,i4,j1,j2,j3,j4;
        i1 = VpisO(X_c, Y_c, R, x1, y1); j1 = VpisE(X_e, Y_e, Rx, Ry, x1, y1); //VpisO и VpisE
        i2 = VpisO(X_c, Y_c, R, x1, y2); j2 = VpisE(X_e, Y_e, Rx, Ry, x1, y2); //Проверяют точки
        i3 = VpisO(X_c, Y_c, R, x2, y1); j3 = VpisE(X_e, Y_e, Rx, Ry, x2, y1); // на принадлежность
        i4 = VpisO(X_c, Y_c, R, x2, y2); j4 = VpisE(X_e, Y_e, Rx, Ry, x2, y2); // Окружности и эллипсу соответственно
        if(i1 && j1 || i2 && j2 || i3 && j3 || i4 && j4) return true; //проверка на принадлежность точек фигурам 
        else return false;
      }
Вот система:
https://www.cyberforum.ru/cgi-bin/latex.cgi?\begin{cases} & \ {x}^{2}={R}^{2}-{y}^{2}  \\  & \ \frac{{R}^{2}-{y}^{2}}{{a}^{2}}+\frac{{y}^{2}}{{b}^{2}}=1 \\ \end{cases}
где, x=(x-x0) и y=(y-y0)
Результаты расчетов совпадают с ручными, но на практике результаты не попадают в цель. На рисунке ниже, красная точка - есть точка которую мы нашли. Крестики - место где должна находиться точка.
Миниатюры
Пересечение эллипса и окружности  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.12.2014, 21:32
Ответы с готовыми решениями:

Пересечение эллипса и окружности
С помощью программы на С/С++ вычислить с помощью любого вычислительного метода (сканирования, итераций и т.п.) две точки пересечения...

Сравнить длину эллипса и окружности
Здраствуйте, помогите пожалуйста, должно быть два класса эллипс - базовый, окружность - клас-наследник, необходимо сравнить длину даных...

Пересчет угла окружности в угол эллипса
Всем доброго времени суток. Собственно есть угол на окружности, нужно получить угол на эллипсе для построения дуги. Для неподвижного...

2
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
14.12.2014, 21:53
Что-то у вас рисунок не совпадает с системой уравнений. В системе заданы окружность и эллипс симметричные относительно начала координат, а на рисунке их центры симметрии не совпадают.
0
0 / 0 / 1
Регистрация: 19.06.2014
Сообщений: 2
27.01.2015, 10:49  [ТС]
С задачей справился самостоятельно. Вот решение: суть такова, что я определил эллипс множеством точек, вместо кривой, представив уравнение эллипса параметрически.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
bool Collision(здесь передаем координаты центров фигур и их радиусы)
{
           /*Cначало исключаем варианты когда эллипс описан или вписан*/
                bool i1, i2, i3, i4, i5, j1;
        i1 = VpisO(X_c, Y_c, R, X_e, Y_e); 
        i2 = VpisO(X_c, Y_c, R, X_e+Rx, Y_e+Ry);
        i3 = VpisO(X_c, Y_c, R, X_e-Rx, Y_e-Ry);
        i4 = VpisO(X_c, Y_c, R, X_e-Rx, Y_e+Ry);
        i5 = VpisO(X_c, Y_c, R, X_e+Rx, Y_e+Ry);
        if(i1 && i2 && i3 && i4 && i5 || i1 && !i2 && !i3 && !i4 && !i5)
            return false;/*Если эллипс вписанный или описанный, то пересечения нет*/
        else
        {
            double x[361], y[361];
                        //строим эллипс "поточечно" с помощью уравнения эллипса в парам-ой форме
            for(int a = 0; a <= 360; a++)//a - угол альфа [0; 2pi]
            {
                x[a] = X_e + Rx * cos(a); y[a] = Y_e+Ry * sin(a);
                TPrintXML(x[a], y[a]); //Тестовая функция. Рисует эллипс "поточечно"
            }
            for(int a = 0; a <= 360; a++) //проверка всех точек
            {
                j1 = VpisO(X_с, Y_c, R, x[a],y[a]); 
                if(j1) return true;//если хотя бы одна из точек на поверхности эллипса принадлежит окружности
            }
        }
}
На изображений слева эллипс - кривая; справа - эллипс как множество точек.
Вопросы и предложения приветствуются.
Миниатюры
Пересечение эллипса и окружности   Пересечение эллипса и окружности  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.01.2015, 10:49
Помогаю со студенческими работами здесь

Пересечение окружности и прямой
Задана окружность с центром в точке O(x0;y0) и Радиусом R0 и прямая y=ax+b Определить, пересекаются ли прямая и окружность. При...

Пересечение прямой и окружности
На плоскости заданы множество точек А и множество окружностей В. Найдите две такие различные точки из А, что проходящая через них прямая...

Пересечение кубической параболы и окружности
Задание звучит так: с клавиатуры вводятся коэффициенты, которые определяют полином третьего степени. Найти точки пересечения его с...

Проверить пересечение окружности и прямой
Заданы окружность радиуса R с центром в начале координат и прямая, проходящая через точки А (х; у) и В (х; -у).). Написать программу,...

Функция определяющая пересечение окружности и прямой
Пожалуйста напишите код с комментариями а то я немного тупенькая . Нужно | разработать функцию, определяющую, пересекаются ли...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru