我想用 OpenTURNS 创建高斯样本的对数似然的等高线图。每个等高线映射到一个函数值,该函数值由绘图的图例指示。问题是图例在某种程度上隐藏了轮廓:如何设置绘图以使图例不隐藏内容?
这是一个例子。我创建了一个Normal
与 20 至 79 岁之间的男性身高相对应的分布(参见“美国人口普查局的统计摘要。”表 209. 2012)。然后我从这个分布中生成一个样本。我定义了对数似然函数,它采用输入向量 (mu, sigma) 并返回一个包含对数似然输出的一维向量。我可以使用draw
这个函数的方法来创建等高线图。
import openturns as ot
import openturns.viewer as otv
mu = 1.763
sigma = 0.0680
N = ot.Normal(mu, sigma)
sample_size = 100
sample = N.getSample(sample_size)
def loglikelihood_gauss(X):
"""Compute the log-likelihood of a Gaussian sample."""
mu, sigma = X
N = ot.Normal(mu, sigma)
log_pdf = N.computeLogPDF(sample)
sample_size = sample.getSize()
log_likelihood = log_pdf.computeMean() * sample_size
return log_likelihood
# Contour plot
logLikelihoodFunction = ot.PythonFunction(2, 1, loglikelihood_gauss)
ot.ResourceMap_SetAsUnsignedInteger("Contour-DefaultLevelsNumber", 5)
graph = logLikelihoodFunction.draw([1.65, 0.04], [1.85, 0.15], [50]*2)
graph.setXTitle(r"$\mu$")
graph.setYTitle(r"$\sigma$")
graph.setTitle("Log-Likelihood.")
view = otv.View(graph)
这会产生:
如何设置绘图以使图例不隐藏轮廓?