Форум программистов, компьютерный форум, киберфорум
Python: Научные вычисления
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/8: Рейтинг темы: голосов - 8, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 08.05.2022
Сообщений: 5

Как по скоплениям точек провести линии?

20.05.2022, 18:35. Показов 1820. Ответов 5

Студворк — интернет-сервис помощи студентам
Есть набор точек (x, y) в двумерном пространстве, соответствующие "точкам возмущения поля"


Визуально эти точки выстраиваются в линии. Необходимо отрисовать линии по скоплениям точек (ниже пример необходимой отрисовки линии).


Причём линий может быть от одной до двух.

Есть ли какие-то алгоритмы или идеи, как на языке Python реализировать такое построение линий по точкам?
Буду премного благодарен за какие-нибудь идеи или наводки!
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.05.2022, 18:35
Ответы с готовыми решениями:

Найти все способы провести линию через две точки, так чтобы слева и справа от линии было одинаковое число точек
Здравствуйте. Возникли трудности с программой. Сама задача: Дано множество точек с координатами Х и Y (количество четное), необходимо найти...

как провести интернет по телефонной линии?
Здравствуйте.Как провести интернет по телефонной линии? Есть интернет через сетевую плату.Нужно витую пару подсоединить к телефонной...

Как провести линию под определенным углом к уже проведенной линии?
как провести линию под определенным углом к уже проведенной линии (lineto, moveto). Или может можно это сделать не именно lineto а как то...

5
578 / 411 / 69
Регистрация: 09.01.2018
Сообщений: 1,363
20.05.2022, 19:43
Причем тут "идеи". Это- классика жанра. Называется "Регрессия". Может быть линейная, нелинейная. Может быть с предварительной сегментацией или без. При использовании различных мер близости и пр.пр.пр. Какая именно надо вам- можно понять, проанализировав ваши данные и проэксперементирвав с ними.
И разумеется, большинство из используемых в настоящее время регрессионных моделей давно реализованы в Python, вернее в его экосистеме (numpy, scipy, statistics и пр.). Ну, а потом они лЁгко отрисовываются с помощью mstplotlib или seaborn.
0
0 / 0 / 0
Регистрация: 08.05.2022
Сообщений: 5
21.05.2022, 00:37  [ТС]
Спасибо за наводку!

Цитата Сообщение от passant Посмотреть сообщение
Какая именно надо вам- можно понять, проанализировав ваши данные и проэксперементирвав с ними.
Не могли бы вы подробнее рассказать, каким образом можно определить какая регрессионная модель подошла бы для решения моей задачи?
0
533 / 438 / 47
Регистрация: 17.07.2013
Сообщений: 2,236
21.05.2022, 09:00
Цитата Сообщение от passant Посмотреть сообщение
Называется "Регрессия"
Похоже, тут всё гораздо проще - соединить на графике некие точки и основной вопрос, по каким критериям эти точки выбрать.
Судя по этой фразе:
Цитата Сообщение от antohachekhov Посмотреть сообщение
каким образом можно определить
этого никто не знает
0
2630 / 1642 / 266
Регистрация: 19.02.2010
Сообщений: 4,361
21.05.2022, 13:47
Лучший ответ Сообщение было отмечено antohachekhov как решение

Решение

Цитата Сообщение от Nick07 Посмотреть сообщение
Похоже, тут всё гораздо проще - соединить на графике некие точки и основной вопрос, по каким критериям эти точки выбрать.
Загоруйко Н.Г. Прикладные методы анализа данных и знаний. 1999г - там кластеризация на основе идеи https://www.cyberforum.ru/cgi-bin/latex.cgi?\lambda-компактности.
В общем, по облаку точек строится минимальное остовное дерево, рёбра сортируются не по их длине - а по более хитрой метрике (характеризующей изменение локальной плотности распределения, точнее, изменение "густоты" точек), и затем "рубятся" рёбра, соответствующие "переходам" изменения плотности.
Для иллюстрации - фрагмент из указанной книжки:

В итоге остаются однородно локально-связные, "плотные" группы точек, для которых можно будет построить более "красивые" аппроксимации (вместо соединяющих эти точки минимальных остовных подграфов) - например, через непараметрическую регрессию "внутри" каждого из полученных "облаков" точек. Но даже с непараметрикой остаётся проблема возможной многозначности функции регрессии.
2
5515 / 2868 / 571
Регистрация: 07.11.2019
Сообщений: 4,758
21.05.2022, 14:55
antohachekhov, попробуйте DBSCAN...
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.05.2022, 14:55
Помогаю со студенческими работами здесь

Как провести кривую через несколько точек
Привет программистам! Решил написать здесь, так как пишу проект под java. Если быть точным, то под андроид, но вопрос этой платформы не...

Как провести плавную кривую через массив точек
массивы sigmaCM и TtCM служат координатами как x и у Private Sub Ok_Click_Click(ByVal sender As System.Object, ByVal e As...

Как узнать координаты точек на линии тренда?
был построен график, для прогнозирования использовалась линия тренда (полиномиальная), прогноз нужен вперёд на 2 периода, линия тренда была...

Провести перпендикуляр от центра линии
Нужно провести перпендикуляр от центра линии, начальные координаты которого х1,у1; а конечные - х2,у2. Длина перпендикуляра должна быть...

Провести касательные к линии l, перпендикулярные p
l: x^2+y^2-8x+2y+12=0 p: 2x-y+4=0


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru