蒙特卡诺法计算不规则图形的面积

结课大作业题目自拟:

利用蒙特卡诺法计算不规则图形的面积,由于题目自拟,所以选择用椭圆来表示待测面积的不规则图形。

代码实现:

%%先绘制一个椭圆
a=5;%长轴
b=2;%短轴
f=@(x,y) x.^2/a^2 + y.^2/b^2-1;%椭圆方程
fimplicit(f,'LineWidth',2)%绘制椭圆 
设置窗口
set(gcf,'units','normalized','position',[0.2 0.2 0.6 0.6]); %设置figure窗口位置和尺寸
grid on
axis equal
axis([-(a+0.5),(a+0.5),-(b+0.5),(b+0.5)])
pause(2)
hold on
绘制椭圆的包络矩形
rectangle('Position',[-a,-b,2*a,2*b],'EdgeColor','r','LineWidth',2)
A=4*a*b;%矩形面积
pause(2)
投放N个均匀分布的随机点
N=500;
xk=-a+(a+a)*rand(1,N);   %x坐标
yk=-b+(b+b)*rand(1,N);   %y坐标
scatter(xk,yk,'g.')
统计落在椭圆里面的随机点个数
r = xk.^2/a^2+yk.^2/b^2;
m=find(r<=1);
n=length(m);
S=(n/N)*A

效果演示:

 

 注:由于计算过程比较复杂,所以我是选择在matlab中的实时脚本里写的。

 注:为了图像效果较好,结果图中只生成了500个随机点,结果不是很准确,增加至1000以上时,随N增大,面积值变化不再明显。

网上也有其他类似的代码,可以多方借鉴。

 

相关推荐

  1. 【Android高级UI】计算不规则图形面积

    2024-03-30 14:00:05       32 阅读
  2. 定积分应用@元素@微元@平面图面积

    2024-03-30 14:00:05       40 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-30 14:00:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-30 14:00:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-30 14:00:05       82 阅读
  4. Python语言-面向对象

    2024-03-30 14:00:05       91 阅读

热门阅读

  1. sqlmap基础知识

    2024-03-30 14:00:05       36 阅读
  2. Go的数据结构与实现【LinkedList】

    2024-03-30 14:00:05       41 阅读
  3. 手写DNS服务器测速程序(工具分享)

    2024-03-30 14:00:05       56 阅读
  4. test6

    test6

    2024-03-30 14:00:05      46 阅读
  5. 成都某公司笔试题sql

    2024-03-30 14:00:05       45 阅读
  6. 2024年道路运输安全员考试真题题库

    2024-03-30 14:00:05       33 阅读
  7. 怎么在循环List的时候删除List的元素

    2024-03-30 14:00:05       36 阅读