python 等值线图_如何用Python绘出三值等值线图?

如果可以生成要绘制任意比例轮廓的数据,则有一种解决方法。在这种情况下,您可以在网格上生成(x,y)数据,将它们映射到重心坐标,并计算z值。然后您可以使用非三元图,如轮廓或曲面。在

下面是一个绘制Dirichlet分布密度函数的示例:import plotly as py

import plotly.graph_objs as go

import numpy as np

def compute_in_barycentric_coordinates(a, b, c):

epsilon = 1e-6

if 0.0 < a < 1.0 and 0.0 < b < 1.0 and 0.0 < c < 1.0 and abs(a + b + c - 1.0) < epsilon:

return pow(a, 2) * pow(b, 1.5) * pow(c, 1.8)

return None

x_data = np.linspace(0, 1, 101)

y_data = np.linspace(0, 1, 101)

z_data = []

f = 1.0 / pow(3.0, 0.5)

for y in y_data:

next_slice = []

for x in x_data:

a = 1 - x - f*y

b = x - f*y

c = 2*f*y

z = compute_in_barycentric_coordinates(a, b, c)

next_slice.append(z)

z_data.append(next_slice)

data = [

go.Contour(

x=x_data,

y=y_data,

z=z_data,

)

]

py.offline.plot(data)

7d092b1cbba4565ce7e9432fa6ab985b.png

不过,这仍然是一个解决办法,所以如果你有更好的想法,我将非常高兴听到你的消息。在

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值