公告:本站正式转型为非交互式静态网站!
转型:本站将通过笔记和博客的形式继续为大家服务,关于 Mathematica 问答服务请移步至QQ群:365716997
联系:如有问题请联系QQ群管理员,或发送邮件至:lixuan.xyz@qq.com。
感谢:最后非常感谢大家多年来的支持与帮助!
参考《互联网跟帖评论服务管理规定》《中华人民共和国网络安全法》《网络信息内容生态治理规定》《互联网用户账号信息管理规定》

—— 2022-11-27

欢迎来到 Mathematica 问答社区

提问时请贴上文本代码

语法高亮:在编辑器中点击

被禁止的话题:广告破解

请阅读:《提问的智慧》

备用域名:mma.ooo

支持LaTex数学公式
行内公式标识符:\$ 或“$\backslash ($”+“$\backslash )$”,
行间公式标识符:\$\$ 或 “$\backslash [$”+“$\backslash ]$”

社区建议QQ群:365716997

分类

0 投票
875 浏览
大家好,我正在对一个piecewise 函数进行随机取样,但是最后取出的数值总是来自于一边,另外一边总是取不到,不知道是怎么回事,下面是我的函数的具体细节:

ProbabilityDistribution[Piecewise[{{ (1/806.573)*Exp[-(5713.73 - x)/806.573], x < 5713.73}, {(1/806.573)*Exp[(5713.73 - x)/806.573], x >= 5713.73}}], {x, -\[Infinity], \[Infinity]}]

换句话说,我只能取到小于 5713.73的数值,大于5713.73的样品根本没有。

请大侠帮忙看看,小弟出学。
用户: chenxiankai2009 (11 分)

1个回答

0 投票

这是由于你定义的概率密度函数有问题,其在实数域上的积分等于2,所以除以2就可以了:

pdf = ProbabilityDistribution[
   Piecewise[{{(1/806.573)*Exp[-(5713.73 - x)/806.573]/2, 
      x < 5713.73}, {(1/806.573)*Exp[(5713.73 - x)/806.573]/2, 
      x >= 5713.73}}], {x, -\[Infinity], \[Infinity]}];
RandomVariate[pdf, 100]
Plot[PDF[pdf, x], {x, 5713.73 - 5004, 5713.73 + 5004}, 
 Filling -> Axis]

用户: 野鹤 (5.1k 分)
...