首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >内插x- Python的两个值的峰值

内插x- Python的两个值的峰值
EN

Stack Overflow用户
提问于 2014-05-26 16:25:35
回答 2查看 1.5K关注 0票数 5

我想找到x的两个值,它在共振曲线的x-y图上与y的某个值相交。但是,由于我没有几个数据点,所以需要插值才能找到x的这些值。

我正在看的曲线如下所示:

如何找到x的两个等于y值的值(以红色显示)?

我通过将数据分成两个数组来尝试np.interpolate:首先使用gradient(y)>0,另一个使用gradient(y)<0,但是这产生了不正确的值。然而,这种方法远非优雅,我寻求的是一个简单的解决方案。提前为任何帮助干杯。

补充信息:迄今使用的代码:

代码语言:javascript
复制
from numpy import *
import pylab as pl
import numpy as np
import scipy as scipy
from scipy import optimize

#Get data
fn = '4K_peak_hiresGhz.txt'
F_values, S_values, P_values = loadtxt(fn, unpack=True, usecols=[1, 2, 3])

#Select Frequency range of peak
lower = 4.995
upper = 5.002
F_values_2 = F_values[(F_values>lower) & (F_values<upper)]
S_values_2 = S_values[(F_values>lower) & (F_values<upper)]
P_values_2 = P_values[(F_values>lower) & (F_values<upper)]

#Calculate Q-value of selected peak
S_Peak = max(S_values_2)
print('S21 peak (dB):')
print(S_Peak)
print

F_Peak = F_values_2[S_values_2.argmax()]
print('Freq at S21 peak (GHz)')
print(F_Peak)
print

width_S = S_Peak - 3
print('S21 peak - 3dB (dB)')
print(width_S)
print

f, axarr = pl.subplots(2, sharex=False)
axarr[0].set_xlabel('Frequency (GHz)')
axarr[0].plot(F_values_2,S_values_2)
axarr[0].plot(F_values_2,S_values_2,'.')
axarr[0].set_ylabel('S21 (dB)')
axarr[0].axhline(y=width_S, linewidth='0.7', ls='dashed',color='red')
axarr[0].axhline(y=S_Peak, linewidth='1', ls='dashed', color='black')
axarr[0].axvline(x=F_Peak, linewidth='1', ls='dashed', color='black')
axarr[1].scatter(F_values_2, P_values_2)
axarr[1].set_ylabel('Phase (deg)')
axarr[1].set_xlabel('Frequency (GHz)')
pl.show()

此外,在这个程序中分析的数据也可以在这个data:http://dpaste.com/13AMJ92/中找到。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-05-26 18:46:34

在本例中,您可以将np.interp()用作:

代码语言:javascript
复制
np.interp(width_S, S_values_2, F_values_2)

在您的绘图中,ticklabelsthickvalues不同,您可以比较一下这个事实:

代码语言:javascript
复制
print(axarr[0].get_xticks())
print([s.get_text() for s in axarr[0].get_xticklabels()])

使用此公式的内插值是正确的,您必须设置正确的勾选值才能看到:

代码语言:javascript
复制
axarr[0].set_xticklabels(map(str, axarr[0].get_xticks()))
票数 4
EN

Stack Overflow用户

发布于 2014-05-27 02:41:07

准备曲线数据:

代码语言:javascript
复制
from numpy import *
import pylab as pl
import numpy as np
import scipy as scipy
from scipy import optimize

#Get data
fn = '13AMJ92.txt'
F_values, S_values, P_values = loadtxt(fn, unpack=True, usecols=[1, 2, 3])

#Select Frequency range of peak
lower = 4.995
upper = 5.002
F_values_2 = F_values[(F_values>lower) & (F_values<upper)]
S_values_2 = S_values[(F_values>lower) & (F_values<upper)]

S_Peak = max(S_values_2)
F_Peak = F_values_2[S_values_2.argmax()]
width_S = S_Peak - 3

在峰值处拆分,并使用interp()

代码语言:javascript
复制
idx = S_values_2.argmax()
x1 = np.interp(width_S, S_values_2[:idx+1], F_values_2[:idx+1])
x2 = np.interp(width_S, S_values_2[-1:idx-1:-1], F_values_2[-1:idx-1:-1])
print x1, x2

产出:

代码语言:javascript
复制
4.99902583799 4.99954573393

您还可以使用Shapely:

代码语言:javascript
复制
from shapely import geometry
curve = geometry.asLineString(np.c_[F_values_2, S_values_2])
hline = geometry.LineString([(F_values_2[0], width_S), (F_values_2[-1], width_S)])
print np.asarray(curve.intersection(hline))

产出:

代码语言:javascript
复制
[[  4.99902584 -21.958     ]
 [  4.99954573 -21.958     ]]

如果可以使用三次样条,那么可以使用InterpolatedUnivariateSpline

代码语言:javascript
复制
from scipy import interpolate
us = interpolate.InterpolatedUnivariateSpline(F_values_2, S_values_2 - width_S)
x1, x2 = us.roots()
print x1, x2
pl.plot(F_values_2, S_values_2 - width_S)
x = np.linspace(F_values_2[0], F_values_2[-1], 100)
pl.plot(x, us(x))
pl.axhline(0)
pl.plot([x1, x2], [0, 0], "o")

产出:

代码语言:javascript
复制
4.99891956723 4.99960633369

情节:

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23874295

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档