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

Python 机器学习求解 PDE 学习项目——PINN 求解二维 Poisson 方程

本文使用 TensorFlow 1.15 环境搭建深度神经网络(PINN)求解二维 Poisson 方程:

模型问题

− Δ u = f in  Ω , u = g on  Γ : = ∂ Ω . \begin{align} -\Delta u &= f \quad & \text{in } \Omega,\\ u & =g \quad & \text{on } \Gamma:=\partial \Omega. \end{align} Δuu=f=gin Ω,on Γ:=Ω.
其中 Ω = [ X a , X b ] × [ Y a , Y b ] \Omega = [X_a,X_b]\times[Y_a,Y_b] Ω=[Xa,Xb]×[Ya,Yb] 是一个二维矩形区域, Δ u = u x x + u y y , g \Delta u = u_{xx}+u_{yy}, g Δu=uxx+uyy,g 是边界条件给定的函数,可以非零.

在这里插入图片描述

代码展现

二维PINN 与一维的整体框架是类似的,只是数据的维度升高了,完整代码及其注释如下:

# PINN 求解 2D Poisson 方程
import tensorflow as tf
print(tf.__version__)
import os
#tensorflow-intel automatically set the TF_ENABLE_ONEDNN_OPTS=1
#os.environ['TF_ENABLE_ONEDNN_OPTS'] = '0'
# Here, TF_ENABLE_ONEDNN_OPTS=0 should be above import tensorflow as tf
import tensorflow as tf
import numpy as np
import time
import matplotlib.pyplot as plt
import scipy.io
import math
# 定义数据集类,用于生成训练所需的数据
class Dataset:def __init__(self, x_range, y_range, N_res, N_bx, N_by, Nx, Ny, xa, xb, ya, yb):self.x_range = x_range  # x 轴范围self.y_range = y_range  # y 轴范围self.N_res = N_res  # 方程残差点数量self.N_bx = N_bx  # x 方向边界条件点数量self.N_by = N_by  # y 方向边界条件点数量self.Nx = Nx  # x 方向网格数量self.Ny = Ny  # y 方向网格数量self.xa = xa  # x 方向左边界self.xb = xb  # x 方向右边界self.ya = ya  # y 方向下边界self.yb = yb  # y 方向上边界# 定义边界条件函数# 可以求解非齐次 Dirichlet 边界条件def bc(self, X_b):U_bc = Exact(self.xa, self.xb, self.ya, self.yb)u_bc = U_bc.u_exact(X_b)return u_bc# 生成数据:残差点和边界条件点def build_data(self):x0, x1 = self.x_rangey0, y1 = self.y_rangeXmin = np.hstack((x0, y0))Xmax = np.hstack((x1, y1))## 如果使用均匀网格,代码如下:"""x_ = np.linspace(x0, x1, self.Nx).reshape((-1, 1))y_ = np.linspace(y0, y1, self.Ny).reshape((-1, 1))x, y = np.meshgrid(x_, y_)x = np.reshape(x, (-1, 1))y = np.reshape(y, (-1, 1))xy = np.hstack((x, y))X_res_input = xy"""## 为方程生成随机残差点x_res = x0 + (x1 - x0) * np.random.rand(self.N_res, 1)y_res = y0 + (y1 - y0) * np.random.rand(self.N_res, 1)X_res_input = np.hstack((x_res, y_res))# 生成 x = xa, xb 的边界条件点y_b = y0 + (y1 - y0) * np.random.rand(self.N_by, 1)x_b0 = x0 * np.ones_like(y_b)x_b1 = x1 * np.ones_like(y_b)X_b0_input = np.hstack((x_b0, y_b))X_b1_input = np.hstack((x_b1, y_b))# 生成 y = ya, yb 的边界条件点x_b = x0 + (x1 - x0) * np.random.rand(self.N_bx, 1)y_b0 = y0 * np.ones_like(x_b)y_b1 = y1 * np.ones_like(x_b)Y_b0_input = np.hstack((x_b, y_b0))Y_b1_input = np.hstack((x_b, y_b1))return X_res_input, X_b0_input, X_b1_input, Y_b0_input, Y_b1_input, Xmin, Xmax# 定义精确解类,用于计算精确解
class Exact:def __init__(self, xa, xb, ya, yb):self.xa = xa  # x 方向左边界self.xb = xb  # x 方向右边界self.ya = ya  # y 方向下边界self.yb = yb  # y 方向上边界# 精确解函数def u_exact(self, X):x = X[:, 0:1]y = X[:, 1:2]u = np.sin(2 * np.pi * x  ) * np.sin(2 * np.pi * y )return uclass Train:def __init__(self, train_dict):self.train_dict = train_dict  # 训练数据self.step = 0  # 训练步数# 打印训练损失def callback(self, loss_value):self.step += 1if self.step % 200 == 0:print(f'Loss: {loss_value:.4e}')# 使用 Adam 和 L-BFGS 优化器进行训练def nntrain(self, sess, u_pred, loss, train_adam, train_lbfgs):n = 0max_steps = 1000loss_threshold = 4.0e-4current_loss = 1.0while n < max_steps and current_loss > loss_threshold:n += 1u_, current_loss, _ = sess.run([u_pred, loss, train_adam], feed_dict=self.train_dict)# 每2^n步打印一次损失并绘制结果  if math.isclose(math.fmod(math.log2(n), 1), 0, abs_tol=1e-9): print(f'Steps: {n}, loss: {current_loss:.4e}')train_lbfgs.minimize(sess, feed_dict=self.train_dict, fetches=[loss], loss_callback=self.callback)class DNN:def __init__(self, layer_sizes, Xmin, Xmax):self.layer_sizes = layer_sizes  # 每层的节点数self.Xmin = Xmin  # 输入范围最小值self.Xmax = Xmax  # 输入范围最大值# 初始化神经网络的权重和偏置def hyper_initial(self):num_layers = len(self.layer_sizes)weights = []biases = []for l in range(1, num_layers):in_dim = self.layer_sizes[l-1]out_dim = self.layer_sizes[l]std = np.sqrt(2 / (in_dim + out_dim))weight = tf.Variable(tf.random_normal(shape=[in_dim, out_dim], stddev=std))bias = tf.Variable(tf.zeros(shape=[1, out_dim]))weights.append(weight)biases.append(bias)return weights, biases# 构建前馈神经网络def fnn(self, X, weights, biases):A = 2.0 * (X - self.Xmin) / (self.Xmax - self.Xmin) - 1.0  # 归一化输入num_layers = len(weights)for i in range(num_layers - 1):A = tf.tanh(tf.add(tf.matmul(A, weights[i]), biases[i]))  # 隐藏层激活函数Y = tf.add(tf.matmul(A, weights[-1]), biases[-1])  # 输出层return Y# 构建用于求解 Poisson 方程的神经网络def pdenn(self, x, y, weights, biases):u = self.fnn(tf.concat([x, y], 1), weights, biases)  # 前馈网络输出u_x = tf.gradients(u, x)[0]  # u 对 x 的一阶导数u_xx = tf.gradients(u_x, x)[0]  # u 对 x 的二阶导数u_y = tf.gradients(u, y)[0]  # u 对 y 的一阶导数u_yy = tf.gradients(u_y, y)[0]  # u 对 y 的二阶导数# 源项函数rhs_func = 8 * np.pi**2 * tf.sin(2 * np.pi * x  ) * tf.sin(2 * np.pi * y )# 残差项residual = -(u_xx + u_yy) - rhs_funcreturn residualdef compute_errors(u_pred, u_exact):"""计算数值解与精确解之间的 L2 误差和最大模误差:param u_pred: 数值解:param u_exact: 精确解:return: L2 误差和最大模误差"""# 计算 L2 误差L2_error = np.sqrt(np.mean((u_pred - u_exact) ** 2))# 计算最大模误差max_error = np.max(np.abs(u_pred - u_exact))return L2_error, max_error
# 检查保存路径是否存在,如果不存在则创建
save_path = './Output'
if not os.path.exists(save_path):os.makedirs(save_path)# 定义保存和绘图类
class SavePlot:def __init__(self, session, x_range, y_range, num_x_points, num_y_points, xa, xb, ya, yb):self.x_range = x_range  # x 轴范围self.y_range = y_range  # y 轴范围self.num_x_points = num_x_points  # x 方向上的测试点数量self.num_y_points = num_y_points  # y 方向上的测试点数量self.session = session  # TensorFlow 会话self.xa = xa  # x 方向左边界self.xb = xb  # x 方向右边界self.ya = ya  # y 方向下边界self.yb = yb  # y 方向上边界# 保存并绘制预测和精确解def save_and_plot(self, u_pred, x_res_train, y_res_train):# 生成测试点x_test = np.linspace(self.x_range[0], self.x_range[1], self.num_x_points).reshape((-1, 1))y_test = np.linspace(self.y_range[0], self.y_range[1], self.num_y_points).reshape((-1, 1))x_test_grid, y_test_grid = np.meshgrid(x_test, y_test)x_test_grid = np.reshape(x_test_grid, (-1, 1))y_test_grid = np.reshape(y_test_grid, (-1, 1))# 创建测试字典test_feed_dict = {x_res_train: x_test_grid, y_res_train: y_test_grid}# 在测试网格上进行预测u_test = self.session.run(u_pred, feed_dict=test_feed_dict)u_test = np.reshape(u_test, (y_test.shape[0], x_test.shape[0]))u_test = np.transpose(u_test)# 保存预测结果到文件np.savetxt(os.path.join(save_path, 'u_pred.txt'), u_test, fmt='%e')# 绘制预测结果并保存图片plt.imshow(u_test, cmap='rainbow', aspect='auto')plt.colorbar()plt.title('Numerical Solution')plt.xlabel('X-axis')plt.ylabel('Y-axis')plt.savefig(os.path.join(save_path, 'u_pred.png'))plt.show()plt.close()# 计算并保存精确解exact_solution = Exact(self.xa, self.xb, self.ya, self.yb)u_exact = exact_solution.u_exact(np.hstack((x_test_grid, y_test_grid)))u_exact = np.reshape(u_exact, (y_test.shape[0], x_test.shape[0]))u_exact = np.transpose(u_exact)np.savetxt(os.path.join(save_path, 'u_exact.txt'), u_exact, fmt='%e')# 绘制精确解并保存图片plt.imshow(u_exact, cmap='rainbow', aspect='auto')plt.colorbar()plt.title('Exact Solution')plt.xlabel('X-axis')plt.ylabel('Y-axis')plt.savefig(os.path.join(save_path, 'u_exact.png'))plt.show()plt.close()

下面是主程序:

import os
import tensorflow as tf
import numpy as np
import time
import matplotlib.pyplot as plt# 设置随机种子以确保可重复性
np.random.seed(1234)
tf.set_random_seed(1234)def main():# 定义计算域范围x_range = [-0.5, 1.5]y_range = [-1.0, 1.0]# 网格点数量num_x_points = 101num_y_points = 101# 残差点和边界点数量num_residual_points = 8000num_boundary_x_points = 100num_boundary_y_points = 100# 边界范围xa = x_range[0]xb = x_range[1]ya = y_range[0]yb = y_range[1]# 创建数据集对象data = Dataset(x_range, y_range, num_residual_points, num_boundary_x_points, num_boundary_y_points, num_x_points, num_y_points, xa, xb, ya, yb)# 生成数据X_res, X_b0, X_b1, Y_b0, Y_b1, Xmin, Xmax = data.build_data()# 定义神经网络的层结构layers = [2] + 5 * [40] + [1]# 定义输入占位符x_res_train = tf.placeholder(shape=[None, 1], dtype=tf.float32)y_res_train = tf.placeholder(shape=[None, 1], dtype=tf.float32)X_x_b0_train = tf.placeholder(shape=[None, 1], dtype=tf.float32)X_y_b0_train = tf.placeholder(shape=[None, 1], dtype=tf.float32)X_x_b1_train = tf.placeholder(shape=[None, 1], dtype=tf.float32)X_y_b1_train = tf.placeholder(shape=[None, 1], dtype=tf.float32)Y_x_b0_train = tf.placeholder(shape=[None, 1], dtype=tf.float32)Y_y_b0_train = tf.placeholder(shape=[None, 1], dtype=tf.float32)Y_x_b1_train = tf.placeholder(shape=[None, 1], dtype=tf.float32)Y_y_b1_train = tf.placeholder(shape=[None, 1], dtype=tf.float32)# 创建物理信息神经网络(PINN)pinn = DNN(layers, Xmin, Xmax)weights, biases = pinn.hyper_initial()# 预测解u_pred = pinn.fnn(tf.concat([x_res_train, y_res_train], 1), weights, biases)# 计算残差f_pred = pinn.pdenn(x_res_train, y_res_train, weights, biases)# 边界条件预测 (x = xa, xb)u_x_b0_pred = pinn.fnn(tf.concat([X_x_b0_train, X_y_b0_train], 1), weights, biases)u_x_b1_pred = pinn.fnn(tf.concat([X_x_b1_train, X_y_b1_train], 1), weights, biases)# 边界条件预测 (y = ya, yb)u_y_b0_pred = pinn.fnn(tf.concat([Y_x_b0_train, Y_y_b0_train], 1), weights, biases)u_y_b1_pred = pinn.fnn(tf.concat([Y_x_b1_train, Y_y_b1_train], 1), weights, biases)# 定义损失函数loss = 0.1 * tf.reduce_mean(tf.square(f_pred)) + \tf.reduce_mean(tf.square(u_x_b0_pred)) + \tf.reduce_mean(tf.square(u_x_b1_pred)) + \tf.reduce_mean(tf.square(u_y_b0_pred)) + \tf.reduce_mean(tf.square(u_y_b1_pred))# 定义优化器train_adam = tf.train.AdamOptimizer(0.0008).minimize(loss)train_lbfgs = tf.contrib.opt.ScipyOptimizerInterface(loss,method="L-BFGS-B",options={'maxiter': 10000 ,'ftol': 1.0 * np.finfo(float).eps})# 创建 TensorFlow 会话session = tf.Session()session.run(tf.global_variables_initializer())# 创建训练字典train_feed_dict = {x_res_train: X_res[:, 0:1], y_res_train: X_res[:, 1:2], X_x_b0_train: X_b0[:, 0:1], X_y_b0_train: X_b0[:, 1:2],X_x_b1_train: X_b1[:, 0:1], X_y_b1_train: X_b1[:, 1:2], Y_x_b0_train: Y_b0[:, 0:1], Y_y_b0_train: Y_b0[:, 1:2], Y_x_b1_train: Y_b1[:, 0:1], Y_y_b1_train: Y_b1[:, 1:2]}# 创建训练模型model = Train(train_feed_dict)# 记录训练时间start_time = time.perf_counter()model.nntrain(session, u_pred, loss, train_adam, train_lbfgs)stop_time = time.perf_counter()print('训练时间为 %.3f 秒' % (stop_time - start_time))# 保存预测数据和图像num_test_x_points = 101num_test_y_points = 101data_saver = SavePlot(session, x_range, y_range, num_test_x_points, num_test_y_points, xa, xb, ya, yb)data_saver.save_and_plot(u_pred, x_res_train, y_res_train)# 计算误差x_test = np.linspace(x_range[0], x_range[1], num_test_x_points).reshape((-1, 1))y_test = np.linspace(y_range[0], y_range[1], num_test_y_points).reshape((-1, 1))x_t, y_t = np.meshgrid(x_test, y_test)x_t = np.reshape(x_t, (-1, 1))y_t = np.reshape(y_t, (-1, 1))test_dict = {x_res_train: x_t, y_res_train: y_t}u_test_pred = session.run(u_pred, feed_dict=test_dict)  # 预测在均匀网格上的解Exact_sln = Exact(xa, xb, ya, yb)u_test_exact = Exact_sln.u_exact(np.hstack((x_t, y_t)))# 计算误差L2_error, max_error = compute_errors(u_test_pred, u_test_exact)print('L2 Error: %.6e' % L2_error)print('Max Error: %.7e' % max_error)if __name__ == '__main__':main()

程序中已经写好了详细的注释,关于优化器与 TF 会话(session) 的相关知识请各位移步 TensorFlow 优化器使用。另外建议读者对比阅读我之前总结的一维PINN 算法的实现 ,理解一维二维的本质不同,更高维的 PDE 求解也就不在话下了。

运行结果

在这里插入图片描述
在这里插入图片描述
效果不错!

-----------------------------------------------------------------------------------------------
本专栏目标从简单的一维 Poisson 方程,到对流扩散方程,Burges 方程,到二维,三维以及非线性方程,发展方程,积分方程等等,所有文章包含全部可运行代码。请持续关注!

相关文章:

Python 机器学习求解 PDE 学习项目——PINN 求解二维 Poisson 方程

本文使用 TensorFlow 1.15 环境搭建深度神经网络&#xff08;PINN&#xff09;求解二维 Poisson 方程: 模型问题 − Δ u f in Ω , u g on Γ : ∂ Ω . \begin{align} -\Delta u & f \quad & \text{in } \Omega,\\ u & g \quad & \text{on } \Gamma:\p…...

微信小程序删除滑块 SwiperCell 自动收起 Van weapp van-swipe-cell 滑块自动收起 点击页面也自动收起滑块

在当前页面整个 view 中 给页面绑定 点击事件bindtap"onSwipeCellPage"给 van-swipe-cell 组件设置 id &#xff08;for循环可以添加 id"swip-cell-{{item.id}}" &#xff09;van-swipe-cell 组件 添加属性 当用户打开滑块时触发 bind:open"swiperCel…...

【vluhub】log4j注入漏洞 CVE-2021-44228

LOG4介绍 是一个用Java编写的可靠&#xff0c;快速和灵活的日志框架&#xff08;API&#xff09;&#xff0c;它在Apache软件许可下发布 log4j存在远程代码执行漏洞、受影响版本2.x 部署环境 攻击机环境&#xff1a;192.168.3.180 kail环境&#xff1a;192.168.203.12【NAT…...

Redis核心技术与实战学习笔记

Redis核心技术与实战学习笔记 最近想沉下心来看下redis&#xff0c;买了蒋德钧老师的《Redis 核心技术与实战》,这里记录一些学习笔记 希望能够坚持下去有想一起学习的童鞋&#xff0c;可以点击跳转到文章尾部获取学习资源,仅供学习不要用于任何商业用途!!! redis知识全景图 …...

力扣经典题目之->设计循环队列 的超详细讲解与实现

一&#xff1a;题目 二&#xff1a;思路讲解 前提&#xff1a; a&#xff1a;本文采取数组来实现队列去解决题目 b&#xff1a;开辟k1个空间&#xff0c;front指向队首&#xff0c;rear指向队尾的后一个&#xff0c;rear这样会更好的判空和判满 以下根据pop和push感受满和空…...

【数据结构】排序算法——Lesson2

Hi~&#xff01;这里是奋斗的小羊&#xff0c;很荣幸您能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎 ~~ &#x1f4a5;&#x1f4a5;个人主页&#xff1a;奋斗的小羊 &#x1f4a5;&#x1f4a5;所属专栏&#xff1a;C语言 &#x1f680;本系列文章为个人学习…...

Ubuntu编译ffmpeg并添加cmake工程

文章目录 前言前提须知为什么要自己编译 FFmpeg前提软件包与工具的安装编译ffmpeg写CMakeList.txt包含ffmpeg到我们项目中 总结 前言 FFmpeg 是一个领先的多媒体框架&#xff0c;能够解码、编码、转码、复用、解复用、流化、过滤和播放几乎所有人类和机器创造的内容。FFmpeg 包…...

Vue.js[组件(Component)]

什么是: 拥有专属的HTML&#xff0c;CSS&#xff0c;数据的&#xff0c;可重用的页面独立区域 一个页面由多个组件聚合而成一个大型的页面 在代码层面上&#xff0c;一个组件就是一个可反复使用的自定义标签。 vs jq插件 vs boot组件 boot插件: 虽然可重用&#xff0c;但仍需…...

基于微信小程序+SpringBoot+Vue的校园自助打印系统(带1w+文档)

基于微信小程序SpringBootVue的校园自助打印系统(带1w文档) 基于微信小程序SpringBootVue的校园自助打印系统(带1w文档) 管理信息可以处理复杂的信息从而提高用户的工作效率&#xff0c;减少失误。所以本基于Vue和微信小程序的校园自助打印系统的开发非常有意义&#xff0c;本系…...

qt设置过滤器

1.创建事件过滤器类&#xff0c;在主窗口中安装事件过滤器 class PasteFilter : public QObject {Q_OBJECTpublic:PasteFilter(QObject *parent nullptr) : QObject(parent) {}protected:bool eventFilter(QObject *obj, QEvent *event) override {if (event->type() QEv…...

线上环境服务器CPU飙升排查

前因 收到线上服务器CPU使用率100%的告警信息。 环境 jdk1.8CentOS Linux &#xff1b;CentOS Linux 排查 查看服务器CPU使用率 果然cpu已经达到了100%了 命令 top 使用arthas工具 使用方式 arthas 执行命令java -jar arthas-boot.jar 然后执行命令 thread 看到有两个…...

unity文字||图片模糊

一.文字模糊 1、增大字体大小后等比缩放 快捷键R 2、更改字体渲染模式 二.图片模糊 1、更改过滤模式 2、更改格式或者压缩 3、如果只是图片边缘看不清&#xff0c;可以增加canvas/图片的每单位参考像素...

香薰学习笔记

1 喷香水的方法 ChatGPT-4o 学习使用香水是提升个人形象的一个好方法。 喷香水的方法如下&#xff1a; 皮肤吸收&#xff1a;香水最好喷在皮肤上&#xff0c;因为皮肤的温度能帮助香水散发出更好的香味。喷在衣服上可能会影响香水的原始味道。脉搏点&#xff1a;将香水喷在脉搏…...

iOS ------ weak的基本原理

1.weak的基本概念 weak弱引用&#xff0c;所引用的对象的引用计数不会加一&#xff0c;引用对象被释放的时候会自动设置为nil多用于解决对象间的相互引用造成内存泄露的循环引用的问题 2.实现原理 Person *object [[Person alloc] init]; id __weak objc object;Runtime维…...

实时更新UI界面

1.处理实时通信&#xff0c;几种方案 1&#xff1a;当一个用户发送一条需要实时更新的信息&#xff0c;我可以直接查找在线用户&#xff0c;通过在线用户来进行判断条件&#xff0c;发送更新请求 2&#xff1a;用户在一个需要实时更新的界面时&#xff0c;就不断的向服务端发…...

为什么Spring不推荐@Autowired用于字段注入

背景 Spring是Java程序员常用的框架之一。官方从Spring 4.0开始不推荐使用Autowired进行字段注入。 Spring注入方式 基于构造器注入&#xff1a;在构造器上使用Autowired。 优点&#xff1a;可以声明字段为final&#xff0c;确保字段在构造时被初始化。 基于setter方法注入&…...

【北京迅为】《i.MX8MM嵌入式Linux开发指南》-第三篇 嵌入式Linux驱动开发篇-第三十九章 Linux MISC驱动

i.MX8MM处理器采用了先进的14LPCFinFET工艺&#xff0c;提供更快的速度和更高的电源效率;四核Cortex-A53&#xff0c;单核Cortex-M4&#xff0c;多达五个内核 &#xff0c;主频高达1.8GHz&#xff0c;2G DDR4内存、8G EMMC存储。千兆工业级以太网、MIPI-DSI、USB HOST、WIFI/BT…...

基于MobileNetv2的垃圾分类函数式自动微分-昇思25天打卡

基于MobileNetv2的垃圾分类 本文档主要介绍垃圾分类代码开发的方法。通过读取本地图像数据作为输入&#xff0c;对图像中的垃圾物体进行检测&#xff0c;并且将检测结果图片保存到文件中。 1、实验目的 了解熟悉垃圾分类应用代码的编写&#xff08;Python语言&#xff09;&a…...

STM32CubeIDE(CAN)

目录 一、概念 1、简述 2、CAN 的几种模式 二、实践 1、环回模式轮询通信 1.1 软件配置 1.2 代码编写 2、环回模式中断通信 2.1 软件配置 2.2 代码编写 一、概念 1、简述 STM32微控制器系列包含多个型号&#xff0c;其中一些型号集成了CAN&#xff08;Controller Are…...

GO Channel使用详解(各种场景下的最佳实践)

GO Channel使用详解(各种场景下的最佳实践) 一个知识点:通过反射的方式执行 select 语句,在处理很多的 case clause,尤其是不定长的 case clause 的时候,非常有用。而且,在后面介绍任务编排的实现时,我也会采用这种方法,所以,我先带你具体学习下 Channel 的反射用法…...

SwiftUI 5.0(iOS 17)滚动视图的滚动目标行为(Target Behavior)解惑和实战

概览 在 SwiftUI 的开发过程中我们常说&#xff1a;“屏幕不够&#xff0c;滚动来凑”。可见滚动视图对于超长内容的呈现有着多么秉轴持钧的重要作用。 这不&#xff0c;从 SwiftUI 5.0&#xff08;iOS 17&#xff09;开始苹果又为滚动视图增加了全新的功能。但是官方的示例可…...

picker 构建记录

picker 构建记录 tomlinuxtom:~/openverify/picker$ cd picker bash: cd: picker: 没有那个文件或目录 tomlinuxtom:~/openverify/picker$ export BUILD_XSPCOMM_SWIGpython tomlinuxtom:~/openverify/picker$ make rm -rf temp build /home/tom/Tools/verible-v0.0-3724/bin/…...

Docker部署kafka,Docker所在宿主机以外主机访问

# 安装启动zookeeper docker run -d --name zookeeper --publish 2181:2181 --volume /etc/localtime:/etc/localtime zookeeper:latest --network 指定的网络 -p&#xff1a;设置映射端口&#xff08;默认2181&#xff09; -d&#xff1a;后台启动 # 启动kafka docker run -d…...

控制欲过强的Linux小进程

控制欲强?视奸&#xff1f;普通人那才叫视奸&#xff0c;您是皇帝&#xff0c;天下大事无一逃过您的耳目&#xff0c;您想看什么就看什么&#xff0c;臣怀疑他在朋友圈私养兵士&#xff0c;囤积枪甲&#xff0c;蓄意谋反&#xff0c;图谋皇位啊&#xff01; 哈哈哈哈开个玩笑&…...

​探讨元宇宙和VR虚拟现实之间的区别​

在数字时代&#xff0c;人们对虚拟现实的兴趣与日俱增。在虚拟现实技术的推动下&#xff0c;出现了两个概念&#xff1a;元宇宙和VR虚拟现实。虽然这两个概念都与虚拟现实有关&#xff0c;但它们有着不同的特点和用途。在本文中&#xff0c;我们将探讨元宇宙和VR虚拟现实之间的…...

Docker Desktop安装

0 Preface/Foreward 1 安装 1.1 运行docker安装包 安装完Docker Desktop后&#xff0c;运行Docker Desktop&#xff0c;出现WSL 2安装不完整情况&#xff0c;具体情况如下&#xff1a; 解决方法&#xff1a;旧版 WSL 的手动安装步骤 | Microsoft Learn 也可以直接下载新的安…...

《Towards Black-Box Membership Inference Attack for Diffusion Models》论文笔记

《Towards Black-Box Membership Inference Attack for Diffusion Models》 Abstract 识别艺术品是否用于训练扩散模型的挑战&#xff0c;重点是人工智能生成的艺术品中的成员推断攻击——copyright protection不需要访问内部模型组件的新型黑盒攻击方法展示了在评估 DALL-E …...

vscode调试nextjs前端后端程序、nextjs api接口

最近有一个项目使用了nextjs框架&#xff0c;并且使用nextjs同时实现了前后端&#xff0c;由于之前前后端都是分离的&#xff0c;前端的调试可以通过在代码种添加debugger或者直接在浏览器中打断点实现&#xff0c;现在想调试后端接口&#xff0c;前面的方式就不适用了。故研究…...

《SeTformer Is What You Need for Vision and Language》

会议&#xff1a;AAAI 年份&#xff1a;2024 论文&#xff1a;DDAE: Towards Deep Dynamic Vision BERT Pretraining - AMinerhttps://www.aminer.cn/pub/6602613613fb2c6cf6c387c2/ddae-towards-deep-dynamic-vision-bert-pretraining 摘要 这篇论文介绍了一种新型的变换器…...

[保姆级教程]uniapp安装使用uViewUI教程

文章目录 创建 UniApp 项目下载uView UI下载安装方式步骤 1: 安装 uView UI步骤 2: 查看uView UI是否下载成功步骤 3: 引入 uView 主 JS 库步骤 4: 引入 uView 的全局 SCSS 主题文件步骤 5: 引入 uView 基础样式步骤 6: 配置 easycom 组件模式注意事项 NPM方式步骤 1: 安装 uVi…...

网络安全法规对企业做等保有哪些具体规定?

网络安全法规对企业做等保的具体规定 根据《中华人民共和国网络安全法》&#xff0c;企业作为网络运营者&#xff0c;需要履行网络安全等级保护制度的相关义务&#xff0c;确保网络安全和数据保护。具体规定包括&#xff1a; 网络安全等级保护制度&#xff1a;企业应根据网络安…...

Java开发中超好用Orika属性映射工具

Orika属性映射工具 引入pom依赖 <dependency><groupId>ma.glasnost.orika</groupId><artifactId>orika-core</artifactId><version>1.5.4</version></dependency>上干货 封装的工具类:OriUtilsimport ma.glasnost.orika.Map…...

qt初入门8:下拉框,输入框模糊查询,提示简单了解 (借助QCompleter)

实现一个简单的模糊查询的逻辑&#xff0c;输入框能提示相关项。 主要借助qt的QCompleter 类&#xff08; Qt 框架中提供的一个用于自动补全和模糊搜索的类&#xff09;&#xff0c;结合一些控件&#xff0c;比如QComboBox和QLineEdit&#xff0c;实现模糊查询的功能。 1&…...

【qt】VS中如何配置Qt环境

https://download.qt.io/official_releases/vsaddin/ 首先需要下载一下vsaddin,上面的是下载的网站. 下载的时候可能会出现下图的情况 说明你下的vsaddin和您的VS版本不匹配,所以你可以多下几个其他版本的vsAddin,一般都是和你VS版本相匹配的才可以,如Vs2022,那就试试vsaddin2…...

对于相同网段的IP,部分无法ping通问题

现象1&#xff1a;在Linux上执行 ping 192.168.1.232&#xff0c;无法ping通 分析1&#xff1a;使用ifconfig查询&#xff0c;联网使用eth0口&#xff0c;只能上网192.168.10.xx网段&#xff0c;需要增加网段 解决方法&#xff1a;使用ip addr 查询&#xff0c;本身只具备10网…...

Unity发布XR中用于worldbuilding的全新电子书

通过身临其境的虚拟领域开始旅程&#xff0c;在维度之间传送&#xff0c;或将数字奇迹与现实世界融合——虚拟现实(VR)和混合现实(MR)的千万种可能性将邀请创作者把他们的想象力带入生活。 Unity发布的最新版综合指南将帮助有抱负的创作者和经验丰富的开发者深入研究和理解构建…...

Vue3相比于Vue2进行了哪些更新

1、响应式原理 vue2 vue2中采用 defineProperty 来劫持整个对象&#xff0c;然后进行深度遍历所有属性&#xff0c;给每个属性添加getter和setter&#xff0c;结合发布订阅模式实现响应式。 存在的问题&#xff1a; 检测不到对象属性的添加和删除数组API方法无法监听到需要对…...

Unity UGUI 之 Slider

本文仅作学习笔记与交流&#xff0c;不作任何商业用途 本文包括但不限于unity官方手册&#xff0c;唐老狮&#xff0c;麦扣教程知识&#xff0c;引用会标记&#xff0c;如有不足还请斧正 1.Slider是什么 滑块&#xff0c;由三部分组成&#xff1a;背景 填充条 手柄 填充条就是…...

这7款高效爬虫工具软件,非常实用!

在当今数据驱动的时代&#xff0c;自动化爬虫工具和软件成为了许多企业和个人获取数据的重要手段。这里会介绍6款功能强大、操作简便的自动化爬虫工具&#xff0c;用好了可以更高效地进行数据采集。 1. 八爪鱼采集器 八爪鱼是一款功能强大的桌面端爬虫软件&#xff0c;主打可…...

【OJ】二叉树相关OJ题

✨✨欢迎大家来到Celia的博客✨✨ &#x1f389;&#x1f389;创作不易&#xff0c;请点赞关注&#xff0c;多多支持哦&#x1f389;&#x1f389; 所属专栏&#xff1a;OJ题 个人主页&#xff1a;Celias blog~ 目录 ​编辑 单值二叉树 题目描述 OJ-单值二叉树 解题思路 …...

Blender中保存透明图片

在Blender中保存透明图片&#xff0c;主要是通过在渲染设置中调整背景透明度&#xff0c;并选择合适的文件格式来保存图像。以下是一个详细的步骤指南&#xff1a; 一、设置渲染属性 打开Blender并加载你想要渲染的模型。在右侧的属性编辑器中&#xff0c;找到并点击“渲染属…...

MySQL之索引优化

1、在进行查询时&#xff0c;索引列不能是表达式的一部分&#xff0c;也不能是函数的参数&#xff0c;否则无法使用索引 例如下面的查询不能使用 actor_id 列的索引&#xff1a; #这是错误的 SELECT actor_id FROM sakila.actor WHERE actor_id 1 5; 优化方式&#xff1a;…...

Spring Boot 与 Amazon S3:快速上传与下载文件的完整指南

概要 在将 Spring Boot 更新到 3 系列时&#xff0c;由于 javax 需要被替换为 jakarta&#xff0c;因此原先依赖于 javax 的 spring-cloud-starter-aws1 将无法使用&#xff08;虽然在我本地环境中仍然可以正常工作&#xff09;。为了确保兼容性&#xff0c;我将依赖关系更改为…...

细节剖析:HTTP与HTTPS在安全性、性能等方面的不同!

HTTPS是现代互联网通信的重要基石&#xff0c;通过加密通信、身份验证和数据完整性保护&#xff0c;为数十亿用户提供了安全可靠的互联网体验。 小编整理了2GB程序员相关资料&#xff0c;关注微信公众号“程序员Style”回复“程序员”免费领取&#xff01; 1、介绍 随着 HTT…...

MySQL面试篇章——MySQL索引

文章目录 MySQL 索引索引分类索引创建和删除索引的执行过程explain 查看执行计划explain 结果字段分析 索引的底层实现原理B-树B树哈希索引 聚集和非聚集索引MyISAM&#xff08;\*.MYD&#xff0c;*.MYI&#xff09;主键索引辅助索引&#xff08;二级索引&#xff09; InnoDB&a…...

WSL 2 Oracle Linux 9.1 安装配置

文章目录 环境使用体验安装 Oracle Linux 9.1修改默认存储路径默认 root 用户登录启用 systemd启用 SSH 连接WSL 无法 ping 通宿主机和域名WSL 使用主机代理&#xff08;测试通过&#xff09;WSL 常用命令 环境 OS&#xff1a;Win11 24H2 (OS 内部版本26120.1252) wsl --versio…...

MySQL日志文件详解

MySQL中的日志文件是MySQL数据库系统的重要组成部分&#xff0c;它们记录了数据库的运行情况、用户操作、错误信息等&#xff0c;对于数据库的维护、优化、故障排查和恢复都具有重要意义。以下是MySQL中几种主要日志文件的详解&#xff1a; 1. 二进制日志&#xff08;Binary L…...

MySQL零散拾遗(三)

在mysql中&#xff0c;JOIN ON 和 WHERE 的作用和用法是怎么样的&#xff1f; 在MySQL中&#xff0c;JOIN语句用于将两个或多个表根据指定的关联条件合并成一个新的结果集。JOIN ON和WHERE子句在JOIN语句中扮演着不同的角色&#xff0c;它们的用法和作用如下&#xff1a; JOI…...

鸿蒙 使用 Refresh 实现下拉刷新

import promptAction from ohos.promptActionEntry Component struct Index {Staterefreshing: boolean falseStatelist: number[] Array(20).fill(Date.now())Buildercontent(){Stack(){Row(){LoadingProgress().height(32)Text(正在刷新...).fontSize(16).margin({left:20}…...

【JavaScript 算法】图的遍历:理解图的结构

&#x1f525; 个人主页&#xff1a;空白诗 文章目录 一、深度优先搜索&#xff08;DFS&#xff09;深度优先搜索的步骤深度优先搜索的JavaScript实现 二、广度优先搜索&#xff08;BFS&#xff09;广度优先搜索的步骤 三、应用场景四、总结 图的遍历是图论中的基本操作之一&am…...