кодесурса
«Python

Python Math: Рассчитать сетку шестиугольных координат заданного радиуса с учетом нижнего левого и верхнего правого координат

script1adsense2code
script1adsense3code

Python Math: упражнение 62 с решением

Напишите программу на Python для расчета сетки координат шестиугольника заданного радиуса с учетом координат внизу слева и справа. Функция вернет список списков, содержащий 6 наборов координат точек x, y. Их можно использовать для построения правильных правильных шестиугольных многоугольников.

Пример решения : -

Код Python:

#https://gist.github.com/urschrei/17cf0be92ca90a244a91
import math
def calculate_polygons(startx, starty, endx, endy, radius):
     # calculate side length given radius   
    sl = (2 * radius) * math.tan(math.pi / 6)
    # calculate radius for a given side-length
    # (a * (math.cos(math.pi / 6) / math.sin(math.pi / 6)) / 2)
    # see http://www.calculatorsoup.com/calculators/geometry-plane/polygon.php
    
    # calculate coordinates of the hexagon points
    # sin(30)	
    p = sl * 0.5
    b = sl * math.cos(math.radians(30))
    w = b * 2
    h = 2 * sl
    
    # offset start and end coordinates by hex widths and heights to guarantee coverage     
    startx = startx - w
    starty = starty - h
    endx = endx + w
    endy = endy + h
    origx = startx
    origy = starty
    # offsets for moving along and up rows
    xoffset = b
    yoffset = 3 * p
    polygons = []
    row = 1
    counter = 0
    while starty < endy:
        if row % 2 == 0:
            startx = origx + xoffset
        else:
            startx = origx
        while startx < endx:
            p1x = startx
            p1y = starty + p
            p2x = startx
            p2y = starty + (3 * p)
            p3x = startx + b
            p3y = starty + h
            p4x = startx + w
            p4y = starty + (3 * p)
            p5x = startx + w
            p5y = starty + p
            p6x = startx + b
            p6y = starty
            poly = [
                (p1x, p1y),
                (p2x, p2y),
                (p3x, p3y),
                (p4x, p4y),
                (p5x, p5y),
                (p6x, p6y),
                (p1x, p1y)]
            polygons.append(poly)
            counter += 1
            startx += w
        starty += yoffset
        row += 1
    return polygons
print(calculate_polygons(1,1, 4, 4, 3))

Пример вывода:

 [[(-5,0, -4,196152422706632), (-5,0, -0,7320508075688767), (-2,0, 1,0), (1,0, -0,7320508075688767), (1,0, -4,1
96152422706632), (-2,0, -5,928203230275509), (-5,0, -4,196152422706632)], [(1,0, -4,196152422706632), (1,0, -0
.7320508075688767), (4.0, 1.0), (7.0, -0.7320508075688767), (7.0, -4.196152422706632), (4.0, -5.92820323027550
9), (1.0, -4.196152422706632)], [(7.0, -4.196152422706632), (7.0, -0.7320508075688767), (10.0, 1.0), (13.0, -0
.7320508075688767), (13,0, -4,196152422706632), (10,0, -5,928203230275509), (7,0, -4,196152422706632)], [(-2,0
------
), (10,0, 14,85640646055102), (10,0, 11,392304845413264), (7,0, 9,660254037844387), (4,0, 11,392304845413264)]
]  

Блок - схема:

«Блок-схема:

Визуализируйте выполнение кода Python:

Следующий инструмент визуализирует, что компьютер делает шаг за шагом при выполнении указанной программы:

Редактор кода Python:

Есть другой способ решить это решение? Внесите свой код (и комментарии) через Disqus.

Предыдущий: Напишите программу на Python для описания линейной регрессии.
Далее: Напишите программу на Python для создания простого математического теста.

Каков уровень сложности этого упражнения?

Новый контент: Composer: менеджер зависимостей для PHP , R программирования


script1adsense4code
script1adsense5code
disqus2code
script1adsense6code
script1adsense7code
script1adsense8code
buysellads2code