当前位置: 首页 > news >正文

python微分方程求解,分别用显式欧拉方法、梯形法、改进欧拉方法、二阶龙格库塔方法、四阶龙格库塔方法求解微分方程

        微分方程在自然科学、工程技术、社会科学等多个领域都有着广泛而重要的应用。而求解微分方程是数学与应用数据领域一大难题,对于一些复杂的微分方程无法通过计算推导计算其精确的方程表达式与 结果,因此,我们通过数学理论。迭代,微分约等于思想寻求其精确解,随着计算机的快速发展,利用计算机程序求解微分方程非常重要,下面我们基于python代码分别利用显式欧拉方法、梯形法、改进欧拉方法、二阶龙格库塔方法、四阶龙格库塔方法求解微分方程。

1.问题描述

 已知微分方程如下

\begin{cases} y'=-2y-4x, & \ 0 \leq x \leq 1 \\ y(0)=2 \end{cases}

其方程精确解如下:

$ y(x)=e^{-2x}-2x+1 $

利用python编程技术,取步长h=0.1分别1.用显示欧拉方法,2.梯形法,3.改进欧拉方法,4.二阶龙格库塔方法,5.四阶龙格库塔方法计算数值解,并于精确解比较。

2.显式欧拉方法

2.1显式欧拉方法原理

        对于一阶常微分方程初值问题\frac{dy}{dt}=f(t,y)y(t_0)=y_0其基本思想是在每个小区间上,用差商来近似代替导数。具体来说,在t_n时刻,已知y(t_n)=y_n,通过向前差分来近似t_{n + 1}=t_n + h时刻的y值,其中h为时间步长。根据导数的定义\frac{dy}{dt}\approx\frac{y_{n + 1}-y_n}{h},将\frac{dy}{dt}=f(t,y)代入可得y_{n + 1}=y_n + hf(t_n,y_n)这就是显式欧拉方法的迭代公式,它通过已知的t_ny_n,以及函数f(t,y)来直接计算出y_{n + 1}的值,从而逐步推进求解常微分方程在不同时刻的数值解。

2.2 python代码实现

import numpy as np
import matplotlib.pyplot as plt# 定义微分方程
def f(x, y):return -2 * y - 4 * x# 定义精确解
def exact_solution(x):return np.exp(-2 * x) - 2 * x + 1# 显式欧拉方法
def euler_method(x0, y0, h, n):x = np.zeros(n + 1)y = np.zeros(n + 1)x[0] = x0y[0] = y0for i in range(n):y[i + 1] = y[i] + h * f(x[i], y[i])x[i + 1] = x[i] + hreturn x, y
# 参数设置
x0 = 0
y0 = 2
h = 0.1
n = int(1 / h)# 计算数值解
x_euler, y_euler = euler_method(x0, y0, h, n)
# 计算精确解
x_exact = np.linspace(x0, x0 + 1, n + 1)
y_exact = exact_solution(x_exact)# 打印结果并绘图比较
print("显式欧拉方法结果:", y_euler)
plt.plot(x_exact, y_exact, label='Exact Solution')
plt.plot(x_euler, y_euler, 'o-', label='Euler Method')
plt.xlabel('x')
plt.ylabel('y')
plt.title('Numerical Solutions Comparison')
plt.legend()
plt.show()

运行结果

3.梯形法

3.1梯形法原理

考虑一阶常微分方程的初值问题:\frac{dy}{dt}=f(t,y)y(t_0)=y_0 其中f(t,y) 是已知的函数,t_0和 y_0 分别是初始时刻和初始条件。在数值求解过程中,我们将时间区间进行离散化,设时间步长为 h,t_{n + 1}=t_n + h 。

显式欧拉方法是基于向前差分近似导数\frac{dy}{dt}\approx\frac{y_{n + 1}-y_n}{h}得到y_{n + 1}=y_n+hf(t_n,y_n),它仅使用了当前时刻 t_n的斜率 f(t_n,y_n)

而梯形法结合了当前时刻 t_n 和下一时刻t_{n + 1} 的斜率信息。根据积分中值定理,y(t_{n + 1})-y(t_n)=\int_{t_n}^{t_{n + 1}}f(t,y(t))dt

梯形法使用梯形公式来近似这个积分,即\int_{t_n}^{t_{n + 1}}f(t,y(t))dt\approx\frac{h}{2}[f(t_n,y(t_n)) + f(t_{n + 1},y(t_{n + 1}))]

由此得到梯形法的迭代公式:y_{n + 1}=y_n+\frac{h}{2}[f(t_n,y_n)+f(t_{n + 1},y_{n + 1})]

        与显式欧拉方法不同,梯形法的迭代公式是隐式的,因为y_{n + 1} 同时出现在等式的两边。这意味着在每一步求解 y_{n + 1}时,通常需要求解一个非线性方程。

3.2 python代码实现

import numpy as np
import matplotlib.pyplot as plt# 定义微分方程
def f(x, y):return -2 * y - 4 * x# 定义精确解
def exact_solution(x):return np.exp(-2 * x) - 2 * x + 1# 梯形法
def trapezoid_method(f, x0, y0, h, n):x_values = [x0]y_values = [y0]x = x0y = y0for _ in range(n):def g(y_next):return y_next - y - 0.5 * h * (f(x, y) + f(x + h, y_next))from scipy.optimize import rootsol = root(g, y)y = sol.x[0]x = x + hx_values.append(x)y_values.append(y)return x_values, y_values
# 参数设置
x0 = 0
y0 = 2
h = 0.1
n = int(1 / h)# 计算数值解
x_trapezoid, y_trapezoid = trapezoid_method(f, x0, y0, h, n)
# 计算精确解
x_exact = np.linspace(x0, x0 + 1, n + 1)
y_exact = exact_solution(x_exact)# 打印结果并绘图比较
print("梯形方法结果:", y_trapezoid)
plt.plot(x_exact, y_exact, label='Exact Solution')
plt.plot(x_trapezoid, y_trapezoid, 'o-', label='Trapezoid Method')
plt.xlabel('x')
plt.ylabel('y')
plt.title('Numerical Solutions Comparison')
plt.legend()
plt.show()

运行结果

 4.改进欧拉方法

4.1改进欧拉方法原理

改进欧拉方法的核心思想是综合考虑当前点(t_n,y_n)和预测的下一个点\(t_{n + 1},\overline{y}_{n + 1})处的斜率信息,通过取二者的平均值作为这一步的平均斜率,以此来得到更准确的y_{n + 1}的估计值。

具体原理和步骤

改进欧拉方法采用了预测 - 校正的策略,具体步骤如下:

  1. 预测阶段 利用显式欧拉方法对t_{n + 1}时刻的y值进行初步预测。设时间步长为h,t_{n + 1}=t_n + h,预测公式为:\overline{y}_{n + 1}=y_n+hf(t_n,y_n)这里\overline{y}_{n + 1}是对y(t_{n + 1})的一个初步估计,它基于当前点(t_n,y_n)处的斜率f(t_n,y_n)得到。
  2. 校正阶段 计算t_n时刻的斜率f(t_n,y_n))和预测的t_{n + 1}时刻的斜率f(t_{n + 1},\overline{y}_{n + 1}),然后取这两个斜率的平均值作为这一步的平均斜率,再用这个平均斜率来校正y_{n + 1}的值。校正公式为: y_{n + 1}=y_n+\frac{h}{2}[f(t_n,y_n)+f(t_{n + 1},\overline{y}_{n + 1})]从几何角度看,改进欧拉方法不再仅仅依赖于当前点的斜率,而是综合考虑了当前点和预测点的斜率,用这两个斜率的平均值来确定在区间[t_n,t_{n + 1}]上的近似直线的斜率,从而使近似曲线更接近真实的解曲线。

4.2 python代码实现

import numpy as np
import matplotlib.pyplot as plt# 定义微分方程
def f(x, y):return -2 * y - 4 * x# 定义精确解
def exact_solution(x):return np.exp(-2 * x) - 2 * x + 1# 改进的欧拉方法
def improved_euler_method(x0, y0, h, n):x = np.zeros(n + 1)y = np.zeros(n + 1)x[0] = x0y[0] = y0for i in range(n):k1 = f(x[i], y[i])k2 = f(x[i] + h, y[i] + h * k1)y[i + 1] = y[i] + h * (k1 + k2) / 2x[i + 1] = x[i] + hreturn x, y
# 参数设置
x0 = 0
y0 = 2
h = 0.1
n = int(1 / h)# 计算数值解
x_euler, y_euler =improved_euler_method(x0, y0, h, n)
# 计算精确解
x_exact = np.linspace(x0, x0 + 1, n + 1)
y_exact = exact_solution(x_exact)# 打印结果并绘图比较
print("改进的欧拉方法:", y_euler)
plt.plot(x_exact, y_exact, label='Exact Solution')
plt.plot(x_euler, y_euler, 'o-', label='Improved Euler Method')
plt.xlabel('x')
plt.ylabel('y')
plt.title('Numerical Solutions Comparison')
plt.legend()
plt.show()

运行结果

5.二阶龙格库塔方法

5.1二阶龙格库塔方法原理

二阶龙格 - 库塔方法的基本思想是在每个时间步长内,通过计算两个不同点的斜率估计值,然后对这些斜率进行加权平均,以此来得到更准确的\(y_{n + 1}\)的估计值。

二阶龙格 - 库塔方法的一般形式可以表示为:

k_1=hf(t_n,y_n)

k_2=hf(t_n+\alpha h,y_n+\beta k_1)

y_{n + 1}=y_n+(c_1k_1 + c_2k_2)

其中\alpha\betac_1c_2是待确定的参数,需要满足一定的条件以保证方法具有二阶精度。

5.2 python代码实现

import numpy as np
import matplotlib.pyplot as plt# 定义微分方程
def f(x, y):return -2 * y - 4 * x# 定义精确解
def exact_solution(x):return np.exp(-2 * x) - 2 * x + 1# 二阶龙格-库塔方法
def second_order_rk_method(x0, y0, h, n):x = np.zeros(n + 1)y = np.zeros(n + 1)x[0] = x0y[0] = y0for i in range(n):k1 = h * f(x[i], y[i])k2 = h * f(x[i] + h / 2, y[i] + k1 / 2)y[i + 1] = y[i] + k2x[i + 1] = x[i] + hreturn x, y
# 计算精确解
x_exact = np.linspace(x0, x0 + 1, n + 1)
y_exact = exact_solution(x_exact)
x_second_order_rk, y_second_order_rk = second_order_rk_method(x0, y0, h, n)
# 参数设置
x0 = 0
y0 = 2
h = 0.1
n = int(1 / h)
plt.plot(x_exact, y_exact, label='Exact Solution')
plt.plot(x_second_order_rk, y_second_order_rk, '^-', label='Second Order RK Method')
plt.xlabel('x')
plt.ylabel('y')
plt.title('Numerical Solutions Comparison')
plt.legend()
plt.show()

运行结果

6.四阶龙格库塔方法

6.1四阶龙格库塔方法原理

前面提到的显式欧拉方法仅使用当前点的斜率来估计下一个点的值,精度较低;二阶龙格 - 库塔方法通过计算两个不同点的斜率估计值并加权平均来提高精度。四阶龙格 - 库塔方法进一步拓展了这一思想,在每个时间步长内计算四个不同点的斜率估计值,然后对这些斜率进行加权平均,从而得到更准确的y_{n + 1}的估计值。

四阶龙格 - 库塔方法公式 

给定时间步长h,从t_nt_{n + 1}=t_n + h,四阶龙格 - 库塔方法的更新公式如下:


 

  1. 计算k_1k_1 = hf(t_n,y_n)
    • 这里k_1是在当前时间点t_n)和当前函数值y_n处的斜率乘以步长h,它反映了从当前点出发的初始斜率信息。
  2. 计算k_2k_2 = hf(t_n+\frac{h}{2},y_n+\frac{k_1}{2})
    • k_2是在时间点t_n+\frac{h}{2}和预测的函数值y_n+\frac{k_1}{2}处的斜率乘以步长h。通过在时间区间的中点进行斜率估计,考虑了函数在该区间内的变化趋势。
  3. 计算k_3k_3 = hf(t_n+\frac{h}{2},y_n+\frac{k_2}{2})
    • k_3同样是在时间点t_n+\frac{h}{2}处计算斜率,但使用了基于k_2更新后的预测函数值y_n+\frac{k_2}{2},进一步细化了对区间内斜率的估计。
  4. 计算k_4k_4 = hf(t_n + h,y_n + k_3)
    • k_4是在时间点t_{n + 1}=t_n + h和基于\(k_3\)更新后的预测函数值y_n + k_3处的斜率乘以步长h,反映了在该时间步结束时的斜率信息。
  5. 更新y_{n + 1}y_{n+1}=y_n+\frac{1}{6}(k_1 + 2k_2+2k_3 + k_4)
    • 最终的y_{n + 1}是通过对k_1k_2k_3k_4进行加权平均得到的,权重分别为\frac{1}{6}\frac{2}{6}\frac{2}{6}和\\frac{1}{6}。这种加权方式使得方法具有四阶精度。

6.2 python代码实现

import numpy as np
import matplotlib.pyplot as plt# 定义微分方程
def f(x, y):return -2 * y - 4 * x# 定义精确解
def exact_solution(x):return np.exp(-2 * x) - 2 * x + 1# 四阶龙格-库塔方法
def fourth_order_rk_method(x0, y0, h, n):x = np.zeros(n + 1)y = np.zeros(n + 1)x[0] = x0y[0] = y0for i in range(n):k1 = h * f(x[i], y[i])k2 = h * f(x[i] + h / 2, y[i] + k1 / 2)k3 = h * f(x[i] + h / 2, y[i] + k2 / 2)k4 = h * f(x[i] + h, y[i] + k3)y[i + 1] = y[i] + (k1 + 2 * k2 + 2 * k3 + k4) / 6x[i + 1] = x[i] + hreturn x, y# 计算精确解
x_exact = np.linspace(x0, x0 + 1, n + 1)
y_exact = exact_solution(x_exact)
x_fourth_order_rk, y_fourth_order_rk = fourth_order_rk_method(x0, y0, h, n)
# 参数设置
x0 = 0
y0 = 2
h = 0.1
n = int(1 / h)
plt.plot(x_exact, y_exact, label='Exact Solution')
plt.plot(x_fourth_order_rk, y_fourth_order_rk,'s-', label='Fourth Order RK Method')
plt.xlabel('x')
plt.ylabel('y')
plt.title('Numerical Solutions Comparison')
plt.legend()
plt.show()

运行结果

7.总结

为了直观的比较以上5种方法计算的准确性,将5种计算结果统一绘图比较分析。

import numpy as np
import matplotlib.pyplot as plt# 定义微分方程
def f(x, y):return -2 * y - 4 * x# 定义精确解
def exact_solution(x):return np.exp(-2 * x) - 2 * x + 1# 显式欧拉方法
def euler_method(x0, y0, h, n):x = np.zeros(n + 1)y = np.zeros(n + 1)x[0] = x0y[0] = y0for i in range(n):y[i + 1] = y[i] + h * f(x[i], y[i])x[i + 1] = x[i] + hreturn x, y
# 梯形法
def trapezoid_method(f, x0, y0, h, n):x_values = [x0]y_values = [y0]x = x0y = y0for _ in range(n):def g(y_next):return y_next - y - 0.5 * h * (f(x, y) + f(x + h, y_next))from scipy.optimize import rootsol = root(g, y)y = sol.x[0]x = x + hx_values.append(x)y_values.append(y)return x_values, y_values# 改进的欧拉方法
def improved_euler_method(x0, y0, h, n):x = np.zeros(n + 1)y = np.zeros(n + 1)x[0] = x0y[0] = y0for i in range(n):k1 = f(x[i], y[i])k2 = f(x[i] + h, y[i] + h * k1)y[i + 1] = y[i] + h * (k1 + k2) / 2x[i + 1] = x[i] + hreturn x, y# 二阶龙格-库塔方法
def second_order_rk_method(x0, y0, h, n):x = np.zeros(n + 1)y = np.zeros(n + 1)x[0] = x0y[0] = y0for i in range(n):k1 = h * f(x[i], y[i])k2 = h * f(x[i] + h / 2, y[i] + k1 / 2)y[i + 1] = y[i] + k2x[i + 1] = x[i] + hreturn x, y# 四阶龙格-库塔方法
def fourth_order_rk_method(x0, y0, h, n):x = np.zeros(n + 1)y = np.zeros(n + 1)x[0] = x0y[0] = y0for i in range(n):k1 = h * f(x[i], y[i])k2 = h * f(x[i] + h / 2, y[i] + k1 / 2)k3 = h * f(x[i] + h / 2, y[i] + k2 / 2)k4 = h * f(x[i] + h, y[i] + k3)y[i + 1] = y[i] + (k1 + 2 * k2 + 2 * k3 + k4) / 6x[i + 1] = x[i] + hreturn x, y# 参数设置
x0 = 0
y0 = 2
h = 0.1
n = int(1 / h)# 计算数值解
x_euler, y_euler = euler_method(x0, y0, h, n)
x_improved_euler, y_improved_euler = improved_euler_method(x0, y0, h, n)
x_second_order_rk, y_second_order_rk = second_order_rk_method(x0, y0, h, n)
x_fourth_order_rk, y_fourth_order_rk = fourth_order_rk_method(x0, y0, h,n)
x_trapezoid, y_trapezoid = trapezoid_method(f, x0, y0, h, n)# 计算精确解
x_exact = np.linspace(x0, x0 + 1, n + 1)
y_exact = exact_solution(x_exact)# 打印结果并绘图比较
print("显式欧拉方法结果:", y_euler)
print("改进的欧拉方法结果:", y_improved_euler)
print("二阶龙格-库塔方法结果:", y_second_order_rk)
print("四阶龙格-库塔方法结果:", y_fourth_order_rk)
print("精确解结果:", y_exact)plt.plot(x_exact, y_exact, label='Exact Solution')
plt.plot(x_euler, y_euler, 'o-', label='Euler Method')
plt.plot(x_improved_euler, y_improved_euler, 'x-', label='Improved Euler Method')
plt.plot(x_second_order_rk, y_second_order_rk, '^-', label='Second Order RK Method')
plt.plot(x_fourth_order_rk, y_fourth_order_rk,'s-', label='Fourth Order RK Method')
plt.plot(x_trapezoid, y_trapezoid, '*-', label='Trapezoid Method')
plt.xlabel('x')
plt.ylabel('y')
plt.title('Numerical Solutions Comparison')
plt.legend()
plt.show()

运行结果

对比五种计算方法结果相差较小, 二阶龙格库塔方法计算结果最精确,

相关文章:

python微分方程求解,分别用显式欧拉方法、梯形法、改进欧拉方法、二阶龙格库塔方法、四阶龙格库塔方法求解微分方程

微分方程在自然科学、工程技术、社会科学等多个领域都有着广泛而重要的应用。而求解微分方程是数学与应用数据领域一大难题,对于一些复杂的微分方程无法通过计算推导计算其精确的方程表达式与 结果,因此,我们通过数学理论。迭代,微…...

【ubuntu】——wsl中使用windows中的adb

一、引言 在 Windows Subsystem for Linux(WSL)环境下工作时,有时需要使用 Android Debug Bridge(ADB)工具与 Android 设备进行交互。通过特定设置,能够在 WSL 中便捷地调用 Windows 系统中已安装的 ADB&a…...

Git 常用命令完全指南:从入门到高效协作

文章需要结构清晰,涵盖从入门到进阶的常用命令,结合实例和注意事项,帮助用户快速掌握Git的核心功能,并应用到实际项目中 一、仓库初始化与基础操作 1. 创建与克隆仓库 # 初始化本地仓库 git init# 克隆远程仓库(SSH方…...

学习单片机需要多长时间才能进行简单的项目开发?

之前有老铁问我,学单片机到底要多久,才能进行简单的项目开发?是三个月速成,还是三年磨一剑? 今天咱们就来聊聊这个话题,我不是什么高高在上的专家,就是个踩过无数坑、烧过几块板子的“技术老友”…...

面试系列|蚂蚁金服技术面【3】

今天继续分享一下蚂蚁金服的 Java 后端开发岗位真实社招面经,复盘面试过程中踩过的坑,整理面试过程中提到的知识点,希望能给正在准备面试的你一些参考和启发,希望对你有帮助,愿你能够获得心仪的 offer ! 第二轮面试之…...

Spring Boot项目中成功集成了JWT

JWT 原理解释 什么是 JWT? JSON Web Token(JWT)是一种开放标准(RFC 7519),用于在网络应用环境间安全地将信息作为JSON对象传输。JWT通常用于身份验证和信息交换。 JWT 的结构 JWT由三部分组成&#xff…...

《Java SQL 操作指南:深入理解 Statement 用法与优化》

在 Java 数据库编程中,Statement 是用于执行 SQL 语句的接口,允许程序与数据库进行交互。本文将详细介绍 Statement 的基本概念、常见用法以及 PreparedStatement 和 CallableStatement 等相关接口。 1. Statement 基本介绍 Statement 接口继承了 AutoC…...

element ui设置结束时间为23:59:59

开始时间为00:00:00结束时间为23:59:59 在请求接口前&#xff0c;用substring取结束时间的年月日&#xff0c;并替换时间值即可 <el-formref"searchForm":model"searchForm":inline"true"size"mini"keyup.enter.native"getDa…...

Matlab 舰载机自动着舰控制系统研究

1、内容简介 Matlab 188-舰载机自动着舰控制系统研究 可以交流、咨询、答疑 2、内容说明 略 3、仿真分析 略 4、参考论文 略...

数据集格式转换——json2txt、xml2txt、txt2json【复制就能用】

秋招面试专栏推荐 :深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 💡💡💡本专栏所有程序均经过测试,可成功执行💡💡💡 专栏地址:YOLO11入门 + 改进涨点——点击即可跳转 欢迎订阅 目录 json2txt脚本 xml2txt txt2json...

MySQL 横向衍生表(Lateral Derived Tables)

前面我们介绍过MySQL中的衍生表&#xff08;From子句中的子查询&#xff09;和它的局限性&#xff0c;MySQL8.0.14引入了横向衍生表&#xff0c;可以在子查询中引用前面出现的表&#xff0c;即根据外部查询的每一行动态生成数据&#xff0c;这个特性在衍生表非常大而最终结果集…...

基于llama.cpp的QwQ32B模型推理

基于llama.cpp的QwQ32B模型推理 llama.cpp项目主页&#xff1a; https://github.com/ggml-org/llama.cpp# llama.cpp源码下载 cd /root/lanyun-tmpgit clone https://github.com/ggml-org/llama.cpp#llama.cpp编译 llama.cpp是个C语言项目&#xff0c;实际调用过程需要先构建项…...

【Jmeter】使用教程

下载及安装 参考链接: JMeter下载及安装&#xff08;附插件及中文包超详细&#xff09; 参考链接: 【Jmeter】win 10 / win 11&#xff1a;Jmeter 下载、安装、汉化、新机迁移、版本更新&#xff08;Jmeter 4 以上版本均适用&#xff09; 分辨率的调整 参考链接: Jmeter5.3字…...

黑马商城完成随笔

完结撒花 &#x1f389; &#x1f389; &#x1f389; 差不多用了两三个星期&#xff1f;终于是完成了。 黑马商城体量应该是全部黑马项目中体量最多&#xff0c;技术栈最复杂的了。 可是仍然存在之前黑马项目的问题&#xff1a;不细致&#xff0c;不完整 很多技术栈的使用仅…...

【Python 算法零基础 1.线性枚举】

我装作漠视一切&#xff0c;以为这样就可以不在乎 —— 25.3.17 一、线性枚举的基本概念 1.时间复杂度 线性枚举的时间复杂度为 O(nm)&#xff0c;其中 n是线性表的长度。m 是每次操作的量级&#xff0c;对于求最大值和求和来说&#xff0c;因为操作比较简单&#xff0c;所以 …...

涨薪技术|Kubernetes(k8s)之Pod端口设置及资源配额

01端口设置 使用以下命令可以可以查看到到ports的子选项 [rootk8s-master01 ~]# kubectl explain pod.spec.containers.portsKIND: PodVERSION: v1RESOURCE: ports <[]Object>FIELDS:name <string> # 端口名称&#xff0c;如果指定&#xff0c;必须保证name在pod…...

七大常用智能家居协议对比

如果您不知道在项目中使用哪种智能家居通信协议&#xff0c;那么进入智能家居行业可能会很困难。如果没有合适的协议将其集成到智能家居生态系统中&#xff0c;智能家居设备将无法正常工作。否则&#xff0c;您将面临硬件和软件无法满足最终用户期望的风险。协议选择不当可能会…...

K8S快速部署

前置虚拟机环境正式部署BUG解决 前置虚拟机环境 每个虚拟机配置一次就好 #关闭防火墙 systemctl stop firewalld systemctl disable firewalld #关闭 selinux sed -i s/enforcing/disabled/ /etc/selinux/config # 永久 setenforce 0 # 临时 #关闭 swap swapoff -a # 临时 vi…...

TCP 三次握手四次挥手过程详解

注&#xff1a;本文为 “TCP 的三次握手与四次挥手” 相关文章合辑。 英文引文&#xff0c;机翻未校。 中文引文&#xff0c;未整理去重。 英文引文第二篇&#xff0c;实为国内《稀土掘金技术社区》文章&#xff0c;没检索到原文&#xff0c;此处 “出口转内销” 。 如有内…...

如何利用 Zeabur 实现 OceanBase 的一键部署

引言 Zeabur 是一个功能强大且即开即用的自动化部署平台&#xff0c;它不仅能迅速部署多种应用&#xff0c;还支持一键安装 MySQL、PostgreSQL 等数据库服务。 Zeabur 拥有众多国内外用户&#xff0c;如 AFFiNE、Bytebase 等企业客户&#xff0c;以及大量全栈和独立开发者。将…...

基于Springboot+服务器磁盘的本地文件存储方案

[local-file-system]基于服务器磁盘的本地文件存储方案 仅提供后端方案 github 环境 JDK11linux/windows/mac 应用场景 适用于ToB业务&#xff0c;中小企业的单体服务&#xff0c;仅使用磁盘存储文件的解决方案 仅使用服务器磁盘存储 与业务实体相结合的文件存储方案&…...

基于FPGA的3U机箱模拟量高速采样板ADI板卡,应用于轨道交通/电力储能等

板卡简介&#xff1a; 本板为模拟量高速采样板&#xff08;ADI&#xff09;&#xff0c;主要用于电机转速和相电流检测&#xff0c;以实现电机闭环控制。 性能规格&#xff1a; 电源&#xff1a;DC5V&#xff0c;DC3.3V&#xff0c;DC15V&#xff0c;DC24V FPGA&#xff1a;…...

泰勒·斯威夫特(Taylor Swift)的音乐影响力与商业版图深度研究

泰勒斯威夫特的音乐影响力与商业版图深度研究 简介 泰勒斯威夫特&#xff08;Taylor Swift&#xff09;是当今流行音乐领域最具影响力的全球巨星之一。自少年时期出道以来&#xff0c;她在音乐风格、形象和商业战略上不断演变&#xff0c;从乡村音乐新人成长为引领流行文化的…...

神经网络微调技术解析

神经网络微调技术 微调&#xff08;Fine-tuning&#xff09;是迁移学习的核心技术&#xff0c;通过在预训练模型基础上调整参数&#xff0c;使其适应特定任务或领域。以下从传统方法、参数高效微调&#xff08;PEFT&#xff09;、新兴技术三个维度展开&#xff0c;覆盖主流技术…...

鸿蒙路由 HMRouter 配置及使用 三 全局拦截器使用

1、前期准备 简单封装一个用户首选项的工具类 import { preferences } from "kit.ArkData";// 用户首选项方法封装 export class Preferences {private myPreferences: preferences.Preferences | null null;// 初始化init(context: Context, options: preference…...

国科大——计网(0812)——考试真题

前沿&#xff1a; 此篇文章记录了国科大秋季学期计网&#xff08;0812&#xff09;课程的一些考试真题&#xff0c;某些题目的答案仅供参考&#xff0c;还请自行辨别。 备注&#xff1a; 计网的考试题一般都会多一道&#xff0c;每道题的分值相同&#xff0c;例如&#xff1a;…...

Feedback-Guided Autonomous Driving

Feedback-Guided Autonomous Driving idea 问题设定&#xff1a;基于 CARLA 的目标驱动导航任务&#xff0c;通过知识蒸馏&#xff0c;利用特权智能体的丰富监督信息训练学生传感器运动策略函数 基于 LLM 的端到端驱动模型&#xff1a;采用 LLaVA 架构并添加航点预测头&#…...

超参数优化算法:scikit-opt库、Scikit-Optimize库

1 scikit-opt库&#xff1a;https://www.cnblogs.com/luohenyueji/p/18333387 https://blog.csdn.net/weixin_45750972/article/details/124683402 a 差分进化算法 (Differential Evolution)&#xff1a;一种基于群体搜索的优化算法&#xff0c;通过模拟生物进化的过程来寻找最…...

我与DeepSeek读《大型网站技术架构》- 大型网站架构技术一览与Web开发技术发展历程

文章目录 大型网站架构技术一览1. 前端架构2. 应用层架构3. 服务层架构4. 存储层架构5. 后台架构6. 数据采集与监控7. 安全架构8. 数据中心机房架构 Web开发技术发展历程一、静态HTML阶段二、CGI脚本模式阶段三、服务器页面模式阶段 大型网站架构技术一览 1. 前端架构 浏览器…...

解决QT_Debug 调试信息不输出问题

方式1 &#xff1a;手动通过添加环境变量解决 ->使用命令&#xff1a; QT_LOGGING_TO_CONSOLE1 qtcreator启动 ->如若还未输出qDebug调试信息 则在程序中引<QLoggingCategory>包 #include <QLoggingCategory> ->在程序入口添加 QLoggingCategory::defa…...

NebulaGraph3.3.0部署与配置

系统参数 8g 2核参考文档: https://docs.nebula-graph.com.cn/3.8.0/4.deployment-and-installation/2.compile-and-install-nebula-graph/2.install-nebula-graph-by-rpm-or-deb/静态IP配置 # 修改网卡配置文件 vim /etc/sysconfig/network-scripts/ifcfg-ens33# 修改文件内容…...

oracle 基础知识之 多表查询

多表查询定义&#xff1a;当查询的数据并不是来源一个表时&#xff0c;需要使用多表连接操作完成查询。多表连接查询通过表之间的关联字段&#xff0c;一次查询出多个表的数据。多表查询包括了等值连接、左连接、右连接、完全连接。 1.等值连接 等值连接也称为简单连接&#xf…...

《论分布式系统架构设计及其应用》架构师论文

【摘要】 2022年3月&#xff0c;我参与了某金融科技公司“智能风控云平台”项目的研发工作&#xff0c;担任系统架构师职务&#xff0c;负责分布式系统架构设计与核心技术选型。该平台旨在为银行、保险等金融机构提供实时风险评估、反欺诈及数据服务&#xff0c;需支撑每秒十万…...

Matlab 汽车主动悬架LQR控制器设计与仿真

1、内容简介 Matlab 182-汽车主动悬架LQR控制器设计与仿真 可以交流、咨询、答疑 2、内容说明 略 1、研究背景 汽车悬架系统由弹性元件、导向元件和减振器组成,是车身与车轴之间连接的所有组合体零件的总称,也是车架(或承载式车身)与车桥(或车轮)之间一切力传递装置的总称,…...

JMeter 参数化工作原理说明

一、核心目标&#xff1a;让每条请求都能用不同数据 参数化的本质是让 JMeter 在发送请求时&#xff0c;自动替换变量为不同的值。例如&#xff1a; 模拟 100 个用户登录 → 每个用户使用不同的账号密码。模拟搜索不同关键词 → 每次请求自动更换关键词。 二、参数化如何工作…...

[免费]直接整篇翻译pdf工具-支持多种语言

<闲来没事写篇博客填补中文知识库漏洞> 如题&#xff0c;[免费][本地]工具基于开源仓库&#xff1a; 工具 是python&#xff01;太好了&#xff0c;所以各个平台都可以&#xff0c;我这里基于windows. 1. 先把github代码下载下来&#xff1a; git clone https://githu…...

Python 鼠标轨迹算法 - 防止游戏检测

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序&#xff0c;它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言&#xff0c;原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势&#xff1a; 模拟…...

Unity音乐内存优化

文章目录 音乐下载远程音乐 音乐 音乐文件如果只从工程目录里面读取&#xff0c;那有很多种方法可以优化&#xff0c;比如设置Load Type直接采用流式加载方式&#xff0c;内存直接降最小&#xff08;但是记住&#xff0c;每种优化都是有对应的代价的&#xff0c;优化是一种平衡…...

hubilder打包ios app, 并上传TestFlight

目录 一 前提条件 不是该项目成员解决 1. 直接找到该项目的管理人员去设置你的账号 2. 直接重新生成APPID(一般不建议的&#xff0c;可以查看) 3. 如果是离职人员&#xff0c;可以让他将项目权限转让出来 - 如何转让应用 - DCloud问答 未申请ios证书和描述文件 APP ID 的…...

3个 Vue $set 的应用场景

大家好&#xff0c;我是大澈&#xff01;一个喜欢结交朋友、喜欢编程技术和科技前沿的老程序员&#x1f468;&#x1f3fb;‍&#x1f4bb;&#xff0c;关注我&#xff0c;科技未来或许我能帮到你&#xff01; 在 Vue2 中&#xff0c;由于 Object.defineProperty 的限制&#…...

3ds Max 导入到 After Effects 还原摄像机要注意事项--deepseek

我&#xff1a;dp我这有两个脚本分别是syn软件相机导出到max的和syn软件相机导出到ae的&#xff0c;你能看出差别来吗&#xff1f;如果我想把max里的相机导入到ae里&#xff0c;保持原来的位置方向&#xff0c;该怎么做 dp&#xff1a;从这两个脚本可以看出&#xff0c;3ds Ma…...

从零开始 | C语言基础刷题DAY3

❤个人主页&#xff1a;折枝寄北的博客 目录 1.打印3的倍数的数2.从大到小输出3. 打印素数4.打印闰年5.最大公约数 1.打印3的倍数的数 题目&#xff1a; 写一个代码打印1-100之间所有3的倍数的数字 代码&#xff1a; int main(){int i 0;for (i 1; i < 100; i){if (i % …...

SQL注入第7关

存在注入&#xff0c;需要使用单引号闭合 拥有root权限&#xff0c;secure_file_priv值为空&#xff0c;确定路径 http://127.0.0.1/sqli-labs-master/Less-7/?id1)) union select 1,"<?phpinfo();?>",3 into outfile "D:\\landui\\xp\\phpstudy_pro…...

Git使用和原理(3)

1.远程操作 1.1分布式版本控制系统 我们⽬前所说的所有内容&#xff08;⼯作区&#xff0c;暂存区&#xff0c;版本库等等&#xff09;&#xff0c;都是在本地&#xff01;也就是在你的笔记本或者 计算机上。⽽我们的 Git 其实是分布式版本控制系统&#xff01;什么意思呢&a…...

从零搭建微服务项目Pro(第6-1章——Spring Security+JWT实现用户鉴权访问与token刷新)

前言&#xff1a; 在现代的微服务架构中&#xff0c;用户鉴权和访问控制是非常重要的一部分。Spring Security 是 Spring 生态中用于处理安全性的强大框架&#xff0c;而 JWT&#xff08;JSON Web Token&#xff09;则是一种轻量级的、自包含的令牌机制&#xff0c;广泛用于分…...

LeetCode 124.二叉树中的最大路径和

题目&#xff1a; 二叉树中的 路径 被定义为一条节点序列&#xff0c;序列中每对相邻节点之间都存在一条边。同一个节点在一条路径序列中 至多出现一次 。该路径 至少包含一个 节点&#xff0c;且不一定经过根节点。 路径和 是路径中各节点值的总和。 给你一个二叉树的根节点…...

结构型模式之适配器模式:让不兼容的接口兼容

在软件开发中&#xff0c;经常会遇到这样一种情况&#xff1a;系统的不同部分需要进行交互&#xff0c;但由于接口不兼容&#xff0c;导致无法直接使用。这时&#xff0c;适配器模式&#xff08;Adapter Pattern&#xff09;就能派上用场。适配器模式是设计模式中的结构型模式&…...

Python 中用T = TypeVar(“T“)这个语法定义一个“类型变量”,属于类型提示系统的一部分

T TypeVar("T") 这一语法规则定义了一个泛型类型变量 T&#xff0c;用于标记“某种类型”&#xff0c;让你可以写出既通用又类型安全的代码。 TypeVar(“T”) 会创建一个名为 T 的类型占位符&#xff0c;这个占位符可以在后续的函数、类或方法中用作泛型参数。泛型…...

uniapp移动端图片比较器组件,仿英伟达官网rtx光追图片比较器功能

组件下载地址&#xff1a;https://ext.dcloud.net.cn/plugin?id22609 已测试h5和微信小程序&#xff0c;理论支持全平台 亮点&#xff1a; 简单易用 使用js计算而不是resize属性&#xff0c;定制化程度更高 组件挂在后可播放指示线动画&#xff0c;提示用户可以拖拽比较图片…...

理解我们单片机拥有的资源

目录 为什么要查询单片机拥有的资源 所以&#xff0c;去哪些地方可以找数据手册 一个例子&#xff1a;STM32F103C8T6 前言 本文章隶属于项目&#xff1a; Charliechen114514/BetterATK: This is a repo that helps rewrite STM32 Common Repositorieshttps://github.com/C…...