Форум программистов, компьютерный форум, киберфорум
Python
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
2 / 2 / 0
Регистрация: 05.10.2019
Сообщений: 228

Для каждого треугольника триангуляции Делоне нарисовать описанную окружность

19.02.2023, 11:38. Показов 836. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Для каждого треугольника триангуляции Делоне нарисовать описанную окружность (Matplotlib)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.02.2023, 11:38
Ответы с готовыми решениями:

Нарисовать окружность, описанную около треугольника
Нарисовать окружность,описанную около треугольника. Есть определенная формула,или методом подбора можно нарисовать? С помощью...

Реализовать итеративный алгоритм триангуляции Делоне для построения нерегулярной сетки
Всем привет,прошу помочь вот с чем: -В C# нужно реализовать алгоритм триангуляции делоне(Итеративный) для построения нерегулярной сетки ...

Доработка Триангуляции Делоне
Добрый вечер, ребята. Есть готовая программа, которая строит триангуляционную сетку и выполняет поиск k - D деревом от одной точки до...

3
 Аватар для anapshy
533 / 274 / 220
Регистрация: 14.11.2016
Сообщений: 1,054
27.02.2023, 04:55
Python
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
import matplotlib.pyplot as plt
import scipy.spatial as sp
import numpy as np
 
# Generate some random points
points = np.random.rand(10, 2)
 
# Create a Delaunay triangulation object
tri = sp.Delaunay(points)
 
# Plot the triangulation
plt.triplot(points[:,0], points[:,1], tri.simplices)
 
# Get the circumcenters of each triangle
circumcenters = tri.circumcenters
 
# Plot the circumcircles
for c in circumcenters:
    # Calculate the radius of the circle
    r = np.sqrt(np.sum((points[tri.simplices[0]] - c)**2, axis=1))[0]
    # Draw the circle
    circle = plt.Circle(c, r, fill=False)
    plt.gca().add_patch(circle)
 
plt.show()
0
5516 / 2869 / 571
Регистрация: 07.11.2019
Сообщений: 4,760
27.02.2023, 21:01
anapshy, это не твой код. Ты его даже не проверял. Он нерабочий.
0
 Аватар для anapshy
533 / 274 / 220
Регистрация: 14.11.2016
Сообщений: 1,054
09.03.2023, 12:59
Python
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
import matplotlib.pyplot as plt
import scipy.spatial as sp
import numpy as np
 
# Generate some random points
points = np.random.rand(10, 2)
 
# Create a Delaunay triangulation object
tri = sp.Delaunay(points)
 
# Plot the triangulation
plt.triplot(points[:,0], points[:,1], tri.simplices)
 
# Calculate the circumcenters manually
circumcenters = []
for simplex in tri.simplices:
    # Get the coordinates of the three vertices of the simplex
    vertices = points[simplex]
    # Calculate the midpoint and perpendicular bisector of each side
    midpoints = [(vertices[i] + vertices[j])/2 for i, j in [(0, 1), (1, 2), (2, 0)]]
    bisectors = [-1*np.array([mp[1]-mp[0], mp[0]-mp[1]]) for mp in midpoints]
    # Calculate the intersection of two bisectors to get the circumcenter
    intersections = []
    for i, j in [(0, 1), (1, 2), (2, 0)]:
        A, B = bisectors[i], bisectors[j]
        b = np.dot(B,B)
        A_dot_B = np.dot(A,B)
        A_dot_A = np.dot(A,A)
        D = A_dot_A*b - A_dot_B**2
        if D != 0:
            C = [(A_dot_A*np.dot(A,B) - A_dot_B*np.dot(A,A))/D, (A_dot_A*np.dot(B,A) - A_dot_B*np.dot(B,B))/D]
            intersections.append(C)
    if intersections:
        circumcenters.append(intersections[0])
 
# Plot the circumcircles
for c in circumcenters:
    # Calculate the radius of the circle
    r = np.sqrt(np.sum((points[tri.simplices[0]] - c)**2, axis=1))[0]
    # Draw the circle
    circle = plt.Circle(c, r, fill=False)
    plt.gca().add_patch(circle)
 
plt.show()
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.03.2023, 12:59
Помогаю со студенческими работами здесь

Алгоритм триангуляции Делоне
Здравствуйте! У меня возник вопрос касательно итеративного алгоритма триангуляции Делоне набора точек. Кратко опишу алгоритм. ...

Классификация триангуляции Делоне
Всем добрый день! Есть такая задача. Объект. Объект трехмерный, построен с помощью триангуляции Делоне. Есть жёстко завязанные...

Нужен алгоритм триангуляции Делоне
Скажите по пунктам алгоритм триангуляции Делоне, а то во всех источниках написана теория. p.s моя задача - запрограммировать триангуляцию...

Написание Триангуляции Делоне иттеративным методом
Всем привет, сейчас пытаюсь создать игру при помощи Unity и столкнулся с проблемой соединения комнат, сгенерированных BSP-алгоритмом,...

Локализация точки с динамическим кэшированием в триангуляции Делоне
Здравствуйте! Можете подробно рассказать, как работает локализация точки с динамическим кэшированием поиска треугольников? Вот здесь,...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru