Python 生成两组具有相关性的随机数(给定相关系数)

在针对供需匹配模型做数值实验时时,遇到一个问题:当面临需求不确定性,如果不同需求点之间存在相关性,如何验证模型的有效性。
因此,在数值实验中需要生成具有一定相关性的需求随机数。

# 导入数组和画图包
import numpy as np
import matplotlib.pyplot as plt

# 设定样本数量
num_samples = 500

# The desired mean values of the sample.均值
mu = np.array([6, 8, 10])

# The desired covariance matrix.协方差矩阵
r = np.array([
        [  2.60, -1.55, -3.00],
        [ -1.55,  3.20,  1.40],
        [ -3.00,  1.40,  2.25]
    ])

# Generate the random samples.调用相关函数,生成随机数
rng = np.random.default_rng()
y = rng.multivariate_normal(mu, r, size=num_samples)


# Plot various projections of the samples.
# 从三组数据中任意取两组数据进行绘制,观察相关性
plt.subplot(2,2,1)
plt.plot(y[:,0], y[:,1], 'b.', alpha=0.25)
plt.plot(mu[0], mu[1], 'ro', ms=3.5)
plt.ylabel('y[1]')
plt.axis('equal')
plt.grid(True)

plt.subplot(2,2,3)
plt.plot(y[:,0], y[:,2], 'b.', alpha=0.25)
plt.plot(mu[0], mu[2], 'ro', ms=3.5)
plt.xlabel('y[0]')
plt.ylabel('y[2]')
plt.axis('equal')
plt.grid(True)

plt.subplot(2,2,4)
plt.plot(y[:,1], y[:,2], 'b.', alpha=0.25)
plt.plot(mu[1], mu[2], 'ro', ms=3.5)
plt.xlabel('y[1]')
plt.axis('equal')
plt.grid(True)

plt.show()

结果如下图所示:
共计
参考:
https://stackoverflow.com/questions/16024677/generate-correlated-data-in-python-3-3

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值