首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >高斯分布例题_高斯定理求半球面球心电场

高斯分布例题_高斯定理求半球面球心电场

作者头像
全栈程序员站长
发布2022-11-03 15:43:50
发布2022-11-03 15:43:50
3030
举报

给定心形曲线 (x2+y2−1)3=x2y3 (x^2+y^2-1)^3=x^2y^3,给定任意一点的坐标 (X,Y) (X,Y)其中 X~N(X,σx) X~N(X,\sigma_x), Y~N(Y,σy) Y~N(Y,\sigma_y)求点 (X,Y) (X,Y)落入心形曲线内的概率。 思路: 以 (X,Y) (X,Y)为中心,画出 3∗σ 3*\sigma半径的椭圆,求和心形曲线相交的体积。注意:心形曲线方程可化为 x2+y2−1=x2/3y x^2+y^2-1=x^{2/3}y,满足 x2+y2−1<=(x2)1/3y x^2+y^2-1<=(x^2)^{1/3}y在曲线内。利用心形曲线上下左右都有最大值且约等于正负1。可以设定一个分辨率画出图形。 上代码:

代码语言:javascript
复制
# -*- coding: utf-8 -*-
import numpy as np
import matplotlib.pyplot as plt
res=0.01#单位每像素
RES=1/res#像素每单位
block=256
map1=np.ones([block,block])
CX=block/2.0
CY=block/2.0
for y in np.arange(0,block):
for x in np.arange(0,block):
if (res*(x-CX))**2+(res*(y-CX))**2-1<=(res*np.abs(x-CX))**(2.0/3.0)*(res*(y-CY)):
map1[y,x]=0
plt.figure(1)
plt.imshow(map1,cmap='gray')
sigmax=0.3
sigmay=0.1
X=0
Y=0
l=max(CX+(X-3*sigmax)*RES,0)
r=min(CX+(X+3*sigmax)*RES,block)
t=max(CY+(Y-3*sigmay)*RES,0)
b=min(CY+(Y+3*sigmay)*RES,block)
print(l,r,t,b)
theta=1/((2.0*np.pi)*(sigmax*sigmay))
ssum=0;
for y in np.arange(l,r+1):
for x in np.arange(t,b+1):
if map1[y,x]==0:
map1[y,x]=np.exp(-0.5*((((x-CX)*res-X)/sigmax)**2+(((y-CY)*res-Y)/sigmay)**2))
ssum=ssum+theta*map1[y,x]
plt.figure(2)
plt.imshow(map1,cmap='gray')
#print(ssum/(np.sum(np.sum(f))))
#print(res**2*theta*np.sum(np.sum(f)))
print(res**2*ssum)
print(np.round(res**2*ssum*10)/10)
plt.show()

效果图:

心形

p=1.0

p=0.9

p=0.5

p=0.4

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/181369.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月16日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档