网站首页 > 技术文章 正文
求圆周长,我们可以先在圆内构造内接N边形,边长设为a,正边形的周长为n*a,当n不断增大的时候,正边形的边界不断趋近圆的边界,这就表示多边形周长不断接近圆的周长C,即:n趋近于无穷,C=n*a。
此外,如果我们按上述方法计算出圆周长,是不是就可以计算π的值,C=n*a=2π*r。我国古代数学家祖冲之就是利用这种割圆术之法来计算出高精度的圆周率。
随着现代计算机技术的发展,我们可以利用计算机软件,如MATLAB,来方便快速地计算圆的内接多边形的周长,这也是当代圆周率精度不断提高的原因之一。
下面,我们就用MATLAB解决这样一个问题:利用割圆术之法在单位圆周内构造内接N边形:求其周长,使其与圆周长误差<0.0001。(当然,如果求π,我们可以把误差的数值设置的更小,如亿分之一,利用C=n*a=2π*r求出高精度的π)
%下面的这段代码实现的是画出任意圆的内接多边形%
clear all,close all,clc
%参数初始化%
n=10; %正多边形的边数
r=1; %圆的半径
x0=0;y0=0; %圆心
%画圆%
theta=0:2*pi/2000:2*pi;
x=x0+r*cos(theta);
y=y0+r*sin(theta);
plot(x,y,'r')
hold on
plot(x0,y0,'r+')
axis equal
%画内接多边形%
m=2*pi/n;
x1=x0+r*cos(m.*(1:n));
x1=[x1 x1(1)];
y1=y0+r*sin(m.*(1:n));
y1=[y1 y1(1)];
plot(x1,y1,'g-')
text(x0,y0,' \leftarrow 圆心','FontSize',18,'Color','c')
n=5,圆心(0,0),半径=1
n=10,圆心(0,0),半径=1
n=20,圆心(0,0),半径=1
从上面的三幅图可以看出,随着内接多边形的边数增多,多边形边界确实在越来越解决圆的边界。
%下面的代码实现的是利用割圆术之法的思想在单位圆周内构造内接N边形,求其周长,使其与圆周长误差<0.0001。运行时间在1分钟左右%
syms n
r=1;
a=sqrt((r*cos(2*pi/n)-r)^2+(sin(2*pi/n))^2);%多边形的边长,即圆与内接多边形相邻两个交点的距离,设A(r,0),B(r*cos(2*pi/n),r*sin(2*pi/n))
s=r*2*pi/n;%2*pi/n的角度所对应的弧长
q=(s-a)/s;
n=floor(solve(q-0.0001))+1
C1=double(n*sqrt((r*cos(2*pi/n)-r)^2+(sin(2*pi/n))^2))
C2=2*pi*r
运行结果
所以,n=129时,即在单位圆内构造129边形,可使其圆周长误差<0.0001,并且其周长为6.2826。
n=129,圆心(0,0),半径=1
从上图可以看出,圆内接129边形的边界几乎与圆的边界重合,表示二者的周长已经非常接近。
最后,感谢您的耐心阅读!
猜你喜欢
- 2024-10-24 窗口快速切换利器 AltTab 3.22.6中文版
- 2024-10-24 这样上班玩游戏老板都只会夸:5个常用组合键你同事都会用!
- 2024-10-24 窗口快速切换利器AltTab for Mac 3.11.0中文版
- 2024-10-24 这些强大的快捷键,学会你就是公司最早下班的仔!
- 2024-10-24 Altium Design 快捷键(altium designer操作快捷键)
- 2024-10-24 同创双子IT小技巧分享:PPT超实用看快捷键分享,赶紧收藏吧
- 2024-10-24 一个方便的 Windows 10 技巧,让多任务处理变得更容易
- 2024-10-24 css3制作网页中常见的小箭头(html5如何弄箭头)
- 2024-10-24 电脑键盘操作技巧——Windows键或CTRL
- 2024-10-24 窗口快速切换利器AltTab 3.17.0 Mac中文版
- 最近发表
-
- 如何在 Linux 上安装 Java_怎么在linux中安装jdk
- Linux中tar命令打包路径相关问题_linux怎么用tar打包一个目录
- 常用linux系统常用扫描命令汇总_常用linux系统常用扫描命令汇总表
- VM下linux虚拟机新建过程(有图)_linux虚拟机创建新用户命令
- 系统小技巧:迁移通过Wubi方式安装的Ubuntu系统
- 文件系统(八):Linux JFFS2文件系统工作原理、优势与局限
- 如何利用ftrace精确跟踪特定进程调度信息
- prometheus网络监控之fping-exporter
- hyper linux的实操步骤,hyper-v批量管理工具的使用指南
- 2021年,运维工程师笔试真题(二)(附带答案)
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)