- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 python 中创建连续分布时遇到问题,它真的开始让我烦恼。我已经阅读并重读了this python guide (scipy guide)这对我的问题没有帮助。
我的代码是这样的:
import sys
import scipy.stats
import numpy
def CDF_Random(N,NE,E,SE,S,SW,W,NW,Iterations):
WindDir = [0,45,90,135,180,225,270,315]
Freq = N,NE,E,SE,S,SW,W,NW
mydist = scipy.stats.rv_continuous(#My problem is what to write here)
cdf_rand=mydist.rvs(size=Iterations)
return (cdf_rand)
if __name__ == '__main__':
N = float(sys.argv[1])
NE = float(sys.argv[2])
E = float(sys.argv[3])
SE = float(sys.argv[4])
S = float(sys.argv[5])
SW = float(sys.argv[6])
W = float(sys.argv[7])
NW = float(sys.argv[8])
Iterations = float(sys.argv[9])
numpy.set_printoptions(threshold=Iterations)
sys.stdout.write(str(CDF_Random(N,NE,E,SE,S,SW,W,NW,Iterations)))
如您阅读代码时所见,我的问题是知道将什么放在括号中以创建连续分布。 scipy.stats.rv_continuous(#这里放什么)
。
我尝试了很多不同的东西,主要是 this document(scipy guide) 中建议的那些,就像设置我的上限和下限值 a=,b=
将其设置为 pdf
或 ppf
。我已经尝试使用在命令行中输入的那些或我写入代码本身的那些[arrays]
。
我从命令行运行这个命令python C:\Users\...\CDF.py 0.01 0.01 0.01 0.01 0.01 0.93 0.01 0.01 10
每次我得到;RuntimeError: maximum recursion depth exceeded
我曾尝试将递归深度重置为不同的值,但这不起作用或使 python 崩溃。sys.setrecursionlimit(10000)
所以基本上应该在 scipy.stats.rv_continuous()
之后的括号中输入什么来创建 [array]
的连续分布,称为 WindDir
对于给定的分布 freq
?老实说,我已经通过谷歌和 stackoverflow 网站仔细查看,使用关键字、带有标签的关键字和单独的标签进行搜索,但找不到解决方案。
编辑 1-期望的结果我希望输出是 0,360
或 0,2pi
最佳答案
好的,所以为了使用 rv_continuous
,您需要提供某种概率密度函数。在下面的示例中,我为给定的风向间隔 [0,360) 实现了累积密度函数。我通过在输入中指定的最近两个风向之间插入概率密度函数来实现这一点。请注意 rv_continuous
基类构造函数中指定的参数 a
和 b
...这些参数指定了所考虑区间的最小值和最大值。试用代码,如果您有任何问题,请提出,我会尽力帮助澄清。
编辑 我修改了 python 3 的代码,并更新了 cdf 以更准确地在基本方向给定的频率之间进行插值。
import scipy.stats
class rvc(scipy.stats.rv_continuous):
def __init__(self, freqs):
super().__init__(a=0,b=359.9999)
self.WindDir = [0.,45.,90.,135.,180.,225.,270.,315.,360.]
self.Freqs = freqs
def _cdf(self, x):
return [self.do_cdf(i) for i in x]
def do_cdf(self, x):
if x < 0: return 0.0
if x >= 360: return 1.0
v = 0.0
for i in range(9):
if x >= self.WindDir[i]:
v += self.Freqs[i]
else:
v += (self.Freqs[i]-self.Freqs[i-1])*(x-self.WindDir[i-1])/45.
break
return v
rv = rvc([0.01,0.01, 0.01, 0.01, 0.01, 0.01, 0.92, 0.01, 0.01])
print(rv.rvs(size=100))
运行它会产生类似的输出
[ 305.76400244 271.49390379 285.5514374 280.4422151 302.52158889
273.85068415 278.8377575 287.05260894 270.66219523 301.97131911
277.77725392 293.29633122 273.60832876 278.90703722 271.12590324
288.38285244 299.89362412 276.68015144 278.46429959 304.33532312
313.42248626 272.10226608 311.00385667 284.48822492 298.134523
300.08266465 272.17850056 270.07995773 359.9999 289.13032076
206.58066169 308.95821915 288.998036 280.93451276 294.33703562
278.02828894 307.96335447 292.50172701 313.67335738 291.99562061
275.98551449 307.72620259 283.11307243 309.6052904 283.65619152
305.80365684 303.43088801 314.74811251 302.8390404 288.16580807
299.84487396 302.34636138 291.09465231 310.74393544 279.23446355
309.83353391 292.62761642 273.22324646 291.16193395 298.51520679
299.87754111 280.29779055 276.76741796 285.5186257 301.7074023
274.9771402 280.6619726 276.53202603 289.50757382 313.61213159
98.86469637 298.41091812 83.62474126 290.42538277 306.70218844
270.81939255 290.25089647 305.3277742 278.03965968 280.5979916
307.9492377 284.30184233 307.14788891 283.33779011 270.86398644
297.70610336 277.48672772 300.35147777 271.07308885 304.41450287
312.5640489 273.54296504 311.62527023 298.95246144 275.199183
302.6063864 359.9999 311.25861396 306.83491033 313.52858514]
关于python - 在 python 中创建连续分布,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17676710/
我有两个项目。一个项目正在运行,没有任何问题。它是从 gitlab 下载的。另一个项目是从 github 下载的。 github项目有这个问题。我想使用默认的 gradle 分布。我想知道我做错了什么
我正在通过我学习的大学提供的 VNC 软件(远程访问)使用 IBM bigInsights,但我无法通过该桌面访问 Internet。为了使用互联网上的一些数据样本,我决定安装 Hadoop 在我的笔
所以,这非常简单,我有一个包含嵌套列表的列表,如下所示: List( *list1* List(List("n1", "n3"), List("n1", "n4"), List("n3", "n4")
我有以下示例。 prefix = ['blue ','brown '] suffix = [('dog','shoes','bike'), ('tree','cat','car')] 我想获得一个如下
我创建了一项调查并将其发送出去。该调查要求用户提供电子邮件,然后要求他们从包含 8 个不同选项的下拉菜单中选择要吃哪顿饭。有些人使用同一封电子邮件多次填写调查,但食物选择不同。 我有一个如下所示的 M
我在 Python 中使用 plotly 来创建由某些分类变量着色的美国县的等值线。由于县非常小,因此图像中的边界线占主导地位。我怎样才能摆脱它们(或将它们的宽度设置为零)? 到目前为止的代码和输出(
我们有qgamma在 R 和 gamm.inv在 excel 中,我无法使用 invgamma 获得相同的结果python中的函数。例如在excel中GAMMA.INV(0.99,35,0.08)=4
过去几年我经常使用 Docker,但对于 Kubernetes 来说我还是个新手。我从今天开始,与我以前使用 Docker swarm 的方式相比,我正在努力思考 Pod 概念的实用性。 假设我有一个
我有一个 UIStackView然而,subViews的第一个 View 是 UILabel它没有相应地调整它的大小。 我的代码如下; private let stackView: UIStackVi
我想绘制自由度为 1、2、5 和 10 的 Student t 分布;所有在一个图中,并为图中的每个分布使用不同的颜色。此外,在 Canvas 的左上角创建一个图例,并增加 df = 1 的曲线线宽。
我对 Python 很陌生,我在互联网上浏览过,但找不到任何可以帮助我解决问题的逻辑。 我在图中有降水值,现在我需要根据图中的这些值拟合 GEV 分布。每个值等于从 1974 年到 2017 年的一年
我正在尝试复制此图 https://wind-data.ch/tools/weibull.php 我编写的代码是 import matplotlib.pyplot as plt import nump
对于家庭作业,我必须绘制文本的词频并将其与最佳 zipf 分布进行比较。 根据对数对数图中的排名绘制文本的词频计数似乎效果很好。 但是我在计算最佳 zipf 分布时遇到了麻烦。结果应该如下所示: 我不
Mathematica 具有四参数广义逆 Gamma 分布: http://reference.wolfram.com/mathematica/ref/InverseGammaDistribution
正在用 C 语言开发一个学校项目,使用 Pthreads 将一维数组分解为 tRows 和 tCols 的子矩阵。整个数组的大小为 wRows 和 wCols。假设 wCols = 4、wRows =
有没有办法得到制服int32_t没有警告的分发?我用这个uniform_int_distribution在我的代码中,但我收到警告: 54988961.cpp: In function ‘int ma
在花了相当多的时间试图了解如何在 postgresql 数据库服务器之间实现负载平衡(分配数据库处理负载)之后,我来到这里。 我有一个 postgresql 系统,每秒吸引大约 100 笔交易,而且这
所以标题已经说明了一切。我们正在开发一个开始获得大量依赖项的项目。到目前为止,我们一直在使用 setuptools,但越来越多的依赖项要么不容易安装(例如 wxPython),要么在某些使用 easy
我有以下代码: #include #include #include using namespace boost::numeric; using namespace interval_lib;
我有一个对象列表,我想以随机顺序连续访问这些对象。 我想知道是否有一种方法可以确保随机值并不总是相似。 例子。 我的列表是队列列表,我试图交错这些值以生成用于测试的真实场景。 我并不是特别想要队列 1
我是一名优秀的程序员,十分优秀!