生成函数简介(Generating function)

11 篇文章 0 订阅

生成函数(Generating function),又称母函数,是一种形式幂级数,其每一项的系数可以提供关于这个序列的信息。使用母函数解决问题的方法称为母函数方法。
生成函数有许多不同的种类,但大多可以表示为单一的形式:
F ( x ) = ∑ n a n k n ( x ) F(x)=sum_{n}a_{n}k_{n}(x) F(x)=n∑ankn(x)
其中 k n ( x ) k_{n}(x) kn(x)被称为核函数。不同的核函数会导出不同的生成函数,拥有不同的性质。举个例子:

  • 普通生成函数: k n ( x ) = x n k_{n}(x)=x^{n} kn(x)=xn;

  • 指数生成函数: k n = x n n ! k_{n}= rac{x^{n}}{n!} kn=n!xn;

  • 狄利克雷生成函数: k n ( x ) = 1 n x k_{n}(x)= rac{1}{n^{x}} kn(x)=nx1。
    其他还有L级数,贝尔级数。
    另外,对于生成函数 F ( x ) F(x) F(x),我们用 [ k n ( x ) ] F ( x ) [k_{n}(x)]F(x) [kn(x)]F(x)来表示它的第 n n n项的核函数对应的系数,也就是 a n a_{n} an。
    对于每个序列都可以写出以上每个类型的一个母函数。构造母函数的目的一般是为了解决某个特定的问题,因此选用何种母函数视乎序列本身的特性和问题的类型。
    母函数的表示一般使用解析形式,即写成关于某个形式变量 x x x形式幂级数。对幂级数的收敛半径中的某一点,可以求母函数在这一点的级数和。但无论如何,由于母函数是形式幂级数的一种,其级数和不一定对每个 x x x的值都存在。
    母函数方法不仅在概率论的计算中有重要地位,而且已成为组合数学中一种重要方法。此外,母函数在有限差分计算、特殊函数论等数学领域中都有着广泛的应用。
    注意母函数本身并不是一个从某个定义域射到某个上域的函数,名字中的“函数”只是出于历史原因而保留。

  • 历史
    瑞士数学家雅各布·伯努利在考虑“当投掷 n n n粒骰子时,加起来点数总和等于 m m m的可能方式的数目”这个问题时首先使用了母函数方法,并得出可能的数目是 ( x + x 2 + x 3 + x 4 + x 5 + x 6 ) (x+x{2}+x{3}+x{4}+x{5}+x^{6}) (x+x2+x3+x4+x5+x6)的展开式中 x m x^{m} xm项的系数。之后欧拉在研究自然数的分解时也使用了母函数方法并奠定了母函数方法的基础。1812年,法国数学家拉普拉斯在著作《概率的分析理论》的第一卷中系统地研究了母函数方法及与之有关的理论。

  • 定义
    母函数就是一列用来展示一串数字的挂衣架。——赫伯特·维尔夫
    普通母函数
    普通母函数就是最常见的母函数。一般来说,序列 ( a n ) n ∈ N (a_{n})_{nin mathbb{N}} (an)n∈N
    G ( a n ; x ) = ∑ n = 0 ∞ a n x n G(a_{n};x)=sum{infty}_{n=0}a_{n}x{n} G(an;x)=n=0∑∞anxn
    如果 a n a_{n} an是某个离散随机变量的概率质量函数,那么它的母函数被称为一个概率母函数。
    多重下标的序列也可以有母函数,例如序列 ( a m , n ) m ∈ N , n ∈ N (a_{m,n})_{min mathbb{N},ninmathbb{N}} (am,n)m∈N,n∈N的母函数是:
    G ( a m , n ; x , y ) = ∑ m , n = 0 ∞ a m , n x m y n . G(a_{m,n};x,y)=sum{infty}_{m,n=0}a_{m,n}x{m}y^{n}. G(am,n;x,y)=m,n=0∑∞am,nxmyn.
    指数母函数
    序列 ( a n ) n ∈ N (a_{n})_{ninmathbb{N}} (an)n∈N的指数母函数是:
    E G ( a n ; x ) = ∑ n = 0 ∞ a n x n n ! EG(a_{n};x)=sum^{infty}_{n=0}a_{n} rac{x^{n}}{n!} EG(an;x)=n=0∑∞ann!xn
    泊松母函数
    序列 ( a n ) n ∈ N (a_{n})_{ninmathbb{N}} (an)n∈N的泊松母函数是:
    P G ( a n ; x ) = ∑ n = 0 ∞ a n e x x n n ! PG(a_{n};x)=sum{infty}_{n=0}a_{n}e{-x} rac{x^{n}}{n!} PG(an;x)=n=0∑∞anexn!xn
    L级数
    序列 ( a n ) n ∈ N (a_{n})_{ninmathbb{N}} (an)n∈N的L级数是:
    L G ( a n ; x ) = ∑ n = 1 ∞ a n x n 1 x n LG(a_{n};x)=sum^{infty}_{n=1}a_{n} rac{x{n}}{1-x{n}} LG(an;x)=n=1∑∞an1xnxn
    注意这里的下标 n n n从1而不是0开始。
    贝尔级数
    关于算术函数: f ( n ) f(n) f(n)和 p p p的贝尔级数是:
    f p ( x ) = ∑ n = 0 ∞ f ( p n ) x n f_{p}(x)=sum{infty}_{n=0}f(p{n})x^{n} fp(x)=n=0∑∞f(pn)xn
    狄利克雷级数母函数
    狄利克雷级数经常被用作母函数,尽管实际上狄利克雷级数并不是严格意义上的形式幂级数。序列 ( a n ) n ∈ N (a_{n})_{ninmathbb{N}} (an)n∈N的狄利克雷级数母函数是:
    D G ( a n ; s ) = ∑ n = 1 ∞ a n n s DG(a_{n};s)=sum^{infty}_{n=1} rac{a_{n}}{n^{s}} DG(an;s)=n=1∑∞nsan
    当 a n a_{n} an是积性函数时狄利克雷级数比较有用,因为这时的母函数可以写成一系列贝尔级数的欧垃积:
    D G ( a n ; s ) = ∏ p f p ( p s ) DG(a_{n};s)=prod limits_{p}f_{p}(p^{-s}) DG(an;s)=p∏fp(ps)
    如果 a n a_{n} an是狄利克雷特征,那么它对应的狄利克雷级数母函数被称为狄利克雷L函数。

  • 应用

  1. 有1克、2克、3克、4克的砝码各一枚,能称出哪几种重量?每种重量各有几种可能方案?
    我们用母函数来解决这个问题:
    1). 1个1克砝码可以看成 1 + x 1 1+x^{1} 1+x1或 x 0 + x 1 x{0}+x{1} x0+x1,1表示不取,x^1表示取一个,以下同理;
    2). 1个2克砝码可以看成 1 + x 2 1+x^{2} 1+x2;
    2). 1个3克砝码可以看成 1 + x 3 1+x^{3} 1+x3;
    2). 1个4克砝码可以看成 1 + x 4 1+x^{4} 1+x4。
    那么生成函数就是:
    G ( x ) = ( 1 + x 1 ) ( 1 + x 2 ) ( 1 + x 3 ) ( 1 + x 4 ) = 1 + x + x 2 + 2 x 3 + 2 x 4 + 2 x 5 + 2 x 6 + 2 x 7 + x 8 + x 9 + x 10 G(x)=(1+x{1})(1+x{2})(1+x{3})(1+x{4}) \ =1+x+x{2}+2x{3}+2x{4}+2x{5}+2x{6}+2x{7}+x{8}+x{9}+x^{10} G(x)=(1+x1)(1+x2)(1+x3)(1+x4)=1+x+x2+2x3+2x4+2x5+2x6+2x7+x8+x9+x10
    这个函数中可以看出重量为3克的方案有两种,重量为7克的方案有两种,重量为10克的有一种。
    不难发现指数表示重量,系数表示方案。
  2. 求用1分、2分、3分的邮票贴出不同数值的方案数:
    把这种情况和第一种比较有何区别?第一种每种是一个,而这里每种是无限的。
    那么生成函数就是:
    G ( x ) = ( 1 + x + x 2 + x 3 + . . . ) ( 1 + x 2 + x 4 + x 6 + . . . ) ( 1 + x 3 + x 6 + x 9 + . . . ) G(x)=(1+x+x{2}+x{3}+…)(1+x{2}+x{4}+x{6}+…)(1+x{3}+x{6}+x{9}+…) G(x)=(1+x+x2+x3+…)(1+x2+x4+x6+…)(1+x3+x6+x9+…)
    以展开后的 x 4 x^{4} x4为例,其系数为4,即4拆分成1,2,3之和的拆分方案数为4:
    4 = 1 + 1 + 1 + 1 = 1 + 1 + 2 = 1 + 3 = 2 + 2 4=1+1+1+1=1+1+2=1+3=2+2 4=1+1+1+1=1+1+2=1+3=2+2
  3. 设有 n n n个标志为1,2,…,n的网袋,第i个 ( i = 1 , 2 , . . . , n ) (i=1,2,…,n) (i=1,2,…,n)网袋里放有 n i n_{i} ni个球。不同网袋里的球是不同的,而同一网袋里的球则是没有差别的,认为是相同的。询问从中取 r r r个球的方案数。
    设生成函数:
    G ( x ) = ( 1 + x 1 + x 2 + . . . + + x n i ) ( 1 + x 1 + x 2 + . . . + + x n 2 ) . . . G(x)=(1+x{1}+x{2}+…++x{n_{i}})(1+x{1}+x{2}+…++x{n_{2}})… G(x)=(1+x1+x2+…++xni)(1+x1+x2+…++xn2)…
    最后指数为 r r r的那一项的系数就是方案数。
    总结一下,生成函数大多用来解决有限或无限物体的组合方案。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值