插值法求解非线性方程

1. 前言

今天在codeing的时候遇到了一个这样的问题,面对以下非线性方程组

若我们给出它的y值,我们应该如何去确定它对应的x呢?

2.解决

直接使用插值法来拟合目标函数,这里我直接使用线性插值来拟合目标函数。线性插值简单点来说就是在一定区间内尽可能多的点,并将这些点之间使用直线连接来拟合目标函数。

现在使用python代码来实现,先导入依赖并定义目标函数

python 复制代码
import numpy as np
from scipy.interpolate import interp1d

def equation(x):
    return x + np.cos(x) + np.sin(x)

然后在该函数上取1000个点来拟合

ini 复制代码
# 生成已知点的 x 和 y 值
x_known = np.linspace(20, 500, 1000)  # 生成 1000 个 x 值
y_known = np.array([equation(x) for x in x_known])  # 计算对应的 y 值

# 创建插值函数
f_interpolated = interp1d(y_known, x_known)

最后,取值并验证误差

ini 复制代码
x0=100

# 给定的 y 值
y0 = equation(x0)

# 使用插值函数求解对应的 x 值
x_value = f_interpolated(y0)

print(f"当 y = {y0} 时,对应的 x 值约为: {x_value},误差为:{x_value-x0}")

执行代码,得出的结果

可以看到如果在所取点的区间[20,500]内取值,误差都是比较小的

相关推荐
闻缺陷则喜何志丹1 天前
P8699 [蓝桥杯 2019 国 B] 排列数|普及+
c++·数学·蓝桥杯·数论·洛谷·数列
sushang~2 天前
初一苏教版数学知识点汇总详细版(自用)
数学
辰尘_星启4 天前
[线性代数]矩阵/向量求导为什么要区别分子布局和分母布局
神经网络·线性代数·数学·矩阵·控制·导数
sushang~4 天前
小学(4-6年级)苏教版数学知识点汇总详细版(自用)
数学
闻缺陷则喜何志丹5 天前
【栈 递归】P8650 [蓝桥杯 2017 省 A] 正则问题|普及+
c++·数学·蓝桥杯·递归·
你好!蒋韦杰-(烟雨平生)6 天前
OpenGL
c++·数学·游戏·3d
闻缺陷则喜何志丹11 天前
【数论】P12191 [蓝桥杯 2025 省研究生组] 01 串|普及+
c++·数学·蓝桥杯·数论·洛谷
Wishell201511 天前
日拱一卒之学习记录2
数学
闻缺陷则喜何志丹21 天前
【.NetAPI]统计标注的值、上公差、下公差
数学·.net·cad·netapi
燃于AC之乐22 天前
我的算法修炼之路--6 ——模幂、构造、背包、贪心、剪枝、堆维护六题精析
c++·数学·算法·贪心算法·dfs·剪枝·01背包