python分段函数实现_python – 在pandas / numpy中实现分段函数的正确方法

在Python中,作者遇到在Pandas或Numpy环境中实现分段函数的挑战。函数期望为线性在特定点x1下,线性在x2上,并通过三次样条插值在两者之间平滑过渡。遇到的问题包括布尔值系列导致的错误和`np.piecewise()`的数组索引错误。作者寻求解决方案以正确地构建这个分段函数。
摘要由CSDN通过智能技术生成

我需要创建一个函数来传递给curve_fit.在我的例子中,函数最好定义为分段函数.

我知道以下内容不起作用,但我正在显示它,因为它使函数的意图清晰:

def model_a(X, x1, x2, m1, b1, m2, b2):

'''f(x) has form m1*x + b below x1, m2*x + b2 above x2, and is

a cubic spline between those two points.'''

y1 = m1 * X + b1

y2 = m2 * X + b2

if X <= x1:

return y1 # function is linear below x1

if X >= x2:

return y2 # function is linear above x2

# use a cubic spline to interpolate between lower

# and upper line segment

a, b, c, d = fit_cubic(x1, y1, x2, y2, m1, m2)

return cubic(X, a, b, c, d)

当然,问题在于X是一个熊猫系列,并且形式(X <= x1)评估为一系列布尔值,因此失败的消息是“系列的真值是模糊的”. 似乎np.piecewise()就是针对这种情况设计的:“无论condlist [i]为True,funclist [i](x)都用作输出值.”所以我尝试了这个:

def model_b(X, x1, x2, m1, b1, m2, b2):

def lo(x):

return m1 * x + b1

def hi(x):

return m2 * x + b2

def mid(x):

y1 = m1 * x + b1

y2 = m2 * x + b2

a, b, c, d = fit_cubic(x1, y1, x2, y2, m1, m2)

return a * x * x * x + b * x * x + c * x + d

return np.piecewise(X, [X<=x1, X>=x2], [lo, hi, mid])

但是这次会议失败了:

return np.piecewise(X, [X<=x1, X>=x2], [lo, hi, mid])

消息“IndexError:数组索引太多”.我倾向于认为它反对condlist中有两个元素和funclist中有三个元素这一事实,但是文档明确指出funclist中的额外元素被视为默认元素.

任何指导?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值