Полярный контурный участок в боке или плотт - PullRequest
0 голосов
/ 27 сентября 2018

Мне нужно нарисовать контурный график, используя Bokeh или Plotly Python, чтобы показать распределение волн в области формы круга.Я всегда изучал 49 пунктов, и x_cord и y_cord известны и не меняются в разных случаях.Плотность волны (z) может быть рассчитана из другой функции в python и изменяется в каждом конкретном случае.

Я искал в Интернете и не могу найти решение.Кто-нибудь знаком с Bokeh / Plotly, который может помочь в этом?

Картинка, которую я хочу нарисовать, выглядит следующим образом: enter image description here

Спасибо!

Вот входные данные x_cord, y_cord и пример z

x_cord = [0, -0,0, -34,6, -49, -34,6, 0,0, 34,6, 49, 34,6, -0,0, -37,5, -69,3, -90,5, -98, -90,5, -69,3, -37,5, 0,0, 37,5, 69,3, 90,5, 98, 90,5, 69,3, 37,5, -0,0, -38,0, -73,5, -103,9, -127,3, -142,0, -147, -142,0, -127,3, -103,9, -73,5, -38,0, 0,0, 38,0, 73,5, 103,9, 127,3, 142,0, 147, 142,0, 127,3, 103,9, 73,5, 38,0]

y_cord = [0, 49, 34,6, -0,0, -34,6, -49, -34,6, 0,0, 34,6, 98, 90,5, 69,3, 37,5, -0,0, -37,5, -69,3, -90,5, -98,-90,5, -69,3, -37,5, 0,0, 37,5, 69,3, 90,5, 147, 142,0, 127,3, 103,9, 73,5, 38,0, -0,0, -38,0, -73,5, -103,9, -127,3, -142,0, -147,-142,0, -127,3, -103,9, -73,5, -38,0, 0,0, 38,0, 73,5, 103,9, 127,3, 142,0]

z = [0,932, 0,93, 0,93, 0,932, 0,933, 0,933, 0,932,0,931, 0,93, 0,924, 0,925, 0,926, 0,927, 0.928, 0,929, 0,929, 0,929, 0,93, 0,929, 0,928, 0,927, 0,926, 0,925, 0,924, 0,924, 0,92, 0,92, 0,921, 0,922, 0,923, 0,923, 0,924, 0,925, 0,924, 0,924, 0,925, 0,925,0,923, 0,921, 0,92, 0,921, 0,92, 0,919, 0,919, 0,917, 0,917, 0,918, 0,919]

1 Ответ

0 голосов
/ 27 сентября 2018

В plotly вы можете получить что-то вроде этого: Contour plot

Code:
# import the necessaries libraries
import plotly.offline as py
import plotly.graph_objs as go
# Create data
data = [
    go.Histogram2dcontour(
          x = [0, -0.0, -34.6, -49, -34.6, 0.0, 34.6, 49, 34.6, -0.0, -37.5,\
               -69.3, -90.5, -98, -90.5, -69.3, -37.5, 0.0, 37.5, 69.3, 90.5,\
               98, 90.5, 69.3, 37.5, -0.0, -38.0, -73.5, -103.9, -127.3,\
               -142.0, -147, -142.0, -127.3, -103.9, -73.5, -38.0, 0.0, 38.0,\
               73.5, 103.9, 127.3, 142.0, 147, 142.0, 127.3, 103.9, 73.5, 38.0],
          y = [0, 49, 34.6, -0.0, -34.6, -49, -34.6, 0.0, 34.6, 98, 90.5, 69.3,\
               37.5, -0.0, -37.5, -69.3, -90.5, -98, -90.5, -69.3, -37.5, 0.0,\
               37.5, 69.3, 90.5, 147, 142.0, 127.3, 103.9, 73.5, 38.0, -0.0,\
               -38.0, -73.5, -103.9, -127.3, -142.0, -147, -142.0, -127.3,\
               -103.9, -73.5, -38.0, 0.0, 38.0, 73.5, 103.9, 127.3, 142.0],
          z = [0.932, 0.93, 0.93, 0.932, 0.933, 0.933, 0.932, 0.931, 0.93,\
               0.924, 0.925, 0.926, 0.927, 0.928, 0.929, 0.929, 0.929, 0.93,\
               0.929, 0.928, 0.927, 0.926, 0.925, 0.924, 0.924, 0.92, 0.92,\
               0.921, 0.922, 0.923, 0.923, 0.924, 0.925, 0.924, 0.924, 0.925,\
               0.925, 0.924, 0.923, 0.921, 0.92, 0.921, 0.92, 0.919, 0.919,\
               0.917, 0.917, 0.918, 0.919],
         # You can choose another colorscale if you want
         #[‘Blackbody’,‘Bluered’,‘Blues’,‘Earth’,‘Electric’,‘Greens’,‘Greys’,\
         # ‘Hot’,‘Jet’,‘Picnic’,‘Portland’,‘Rainbow’,‘RdBu’,‘Reds’,‘Viridis’,
         # ‘YlGnBu’,‘YlOrRd’]
         colorscale='Portland',
         contours=dict(
            coloring='heatmap',
            start=3,
            end=9,
            size=1
         ),
    )
]
# Layout usually need to set the title, size of plot etc.
layout = go.Layout(
    height = 600,
    width = 600,
    bargap = 0,
    hovermode = 'closest',
    showlegend = False)
# Create fig
fig = go.Figure(data=data,layout=layout)
# Save the plot in your Python script directory and open in a browser
py.plot(fig, filename='contoursimple.html')

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

...