gpt4 book ai didi

python - 高斯与 scipy 之和的曲线拟合

转载 作者:行者123 更新时间:2023-11-28 21:59:46 26 4
gpt4 key购买 nike

我从事生物信息学研究,我们在 mRNA 上绘制小 RNA。我们有每个 mRNA 上蛋白质的映射坐标,我们计算蛋白质结合 mRNA 的位置与小 RNA 结合的位点之间的相对距离。

我获得了以下数据集:

dist    eff
-69 3
-68 2
-67 1
-66 1
-60 1
-59 1
-58 1
-57 2
-56 1
-55 1
-54 1
-52 1
-50 2
-48 3
-47 1
-46 3
-45 1
-43 1
0 1
1 2
2 12
3 18
4 18
5 13
6 9
7 7
8 5
9 3
10 1
13 2
14 3
15 2
16 2
17 2
18 2
19 2
20 2
21 3
22 1
24 1
25 1
26 1
28 2
31 1
38 1
40 2

当我绘制数据时,我有 3 张图片:1 张在 3 -4 左右另一个大约 20,最后一个大约 -50。

我尝试了三次样条插值,但它对我的数据效果不是很好。

我的想法是用高斯总和进行曲线拟合。例如在我的例子中,在点 5,20 和 -50 估计 3 高斯曲线。

我该怎么做?

我查看了 scipy.optimize.curve_fit(),但我怎样才能以精确的间隔拟合曲线?如何添加曲线以形成一条曲线?

最佳答案

import numpy as np
import matplotlib.pyplot as plt
import scipy.stats
import scipy.optimize

data = np.array([-69,3, -68, 2, -67, 1, -66, 1, -60, 1, -59, 1,
-58, 1, -57, 2, -56, 1, -55, 1, -54, 1, -52, 1,
-50, 2, -48, 3, -47, 1, -46, 3, -45, 1, -43, 1,
0, 1, 1, 2, 2, 12, 3, 18, 4, 18, 5, 13, 6, 9,
7, 7, 8, 5, 9, 3, 10, 1, 13, 2, 14, 3, 15, 2,
16, 2, 17, 2, 18, 2, 19, 2, 20, 2, 21, 3, 22, 1,
24, 1, 25, 1, 26, 1, 28, 2, 31, 1, 38, 1, 40, 2])
x, y = data.reshape(-1, 2).T

def tri_norm(x, *args):
m1, m2, m3, s1, s2, s3, k1, k2, k3 = args
ret = k1*scipy.stats.norm.pdf(x, loc=m1 ,scale=s1)
ret += k2*scipy.stats.norm.pdf(x, loc=m2 ,scale=s2)
ret += k3*scipy.stats.norm.pdf(x, loc=m3 ,scale=s3)
return ret


params = [-50, 3, 20, 1, 1, 1, 1, 1, 1]

fitted_params,_ = scipy.optimize.curve_fit(tri_norm,x, y, p0=params)

plt.plot(x, y, 'o')
xx = np.linspace(np.min(x), np.max(x), 1000)
plt.plot(xx, tri_norm(xx, *fitted_params))
plt.show()

enter image description here

>>> fitted_params
array([ -60.46845528, 3.801281 , 13.66342073, 28.26485602,
1.63256981, 10.31905367, 110.51392765, 69.11867159,
63.2545624 ])

所以您可以看到您对三峰函数的想法与您的实际数据不太吻合。

关于python - 高斯与 scipy 之和的曲线拟合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16082171/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com