随机游走问题的神奇应用(一)

2023-11-30 05:32

本文主要是介绍随机游走问题的神奇应用(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

泊松方程的随机游走求解

    • 一.问题的提出
    • 二.问题的求解
    • 三.代码求解

可以用monteCarlo方法构建一个随机游走过程来求解偏微分方程。

一.问题的提出

​ 求解二维泊松方程的第一边值问题如下:
∂ 2 u ( P ) ∂ x + ∂ 2 u ( P ) ∂ y 2 = q ( P ) P ( x , y ) ∈ D \frac{\partial^2 u(P)}{\partial x} + \frac{\partial^2 u(P)}{\partial y^2} = q(P)\quad P(x,y) \in D\\ x2u(P)+y22u(P)=q(P)P(x,y)D
​ 边界条件为:
u ( Q ) = f ( Q ) Q ( x , y ) ∈ Γ = ∂ D u(Q) = f(Q)\quad Q(x,y)\in \Gamma = \partial D u(Q)=f(Q)Q(x,y)Γ=D

二.问题的求解

如下图所示如果我们要求在 P ( x ∗ , y ∗ ) P(x^*,y^*) P(x,y)处的值,设求解步长为 h h h。我们就将原来的方程差分化:
u ( x + h , y ) + u ( x − h , y ) − 2 u ( x , y ) h 2 + u ( x , y + h ) + u ( x , y − h ) − 2 u ( x , y ) h 2 = q ( x , y ) \frac{u(x+h,y)+u(x-h,y) -2u(x,y)}{h^2}+\frac{u(x,y+h)+u(x,y-h) -2u(x,y)}{h^2} = q(x,y) h2u(x+h,y)+u(xh,y)2u(x,y)+h2u(x,y+h)+u(x,yh)2u(x,y)=q(x,y)
可以化成如下差分形式:
u = − h 2 4 q + ∑ i = 1 4 u 1 i u = -\frac{h^2}{4}q+\sum_{i= 1}^4u_{1i} u=4h2q+i=14u1i
其中 P 1 i P_{1i} P1i的含义如下图所示:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FS0WKT5q-1608990753380)(D:\文件\2020 09 19\美赛软件\h图.png)]

我们假设方程的定义区域为下图,黑点为边界 Γ \Gamma Γ上的点,白点为内部 D D D上的点。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dR9Iys64-1608990753383)(D:\文件\2020 09 19\美赛软件\截图.png)]

我们定义一个从 P ( x ∗ , y ∗ ) P(x^*,y^*) P(x,y)开始的游走路线:
ρ P : P → P 1 → P 2 → P 3 . . . → P k − 1 → Q ∈ Γ \rho_P :P\rightarrow P_1 \rightarrow P_2 \rightarrow P_3...\rightarrow P_{k-1}\rightarrow Q\in \Gamma ρP:PP1P2P3...Pk1QΓ
其中的点 P i P_i Pi是由点 P i − 1 P_{i-1} Pi1进过以下规则 f f f得到的:
f : P i − 1 → P i f:P_{i-1} \rightarrow P_i f:Pi1Pi
f f f:我们产生一个随机数 r ∈ [ 0 , 1 ] r\in[0,1] r[0,1]:

r r r P i − 1 P_{i-1} Pi1 P i P_i Pi
[ 0 , 0.25 ] [0,0.25] [0,0.25] P i − 1 ( x ∗ , y ∗ ) P_{i-1}(x^*,y^*) Pi1(x,y) P i ( x ∗ + h , y ∗ ) P_i(x^*+h,y^*) Pi(x+h,y)
[ 0.25 , 0.5 ] [0.25,0.5] [0.25,0.5] P i − 1 ( x ∗ , y ∗ ) P_{i-1}(x^*,y^*) Pi1(x,y) P i ( x ∗ , y ∗ + h ) P_i(x^*,y^*+h) Pi(x,y+h)
[ 0.5 , 0.75 ] [0.5,0.75] [0.5,0.75] P i − 1 ( x ∗ , y ∗ ) P_{i-1}(x^*,y^*) Pi1(x,y) P i ( x ∗ − h , y ∗ ) P_i(x^*-h,y^*) Pi(xh,y)
[ 0.75 , 1 ] [0.75,1] [0.75,1] P i − 1 ( x ∗ , y ∗ ) P_{i-1}(x^*,y^*) Pi1(x,y) P i ( x ∗ , y ∗ − h ) P_i(x^*,y^*-h) Pi(x,yh)

表示 P i − 1 P_{i-1} Pi1分别有 1 4 \frac{1}{4} 41的概率到 P 11 , P 12 , P 13 , P 14 P_{11},P_{12},P_{13},P_{14} P11,P12,P13,P14,即有相同的概率前后左右随机移动,到终点为止。

那么在这样的规则下会生成一条路线 ρ P \rho_P ρP。此时我们建立其以下的映射关系:
g : ρ p → u ( P ) g:\rho_p \rightarrow u(P) g:ρpu(P)
即是从 P P P点出发的一条路线 ρ P \rho_P ρP到该点的数值解 u ( P ) u(P) u(P)的一个映射关系 g g g

现在我们直接给出这个关系:
g : u ( P ) = − h 2 4 ∑ i = 1 k − 1 q ( P i ) + f ( Q ) g:u(P) = -\frac{h^2}{4}\sum_{i = 1}^{k-1}q(P_i)+f(Q) g:u(P)=4h2i=1k1q(Pi)+f(Q)
那么我们从这一次随机游走 ρ P \rho_P ρP映射出了一次的 u ( P ) u(P) u(P)。这个结果肯定是不精确的,我们如果设每次的结果都是一次随机变量 ζ P = g ( ρ P ) \zeta_P = g(\rho_P) ζP=g(ρP),那么可以证明的是 E ζ P = u ( P ) E\zeta_P = u(P) EζP=u(P),具体证明过程忽略。我们利用这个结论可以由大数定律:
u ( P ) ∼ 1 N ∑ i = 1 N ζ P i u(P) \sim\frac{1}{N}\sum_{i =1}^N\zeta_{Pi} u(P)N1i=1NζPi
即通过多次模拟随机游走的过程求其均值用来表示当前的解 u ( P ) u(P) u(P)

三.代码求解

假设我们要求解的是以下方程:
∂ 2 u ∂ x + ∂ 2 u ∂ y 2 = 1 \frac{\partial^2 u}{\partial x} + \frac{\partial^2 u}{\partial y^2} =1 \\ x2u+y22u=1
边界 Γ : x 2 + y 2 = 2 \Gamma:x^2+y^2 =2 Γ:x2+y2=2。在此边界上:
u ( Γ ) = 1 2 u(\Gamma) = \frac{1}{2} u(Γ)=21
现求 u ( 0 , 1 ) u(0,1) u(0,1)的值。

理论上该方程的解析解为 u ( x , y ) = x 2 + y 2 4 u(x,y) = \frac{x^2+y^2}{4} u(x,y)=4x2+y2,因此 u ( 0 , 1 ) = 1 4 u(0,1) = \frac{1}{4} u(0,1)=41。在这里,我们给出求解该方程的函数并且显示当前的随机游走过程:

function [uFinal,zeta] = possionRandom(xPoint,yPoint,h,N)
%UNTITLED 求 Deltea u = 1;在u(x^2+y^2 = 2) = 0.5边界条件
%   [xPoint,yPoint]表示该点坐标,h仿真步长,N仿真次数
q = @(x,y)1;  % 函数
f = @(x,y)(0.5);
u = zeros(1,N);
for i = 1:NsumV = 0;xValue = xPoint;yValue = yPoint;P = [xValue ,yValue];%以下是游走过程while(1)if (xValue)^2+(yValue)^2>=2P = [P;xValue,yValue];break;endrandNumber = randsrc(1,1,[[0 1 2 3];[0.25 0.25 0.25 0.25]]);switch (randNumber)case 0xValue = xValue + h;yValue = yValue;case 1xValue = xValue ;yValue = yValue + h;case 2xValue = xValue - h ;yValue = yValue ;    case 3xValue = xValue;yValue = yValue - h;endP = [P;xValue,yValue];end%以下是画图过程if i == 1subplot(121);grid on;plot(P(:,1),P(:,2),'b.-');title('第一次轨迹');end%以下是计算过程[m,n] = size(P);for j = 1:m-1if isnan(q(P(j,1),P(j,2))) == 1q(P(j,1),P(j,2)) = q(h,h);endsumV = sumV + q(P(j,1),P(j,2));endzeta(i) = -h^2/4*sumV + f(P(m,1),P(m,2));u(i) = sum(zeta(1:i))/i;
end
subplot(122);
grid on ;
uFinal = u(N);
plot(1:N,u,'r');
xlabel('次数');
ylabel('进化曲线');
title('收敛过程');
end

在命令行求解 u ( 0 , 1 ) u(0,1) u(0,1)的值如下,设置步长为 h = 0.01 h = 0.01 h=0.01,仿真次数 N = 100 N = 100 N=100

>> [uFinal,zeta] = possionRandom(0,1,0.01,100);

得到如下图形:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZsOWq3gq-1608990753386)(D:\文件\2020 09 19\美赛软件\随机游走1.png)]

最终结果为 0.2353 0.2353 0.2353。可以发现还是有点误差的。

关键是这玩意如果步长设置的比较小的话就会一直游走。所以运行的时间就会比较长。

这篇关于随机游走问题的神奇应用(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/435809

相关文章

java实现延迟/超时/定时问题

《java实现延迟/超时/定时问题》:本文主要介绍java实现延迟/超时/定时问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java实现延迟/超时/定时java 每间隔5秒执行一次,一共执行5次然后结束scheduleAtFixedRate 和 schedu

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

如何解决mmcv无法安装或安装之后报错问题

《如何解决mmcv无法安装或安装之后报错问题》:本文主要介绍如何解决mmcv无法安装或安装之后报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mmcv无法安装或安装之后报错问题1.当我们运行YOwww.chinasem.cnLO时遇到2.找到下图所示这里3.

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1