gpt4 book ai didi

python - 如何将 Poisson CDF 编写为 Python Polars 表达式

转载 作者:行者123 更新时间:2023-12-02 17:57:42 27 4
gpt4 key购买 nike

我有一组极坐标表达式,用于生成 ML 模型的特征。我想向这个集合添加一个 poission cdf 功能,同时保持延迟执行(具有速度、缓存等优点......)。到目前为止我还没有找到实现这一目标的简单方法。

我已经能够在所需的惰性表达式框架之外获得我想要的结果:

import polars as pl
from scipy.stats import poisson

df = pl.DataFrame({"count": [9,2,3,4,5], "expected_count": [7.7, 0.2, 0.7, 1.1, 7.5]})
result = poisson.cdf(df["count"].to_numpy(), df["expected_count"].to_numpy())
df = df.with_column(pl.Series(result).alias("poission_cdf"))

但是,实际上我希望它看起来像这样:

df = pl.DataFrame({"count": [9,2,3,4,5], "expected_count": [7.7, 0.2, 0.7, 1.1, 7.5]})
df = df.select(
[
... # bunch of other expressions here
poisson_cdf()
]
)

其中 poisson_cdf 是一些极坐标表达式,例如:

def poisson_cdf():
# this is just for illustration, clearly wont work
return scipy.stats.poisson.cdf(pl.col("count"), pl.col("expected_count")).alias("poisson_cdf")

我还尝试使用由 "count""expected_count" 组成的结构,并在应用自定义函数时按照文档中的建议进行应用。然而,我的数据集实际上有数百万行 - 导致执行时间荒谬。

如有任何建议或指导,我们将不胜感激。理想情况下,那里存在这样的表达方式吗?提前致谢!

最佳答案

如果scipy.stats.poisson.cdf被实现为正确的numpy universal function ,可以直接在极坐标表达式上使用它,但事实并非如此。幸运的是,Poisson CDF 几乎与 scipy 提供的正则化上不完全 Gamma 函数相同 gammaincc可以在极坐标表达式中使用:

>>> import polars as pl
>>> from scipy.special import gammaincc
>>> df = pl.select(pl.arange(0, 10).alias('k'))
>>> df.with_columns(cdf=gammaincc(pl.col('k') + 1, 4.0))
shape: (10, 2)
┌─────┬──────────┐
│ k ┆ cdf │
│ --- ┆ --- │
│ i64 ┆ f64 │
╞═════╪══════════╡
│ 0 ┆ 0.018316 │
│ 1 ┆ 0.091578 │
│ 2 ┆ 0.238103 │
│ 3 ┆ 0.43347 │
│ ... ┆ ... │
│ 6 ┆ 0.889326 │
│ 7 ┆ 0.948866 │
│ 8 ┆ 0.978637 │
│ 9 ┆ 0.991868 │
└─────┴──────────┘

结果与poisson.cdf返回的结果相同:

>>> _.with_columns(cdf2=pl.lit(poisson.cdf(df['k'], 4)))
shape: (10, 3)
┌─────┬──────────┬──────────┐
│ k ┆ cdf ┆ cdf2 │
│ --- ┆ --- ┆ --- │
│ i64 ┆ f64 ┆ f64 │
╞═════╪══════════╪══════════╡
│ 0 ┆ 0.018316 ┆ 0.018316 │
│ 1 ┆ 0.091578 ┆ 0.091578 │
│ 2 ┆ 0.238103 ┆ 0.238103 │
│ 3 ┆ 0.43347 ┆ 0.43347 │
│ ... ┆ ... ┆ ... │
│ 6 ┆ 0.889326 ┆ 0.889326 │
│ 7 ┆ 0.948866 ┆ 0.948866 │
│ 8 ┆ 0.978637 ┆ 0.978637 │
│ 9 ┆ 0.991868 ┆ 0.991868 │
└─────┴──────────┴──────────┘

关于python - 如何将 Poisson CDF 编写为 Python Polars 表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/75303038/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com