指数分布推导

离散模拟时候经常遇到这个分布.

先说结论:

老板开小卖部,平均经过\(\lambda\)时间会有一个客人进店买东西, 那么第一个客人进店的时间服从指数分布. 速率是 \(1/\lambda\) , 密度函数是: $\frac{1}{\lambda}e^{-\frac{x}{\lambda}} $. 表示当前时间是x, 那么这个时间点第一个客人进来的概率是这个.

证明过程:

先证泊松分布. 再利用泊松分布得到指数分布.

python源码分析:

import random
random.expovariate(1.0 / interval)  # interval就是平均多少小时会有一个客人进来买东西.

def expovariate(self, lambd):
        """Exponential distribution.

        lambd is 1.0 divided by the desired mean.  It should be
        nonzero.  (The parameter would be called "lambda", but that is
        a reserved word in Python.)  Returned values range from 0 to
        positive infinity if lambd is positive, and from negative
        infinity to 0 if lambd is negative.

        """
        # lambd: rate lambd = 1/mean
        # ('lambda' is a Python reserved word)

        # we use 1-random() instead of random() to preclude the
        # possibility of taking the log of zero.
        return -_log(1.0 - self.random()) / lambd

上来一直没看懂源码, 后来问了问心一言和ds. 都提到了逆采样.他们用累计分布来计算密度分布,非常好的思路.

首先我们看指数分布的 CDF, 也就是密度函数的积分.

F(x;λ)=P(X≤x)=\(1−e^{−λx}\) ,其中λ是速率=1/mean

\(y=1−e^{−λx}\)

那么我们有\(e^{−λx}=1-y\), 两遍取log

λx=-log(1-y)

两遍除以λ就是我们上面代码 return部分的公式了.

相关推荐
tyler-泰勒15 分钟前
c++:迭代器的失效
开发语言·c++
白晨并不是很能熬夜20 分钟前
【JVM】字节码指令集
java·开发语言·汇编·jvm·数据结构·后端·javac
IT、木易21 分钟前
大白话解释 JavaScript 中的this关键字,它在不同场景下是如何取值的?
开发语言·javascript·ecmascript
*.✧屠苏隐遥(ノ◕ヮ◕)ノ*.✧27 分钟前
C语言_数据结构总结7:顺序队列(循环队列)
c语言·开发语言·数据结构·算法·visualstudio·visual studio
LIUJH123329 分钟前
数据结构——单调栈
开发语言·数据结构·c++·算法
何以解忧唯有撸码2 小时前
winform 实现太阳,地球,月球 运作规律
c#·winfrom·地球·gdi·月球·太阳·运作规律
Tomorrow'sThinker2 小时前
Python零基础学习第三天:函数与数据结构
开发语言·windows·python
元媛媛2 小时前
Python - 轻量级后端框架 Flask
开发语言·python·flask
钢板兽2 小时前
Java后端高频面经——Spring、SpringBoot、MyBatis
java·开发语言·spring boot·spring·面试·mybatis
爱吃柠檬呀2 小时前
《C陷阱与缺陷》读书笔记(一)
c语言·开发语言·算法·《c陷阱与缺陷》·编写程序