- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个二元分布,它是从每个 Group
的 xy 点生成的。在 'Int_1','Int_2'
.我通过 Norm
对分布进行归一化并将其传递给轮廓以显示 z 值。
我想返回 'Item_X','Item_Y'
中显示的 xy 点处二元分布的 z 值.下图中使用白色散点显示了一个示例。
最终,我将传递 'Item_X','Item_Y'
的 z 值在每个时间点添加到数据框并将其附加回原始 df。
import pandas as pd
import numpy as np
from scipy.stats import multivariate_normal as mvn
import matplotlib.pyplot as plt
from scipy.interpolate import RectBivariateSpline
df = pd.DataFrame({'Int_1': [1.0, 2.0, 1.0, 3.0, 1.0, 2.0, 3.0, 2.0],
'Int_2': [1.0, 2.0, 2.0, 2.0, 1.0, 1.0, 1.0, 2.0],
'Item_X': [0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0],
'Item_Y': [0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 1.0],
'Period': [1, 1, 1, 1, 2, 2, 2, 2],
'Group': ['A', 'B', 'A', 'B', 'A', 'B', 'A', 'B'],
'Item': ['Y', 'Y', 'A', 'B', 'A', 'B', 'A', 'B'],
'id': ['1', '2', '3', '4', '1', '2', '3', '4']})
Group_A = [df[df['Group'] == 'A'][['Int_1','Int_2']].to_numpy()]
Group_B = [df[df['Group'] == 'B'][['Int_1','Int_2']].to_numpy()]
Item = [df[['Item_X','Item_Y']].to_numpy()]
period = df['Period'].drop_duplicates().reset_index(drop = True)
def bivart_func(member_no, location, time_index, group):
if group == 'A':
data = Group_A.copy()
elif group == 'B':
data = Group_B.copy()
else:
return
if np.all(np.isfinite(data[member_no][[time_index,time_index + 1],:])) & np.all(np.isfinite(Item[0][time_index,:])):
sxy = (data[member_no][time_index + 1,:] - data[member_no][time_index,:]) / (period[time_index + 1] - period[time_index])
mu = data[member_no][time_index,:] + sxy * 0.5
out = mvn.pdf(location,mu) / mvn.pdf(data[member_no][time_index,:],mu)
else:
out = np.zeros(location.shape[0])
return out
xx,yy = np.meshgrid(np.linspace(-10,10,200),np.linspace(-10,10,200))
Z_GA = np.zeros(40000)
Z_GB = np.zeros(40000)
for k in range(1):
Z_GA += bivart_func(k,np.c_[xx.flatten(),yy.flatten()],0,'A')
Z_GB += bivart_func(k,np.c_[xx.flatten(),yy.flatten()],0,'B')
fig, ax = plt.subplots(figsize=(8,8))
ax.set_xlim(-10,10)
ax.set_ylim(-10,10)
Z_GA = Z_GA.reshape((200,200))
Z_GB = Z_GB.reshape((200,200))
Norm = xx,yy, (Z_GA - Z_GB)
cfs = ax.contourf(*Norm, cmap = 'magma')
ax.scatter(Item[0][1,0],Item[0][1,1], color = 'white', edgecolor = 'black')
f = RectBivariateSpline(xx[0, :], yy[:, 0], Norm)
z = f(df['Item_X'], df['Item_Y'], grid = False)
print(z)
最佳答案
Z 分数是一个参数,可让您比较不同的正态分布。任何正态分布都以相同的方式取决于 Z 分数。
Z-score 定义为
概率密度函数为
对于任何发行版,如果您替换 z
在f(x)
的定义中你总是得到exp(-0.5*z**2)/(sigma * sqrt(2*pi)
.
在您的情况下,您有一个概率比率,您可以找到一个类似于它的 z 值的值,但它会有不同的解释。为了做到这一点,我将尝试将正常 PDF 的比率转换为具有不同均值和协方差的缩放正常 PDF。
PDF 作为缩放 PDF 的比率
这在启用 latex 的论坛中更合适,我将用类似 python 的语法编写方程
多元分布可以描述为a * exp(-(x - mu).T @ A @ (x-mu))
如果你有两个分布的比率,你可以表示为(a1/a2) * exp(-(x - mu2).T @ A1 @ (x-mu2)) / exp(-(x - mu1).T @ A2 @ (x-mu2))
因为指数的比率是差的指数exp(-(x - mu2).T @ A1 @ (x-mu2) + (x - mu1).T @ A2 @ (x-mu2))
重新排列条款exp(-x.T @ (A1 - A2) @ x + 2 * x.T @ (A1 @ mu1 - A2 @ mu2) + mu1.T @ A1 @ mu2 + mu2.T @ A2 @ mu2)
术语 2 * x.T @ (A1 @ mu1 - A2 @ mu2)
组合两个线性项,并将定义分布的均值,即项 mu1.T @ A1 @ mu2 + mu2.T @ A2 @ mu2
是常数,并将作为分布的常数因子出现。
exp(-(x - mu).T @ A @ (x-mu))
缩放高斯的中心是这样的
(A1 - A2)@ mu3 = (A1 @ mu1 - A2 @ mu2)
因此
mu3 = (A1 - A2).inv() @ (A1 @ mu1 - A2 @ mu2)
和
A3=A1-A2
如
A3
是正定的(所有特征值都是正的),那么分布将是一个平均
mu3
的缩放高斯分布
a3 * exp(-(x - mu3).T @ A3 @ (x-mu3))
def combine(C1, C2, mu1, mu2):
"""
Given two multivariate normal distribution in a n-dimensional space
C1: Covariance of the first distribution
C2: Covariance of the second distribution
mu1: Center of the first distribution
mu2: Center of the second distribution
"""
A1 = C1.inv()
A2 = C2.inv()
C3 = (A1 - A2).inv()
mu3 = C3 @ (A1 @ mu1 - A2 @ mu2)
return C3, mu3
多元 z 值类似
def zValue(C, mu, x):
"""
C: n x n covariance matrix
mu: n x 1 center vector
x: n x 1 location vector
"""
return sqrt((x-mu).T @ C.inv() @ (x-mu))
zValue 将是曲线“中心”处的值与给定点之间的比率的函数。如果
A1 - A2
可能是负数不是肯定的正数,这意味着函数在给定点计算
x
大于在点
mu3
处评估的函数.
关于python - 返回分布的 z 值 - python,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67996607/
我正在处理一组标记为 160 个组的 173k 点。我想通过合并最接近的(到 9 或 10 个组)来减少组/集群的数量。我搜索过 sklearn 或类似的库,但没有成功。 我猜它只是通过 knn 聚类
我有一个扁平数字列表,这些数字逻辑上以 3 为一组,其中每个三元组是 (number, __ignored, flag[0 or 1]),例如: [7,56,1, 8,0,0, 2,0,0, 6,1,
我正在使用 pipenv 来管理我的包。我想编写一个 python 脚本来调用另一个使用不同虚拟环境(VE)的 python 脚本。 如何运行使用 VE1 的 python 脚本 1 并调用另一个 p
假设我有一个文件 script.py 位于 path = "foo/bar/script.py"。我正在寻找一种在 Python 中通过函数 execute_script() 从我的主要 Python
这听起来像是谜语或笑话,但实际上我还没有找到这个问题的答案。 问题到底是什么? 我想运行 2 个脚本。在第一个脚本中,我调用另一个脚本,但我希望它们继续并行,而不是在两个单独的线程中。主要是我不希望第
我有一个带有 python 2.5.5 的软件。我想发送一个命令,该命令将在 python 2.7.5 中启动一个脚本,然后继续执行该脚本。 我试过用 #!python2.7.5 和http://re
我在 python 命令行(使用 python 2.7)中,并尝试运行 Python 脚本。我的操作系统是 Windows 7。我已将我的目录设置为包含我所有脚本的文件夹,使用: os.chdir("
剧透:部分解决(见最后)。 以下是使用 Python 嵌入的代码示例: #include int main(int argc, char** argv) { Py_SetPythonHome
假设我有以下列表,对应于及时的股票价格: prices = [1, 3, 7, 10, 9, 8, 5, 3, 6, 8, 12, 9, 6, 10, 13, 8, 4, 11] 我想确定以下总体上最
所以我试图在选择某个单选按钮时更改此框架的背景。 我的框架位于一个类中,并且单选按钮的功能位于该类之外。 (这样我就可以在所有其他框架上调用它们。) 问题是每当我选择单选按钮时都会出现以下错误: co
我正在尝试将字符串与 python 中的正则表达式进行比较,如下所示, #!/usr/bin/env python3 import re str1 = "Expecting property name
考虑以下原型(prototype) Boost.Python 模块,该模块从单独的 C++ 头文件中引入类“D”。 /* file: a/b.cpp */ BOOST_PYTHON_MODULE(c)
如何编写一个程序来“识别函数调用的行号?” python 检查模块提供了定位行号的选项,但是, def di(): return inspect.currentframe().f_back.f_l
我已经使用 macports 安装了 Python 2.7,并且由于我的 $PATH 变量,这就是我输入 $ python 时得到的变量。然而,virtualenv 默认使用 Python 2.6,除
我只想问如何加快 python 上的 re.search 速度。 我有一个很长的字符串行,长度为 176861(即带有一些符号的字母数字字符),我使用此函数测试了该行以进行研究: def getExe
list1= [u'%app%%General%%Council%', u'%people%', u'%people%%Regional%%Council%%Mandate%', u'%ppp%%Ge
这个问题在这里已经有了答案: Is it Pythonic to use list comprehensions for just side effects? (7 个答案) 关闭 4 个月前。 告
我想用 Python 将两个列表组合成一个列表,方法如下: a = [1,1,1,2,2,2,3,3,3,3] b= ["Sun", "is", "bright", "June","and" ,"Ju
我正在运行带有最新 Boost 发行版 (1.55.0) 的 Mac OS X 10.8.4 (Darwin 12.4.0)。我正在按照说明 here构建包含在我的发行版中的教程 Boost-Pyth
学习 Python,我正在尝试制作一个没有任何第 3 方库的网络抓取工具,这样过程对我来说并没有简化,而且我知道我在做什么。我浏览了一些在线资源,但所有这些都让我对某些事情感到困惑。 html 看起来
我是一名优秀的程序员,十分优秀!