文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

PostgreSQL 16 新特性之正态分布随机数函数的示例

2023-01-31 10:30

关注

random() 函数可以用于生成一个大于等于 0 小于等于 1 的随机数,生成的数据遵循平均分布。不过在实际环境中,更多的数据则是遵循正态分布。PostgreSQL 提供了一个扩展模块 tablefunc,可以用于生成遵循正态分布的随机数;或者我们也可以创建存储函数来模拟正态分布的随机数。

考虑到它的实用性,PostgreSQL 16 新增了一个内置的 random_normal() 函数,用于生成这种随机数。我们使用该函数生成 10 个随机数:

select random_normal() as v from generate_series(1, 10);
v                  |
-------------------+
 1.9147182783615317|
-1.7265731892046994|
-0.9601043210986459|
 -1.481551351102244|
-1.3763031483133177|
0.11872324455736474|
 0.9016843380853512|
 0.1288806844184827|
-1.6392171916791691|
0.33770959079074697|

默认参数调用时,random_normal() 函数生成的随机数遵循标准正态分布(均值为 0,标准差为 1)。

以下示例生成的随机数遵循均值为 1、标准差为 5 的正态分布:

select random_normal(1, 5) as v from generate_series(1, 10);
v                  |
-------------------+
-0.4529440542028027|
  5.442251124798599|
  6.307851828542196|
  4.122825670258253|
 -2.186242122101672|
  4.767936509571358|
  5.172144288566877|
 -3.761475521327373|
-2.6431751259304193|
0.19249449162595722|

接下来我们验证一下该函数生成的数据是否遵循正态分布。

SELECT round(random_normal(1, 0.5)::numeric, 1) AS v,
       count(*),
       repeat('#', (count(*) / 100)::integer)
FROM generate_series(1, 100000)
GROUP BY v
ORDER BY v;

v   |count|repeat                                                                         |
----+-----+-------------------------------------------------------------------------------+
-1.2|    1|                                                                               |
-1.1|    1|                                                                               |
-1.0|    3|                                                                               |
-0.9|    9|                                                                               |
-0.8|   17|                                                                               |
-0.7|   21|                                                                               |
-0.6|   55|                                                                               |
-0.5|   98|                                                                               |
-0.4|  132|#                                                                              |
-0.3|  248|##                                                                             |
-0.2|  521|#####                                                                          |
-0.1|  728|#######                                                                        |
 0.0| 1090|##########                                                                     |
 0.1| 1586|###############                                                                |
 0.2| 2203|######################                                                         |
 0.3| 2975|#############################                                                  |
 0.4| 3878|######################################                                         |
 0.5| 4840|################################################                               |
 0.6| 5778|#########################################################                      |
 0.7| 6670|##################################################################             |
 0.8| 7299|########################################################################       |
 0.9| 7720|#############################################################################  |
 1.0| 7960|###############################################################################|
 1.1| 7794|#############################################################################  |
 1.2| 7271|########################################################################       |
 1.3| 6745|###################################################################            |
 1.4| 5796|#########################################################                      |
 1.5| 4796|###############################################                                |
 1.6| 3904|#######################################                                        |
 1.7| 3034|##############################                                                 |
 1.8| 2300|#######################                                                        |
 1.9| 1567|###############                                                                |
 2.0| 1175|###########                                                                    |
 2.1|  710|#######                                                                        |
 2.2|  454|####                                                                           |
 2.3|  267|##                                                                             |
 2.4|  164|#                                                                              |
 2.5|   94|                                                                               |
 2.6|   56|                                                                               |
 2.7|   23|                                                                               |
 2.8|    7|                                                                               |
 2.9|    8|                                                                               |
 3.0|    2|                                                                               |

从上面的图形可以看出,函数返回的结果是一个正态分布。我们还可以进一步通过均值和标准差进行验证:

WITH RECURSIVE d(n, v) AS (
  SELECT 1 AS n, random_normal(1, 0.5) AS v
  UNION ALL
  SELECT n+1, random_normal(1, 0.5) FROM d WHERE n<100000
)
SELECT count(*), avg(v), stddev(v)
FROM d;

count |avg               |stddev             |
------+------------------+-------------------+
100000|1.0009116232651825|0.49890904328727353|

到此这篇关于PostgreSQL 16 新特性之正态分布随机数函数的文章就介绍到这了,更多相关PostgreSQL随机数函数内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯