设为首页收藏本站

爱吱声

 找回密码
 注册
搜索
楼主: 晨枫
打印 上一主题 下一主题

[科研心得] 问题:如何从数据里估算普瓦松分布的均值?

[复制链接]
  • TA的每日心情
    慵懒
    14 小时前
  • 签到天数: 2515 天

    [LV.Master]无

    21#
    发表于 2019-2-4 13:21:29 | 只看该作者
    本帖最后由 松叶牡丹 于 2019-2-4 13:23 编辑
    ' @) W9 J3 H# q6 d6 H( X: a
    晨枫 发表于 2019-2-4 13:186 p7 {) j! h9 d# P: R( o
    正是:看数据点然后脑补。人工就是这么干的。但操作工要照管的事情太多,一会儿不看,可能就错过了,就可 ...

    ; Q2 k) a% t, J7 X/ f0 Q
    3 \5 S* K! c8 _" m+ z9 q7 Z降低精度,把一系列正态分布离散化为有限几个histogram,每次测试点先第一步进行范围判断,然后归到不同的histogram里面。再反向把histogram变换为对应的大致正态分布,这样可行吗?
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    22#
     楼主| 发表于 2019-2-4 13:23:16 | 只看该作者
    tanis 发表于 2019-2-3 23:12! P$ Y9 z- ~# {
    找温度第二,第三高的两个点,拟合个直线,取中间的那个位置

    9 ^1 s  w/ C6 V: v% J4 o! r% |, @0 v3 i塔板是等间距分布的,这样我还不如直接取温度最高的那一块了
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2023-4-1 00:01
  • 签到天数: 627 天

    [LV.9]渡劫

    23#
    发表于 2019-2-4 13:27:54 | 只看该作者
    晨枫 发表于 2019-2-4 13:23
    ) l) C% E3 _9 h* D& S塔板是等间距分布的,这样我还不如直接取温度最高的那一块了
    3 A8 v8 u) ]$ {) n; @5 f( p
    哦哦。。。 那就取最高和第二个的中间位置 有人工干预的时候就用人工,人忘了看就用这个。。。
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    24#
     楼主| 发表于 2019-2-4 13:28:01 | 只看该作者
    松叶牡丹 发表于 2019-2-3 23:21  Q3 O' n% [4 f( R
    降低精度,把一系列正态分布离散化为有限几个histogram,每次测试点先第一步进行范围判断,然后归到不同 ...
    & M  L. r! x8 V) g  }

    / R+ G; m! W  J( K! J一把抓住:我的问题正是从histogram变换为某种分布,最想poison分布或者log normal distribution,不行的话正态分布也行。有什么现成的计算方法吗?
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    25#
     楼主| 发表于 2019-2-4 13:29:03 | 只看该作者
    tanis 发表于 2019-2-3 23:27
    & E1 \5 i5 N1 E* f9 |哦哦。。。 那就取最高和第二个的中间位置 有人工干预的时候就用人工,人忘了看就用这个。。。 ...

    ; D: l2 `" t9 e6 Q这也是个办法,总是有点“心有不甘”……
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    26#
     楼主| 发表于 2019-2-4 13:33:41 | 只看该作者
    松叶牡丹 发表于 2019-2-3 23:21* a4 ^' R2 ~0 i9 i8 B
    降低精度,把一系列正态分布离散化为有限几个histogram,每次测试点先第一步进行范围判断,然后归到不同 ...
    % K/ g! B3 U- Q$ R- E+ I; n
    唉,MATLAB里有histfit命令,干的正是我要的,可惜没法“偷”过来用啊
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    14 小时前
  • 签到天数: 2515 天

    [LV.Master]无

    27#
    发表于 2019-2-4 13:36:06 | 只看该作者
    晨枫 发表于 2019-2-4 13:33
    ) q6 t' k0 ]1 W6 F( d& h7 ?唉,MATLAB里有histfit命令,干的正是我要的,可惜没法“偷”过来用啊
    7 J% U5 w/ d8 r* W2 W6 k
    完全不会FORTRAN,这样啊,要不就得自己写算法了?
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2023-4-1 00:01
  • 签到天数: 627 天

    [LV.9]渡劫

    28#
    发表于 2019-2-4 13:37:22 | 只看该作者
    晨枫 发表于 2019-2-4 13:33
    1 G' y' l% F' n; }1 `# N& K' e唉,MATLAB里有histfit命令,干的正是我要的,可惜没法“偷”过来用啊

    & |" N) s6 c6 \5 S7 W& {+ WMatlab 直接有poissfit啊。。。
    " C  W0 n% }5 O. e5 B$ h. {
    - D# n: O; Z. x0 p* n我感觉人类脑补的水平估计和取中值也差不了多少了既然连忘了看也只是可能出问题,我脚的中值差不多 )(缺乏工匠精神的我。。。)' t: I) y! M0 ~" Y2 u
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    29#
     楼主| 发表于 2019-2-4 13:40:49 | 只看该作者
    tanis 发表于 2019-2-3 23:37
    * l0 a0 l. H. V9 @Matlab 直接有poissfit啊。。。+ L/ R5 M# q- V7 t& a( _" i  n/ f

    ' g9 w% u8 g4 G4 g  u, R) c我感觉人类脑补的水平估计和取中值也差不了多少了既然连忘了看也 ...
    ; X+ M% Q, S# k- M  F
    问题是我没法把MATLAB装进DCS里用啊。嗯,如果不行的话,可能也只能内插取中值了。
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    14 小时前
  • 签到天数: 2515 天

    [LV.Master]无

    30#
    发表于 2019-2-4 13:41:18 | 只看该作者
    您这个采样数据如果有之前很长时间的大批量数据的话,要不选一部分建模,建立比如10个distribution式子,用剩下数据validate,看看是不是符合六西格玛质量控制要求?如果不行就提高精度,设20,30或者更多式子?我这是笨办法。
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    31#
     楼主| 发表于 2019-2-4 13:43:57 | 只看该作者
    松叶牡丹 发表于 2019-2-3 23:41
    - X) W" [# j  ^$ b0 @! S+ e您这个采样数据如果有之前很长时间的大批量数据的话,要不选一部分建模,建立比如10个distribution式子,用 ...
    ( q) C- I, U+ [. {) [4 l
    这个好像不行?我需要的是实时估计当前的峰值点,历史数据能帮什么忙呢?
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2018-6-21 09:14
  • 签到天数: 2 天

    [LV.1]炼气

    32#
    发表于 2019-2-4 13:55:23 | 只看该作者
    如果问题是拟合若干点的光滑曲线 找到最大值,kernel density 就好,matlab里的histfit 也是基于这个算法。fortran里面library浩若烟海,查查肯定能找到。速度绝对够快,不需要POISSON 假设。
    2 E# h* e) E  G0 U2 W) K% ]# ?0 M- E; B1 u5 Z" Y5 x$ y, X
    试着搜一下,这个fortran code 试试?: https://ideas.repec.org/c/boc/bocode/g00004.html

    评分

    参与人数 1爱元 +2 收起 理由
    tanis + 2 给力

    查看全部评分

    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    14 小时前
  • 签到天数: 2515 天

    [LV.Master]无

    33#
    发表于 2019-2-4 14:07:31 | 只看该作者
    晨枫 发表于 2019-2-4 13:43
    ( F6 @, f- t/ E. d+ ^+ V这个好像不行?我需要的是实时估计当前的峰值点,历史数据能帮什么忙呢? ...

    ' s9 v5 x* u& d( c2 r历史数据建模自己写算法做验证用。不过如果可以像楼上那位说的可以找到现成library调用,kernel density estimation和 guassian mixture model应该都可以。
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    34#
     楼主| 发表于 2019-2-4 14:16:53 | 只看该作者
    gnomegordon 发表于 2019-2-3 23:55
    4 Z) W; d4 b: \! ?) G5 B如果问题是拟合若干点的光滑曲线 找到最大值,kernel density 就好,matlab里的histfit 也是基于这个算法。 ...
      C+ o2 j; x0 e& D/ H2 g9 ]4 E$ ?( M
    十分感谢!打开看到的是SRC文件,还在找FORTRAN……
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    35#
     楼主| 发表于 2019-2-4 14:19:36 | 只看该作者
    松叶牡丹 发表于 2019-2-4 00:07
      p: W9 f" e% p4 [# P* ~历史数据建模自己写算法做验证用。不过如果可以像楼上那位说的可以找到现成library调用,kernel density  ...

    8 i/ f$ |- u3 M( c多谢!这个kernel density以前没有玩过,正在研究中……
    回复 支持 1 反对 0

    使用道具 举报

  • TA的每日心情
    慵懒
    2020-7-26 05:11
  • 签到天数: 1017 天

    [LV.10]大乘

    36#
    发表于 2019-2-4 14:24:18 | 只看该作者
    本帖最后由 Dracula 于 2019-2-4 14:28 编辑 / p) ?7 [" V  c7 K' h. }2 s/ O
    6 M% ~7 H# d, k4 j: H
    说实话,你这个题目我没看懂。
    6 }+ |4 V) D) C! X  }9 T: O9 `
    + q6 _5 S3 ?; o. m6 c1 k但如果你你单纯就是想实现
    ; r2 Y$ ], \* u% z) @6 I8 o4 r
    $ J7 U7 J# ]  G! s, V$ @. L8 U1 @
    我就是要拟合一个“钟形曲线”,然后找峰值所在点。相当于上图中红线(或者lambda=2)里横轴1-2之间的位置。

      p% P: j4 |6 @6 [* j3 }) k; p6 `; s3 ~$ u
    ) x+ z1 z- l3 M* l4 i# r1 J其实应该挺容易。假设这个分布是log normal,如果你知道这个分布的参数, μ和 σ,你要想计算峰值(英语是mode),有现成公式,套公式就可以了(公式你可以上网查,比如Wikipedia上就有)。估计这个分布怎么做,我没看懂你的题目,不好说。但既然正态分布你知道能怎么做,log-normal没什么本质区别,就是公式不一样。简单的使用method of moments应该很容易就能推导出公式。实现就是简单的算术计算,不需要什么数值方法。
    - U7 d, w& a5 I" t- D) A% F' E9 c9 K; Q9 v  E( ]
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    37#
     楼主| 发表于 2019-2-4 14:34:17 | 只看该作者
    Dracula 发表于 2019-2-4 00:244 e' S, {5 a' j
    说实话,你这个题目我没看懂。2 X: C8 Z+ D6 u3 b

    % i$ q& D( E2 q! ~+ C* d0 K# P2 J3 C但如果你你单纯就是想实现
    ( F# O; b1 K- S2 m
    有了 μ和 σ想计算峰值就容易了,我的问题是如何从histogram计算log normal的 μ和 σ。看来这也是个办法,把数据log一下,再按normal做。我也想到过这个办法,就是不大确定。明天试试,上班的活儿用下班的时间试,可不划不来嘛。
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    14 小时前
  • 签到天数: 2515 天

    [LV.Master]无

    38#
    发表于 2019-2-4 14:35:05 | 只看该作者
    Dracula 发表于 2019-2-4 14:24) |4 {: A# Q" k* F
    说实话,你这个题目我没看懂。
    5 \& m$ k& y1 I8 m
    & q" z$ i! e% C) x& U0 h! f但如果你你单纯就是想实现

    1 U1 v. K+ @/ \5 E6 `/ ?( G看题目意思应该是不知道参数的。
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    14 小时前
  • 签到天数: 2515 天

    [LV.Master]无

    39#
    发表于 2019-2-4 14:36:11 | 只看该作者
    晨枫 发表于 2019-2-4 14:19
    7 V( ^/ q3 N% ^0 {- C$ z9 N; Z多谢!这个kernel density以前没有玩过,正在研究中……
    1 s2 s. E, C" P5 C$ F" b8 N9 m
    晨大辛苦,您太客气了。祝新年快乐!
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2018-6-21 09:14
  • 签到天数: 2 天

    [LV.1]炼气

    40#
    发表于 2019-2-4 14:39:24 | 只看该作者
    晨枫 发表于 2019-2-4 14:16
    & K" n0 _- c; Z/ F十分感谢!打开看到的是SRC文件,还在找FORTRAN……

    2 `% M6 h6 a9 s  k3 \apologize. 网上搜code太麻烦,还得验证。最好有本书可以翻翻 或者搜library
    回复 支持 反对

    使用道具 举报

    手机版|小黑屋|Archiver|网站错误报告|爱吱声   

    GMT+8, 2026-4-1 15:10 , Processed in 0.085478 second(s), 21 queries , Gzip On.

    Powered by Discuz! X3.2

    © 2001-2013 Comsenz Inc.

    快速回复 返回顶部 返回列表