C# 定积分求周长&面积原理 代码实现
前言:
前些日子,因为工作原因,接触到了求解曲线周长,真的是搞了很久,学生时代真的很简单,但是如今的我来说,忘记了....很多人跟我应该一样。
所以来巩固加强一下记忆。一开始的时候,求周长嘛,找公式呗,什么matlab呀,乱七八糟的,晕,最后找到了可能还不能满足项目的需求,因为可能计算量过大。(我就是这样子的,灵活性相对较低)
还有就是明明自己可以用代码实现,为什么非要插件,工具呐,这么不自信的?
所以,“一怒之下”,自己去看了一下定积分求周长的原理,自己还是用代码来实现吧。
(以下内容纯是个人这段时间的理解,如果有错误的,欢迎指正出来。)
首先需要说说两个概念,曲线和周长,因为我们要求他们嘛。
曲线:
这个世界,有曲线吗?我的回答是,没有。那...这...曲线是由无数个直接拼接而成。再准确的说无数个很短的曲线拼接而成。
(如果您彻底理解了这句话,后面就不用看了,基本就没了。)
面积:
与周长的概念类似,没有正方形,没有圆形。只有三角形,所有的图形都是三角形拼接而成。而两个三角形拼成长方形,而我们的面积是由无数个长方形,拼接而成。

(定积分原理的参考图)
源码实现:
double GetLength(float start,float end)
{
double sumLength = ; float eachX = (end - start) / testCount;
for (int i = ; i < testCount;i++ )
{ double curY =ArcFunction(start+eachX*i);
double previousY = ArcFunction(start+eachX*(i-));
//根据c²=a²+b²
double curLength = Math.Sqrt(Math.Pow(eachX, ) + Math.Pow(curY - previousY, ));
sumLength += curLength;
}
return sumLength;
}
解释:
testCount,即自定义的测试数量,可以理解为精细度,值越大,计算量越大,数据越准确,这个可看你项目需求精细度,通过该变量
可在实现最少的计算量情况,实现你要的效果。
eachX,就是你的曲线被分成N份,每份的长度。
curY,当前点的y轴分量
previousY,上一个点的y轴分量,
curLength,即如图

(剩余的部分,代码里面含解释,个人喜欢放在源码里面,原生的,纯24k原创)
int testCount = ; //所谓的测试细致度吧,可动态调控,你自己掌握。
/// <summary>
/// 通过已知周长,获取x轴的分量
/// </summary>
/// <param name="length"></param>
/// <returns></returns>
double GetRateXByLength(double length)
{
float eachX = 1.0f;
for (int i = ; i < testCount; i++)
{
double curY = ArcFunction(eachX * i);
double previousY = ArcFunction(eachX * (i - ));
double curLength = Math.Sqrt(Math.Pow(eachX, ) + Math.Pow(curY - previousY, ));
length -= curLength;
if(length<=)
{
return i * eachX;
}
}
return testCount * eachX;
} /// <summary>
/// start到end范围内的面积
/// </summary>
/// <param name="start"></param>
/// <param name="end"></param>
/// <returns></returns>
double GetArea(float start,float end)
{
double sumAera = ; float eachX = (end - start) / testCount;
for (int i = ; i < testCount; i++)
{
double curY = ArcFunction(start + eachX * i);
//面积 = 长*宽
double curAera = curY * eachX;
sumAera += curAera;
}
return sumAera;
} /// <summary>
/// 通过已知面积,获取x轴分量
/// </summary>
/// <param name="aera"></param>
/// <returns></returns>
double GetRateXByAera(double aera)
{
float eachX = 1.0f;
for (int i = ; i < testCount; i++)
{
double curY = ArcFunction(eachX * i);
double curAera = curY * eachX;
aera -= curAera;
if(aera<=)
{
return i * eachX;
}
}
return testCount*eachX;
} /// <summary>
/// 通过x分量,得出y的值。(好像意义不大,但是好像可能有些人不是很理解,写给某些人看的,一目了然)
/// </summary>
/// <param name="x"></param>
/// <returns></returns>
double GetYByX(float x)
{
return ArcFunction(x);
} /// <summary>
/// 核心控制函数。
/// </summary>
/// <param name="x"></param>
/// <returns></returns>
double ArcFunction(float x)
{
return Math.Pow(x, ); //这边我用幂函数来测试。各位爷可以换其他函数啊。 //注:如果对曲线灵活性要求很高,推荐使用贝塞尔曲线。
//详情可参考:
}
补充:这边,我对贝塞尔曲线做一下补充吧。因为我因为什么幂函数,指数函数遇到的肯,因为这些函数毕竟还不是那么灵活,都具有一定“规律”。
贝塞尔曲线的灵活,受6个参数控制,三个点嘛。(二维空间)
详情可参考这篇:http://www.sohu.com/a/118656687_466876
======================================= 2018年9月3日补充================================================================
可以使用第三方插件:开源Math.Net进行数值积分。
参考:https://www.cnblogs.com/asxinyu/p/4301017.html
public static double OnClosedInterval(Func<double, double> f, double intervalBegin, double intervalEnd);
void Start () {
var result = Integrate.OnClosedInterval(TestFunc, 0, 24);
Debug.Log(result);
}
double TestFunc(double x)
{
return x * x;
}
但是上述的result为面积,也是dy。
再根据定积分求弧长公式:
即:弧长 = √(1+result²)
===================================================================================================================
C# 定积分求周长&面积原理 代码实现的更多相关文章
- c++-面向对象类的示例-求周长面积,判断体积相等-文件操作和一般操作
面向对象编程示例:求周长和面积 #define _CRT_SECURE_NO_WARNINGS #include <iostream> using namespace std; //圆的周 ...
- 25.按要求编写一个Java应用程序: (1)编写一个矩形类Rect,包含: 两个属性:矩形的宽width;矩形的高height。 两个构造方法: 1.一个带有两个参数的构造方法,用于将width和height属性初化; 2.一个不带参数的构造方法,将矩形初始化为宽和高都为10。 两个方法: 求矩形面积的方法area() 求矩形周长的方法perimeter() (2)通过继承Rect类编写一个具有
package zhongqiuzuoye; //自己写的方法 public class Rect { public double width; public double height; Rect( ...
- 按要求编写一个Java应用程序: (1)编写一个矩形类Rect,包含: 两个属性:矩形的宽width;矩形的高height。 两个构造方法: 1.一个带有两个参数的构造方法,用于将width和height属性初化; 2.一个不带参数的构造方法,将矩形初始化为宽和高都为10。 两个方法: 求矩形面积的方法area() 求矩形周长的方法perimeter() (2)通过继承Rect类编写一个具有确定位
package com.hanqi.test; public class Rect { ; ; public double getWidth() { return width; } public vo ...
- C#使用多态求方形面积周长和圆的面积周长
class class1 { public static void Main(string[] args) { //使用多态求矩形面积与周长和圆的面积与周长 Shape cl = ); double ...
- java求三角形面积以及周长---封装
/*时间: 2012-10-08作者: 烟大程序要求: 1.封装一类三角形对象Triangle,该类对象具有三条边的属性, 具有初始化三角形的功能.修改边长的功能.判断三条边能否构成三角形的功能. 求 ...
- 微信群里一道六年级数学题,求阴影面积,那我只能用python代码了
前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取http ...
- 编写一个Shape类,具有属性:周长和面积; 定义其子类三角形和矩形,分别具有求周长的方法。 定义主类E,在其main方法中创建三角形和矩形类的对象, 并赋给Shape类的对象a、b,使用对象a、b来测试其特性。
package shape; public class Shape { //定义成员变量 private double zhouchang; private double mianji; public ...
- UVa 11437:Triangle Fun(计算几何综合应用,求直线交点,向量运算,求三角形面积)
Problem ATriangle Fun Input: Standard Input Output: Standard Output In the picture below you can see ...
- (1)定义闭合图形抽象类ClosedFigure定义属性:1.形状;2.定义构造方法,给形状赋值;3.定义两个抽象方法:计算面积和计算周长;4.定义一个显示方法:显示图像形状,周长,面积;
题目显示不全,完整题目描述: (1)定义闭合图形抽象类ClosedFigure定义属性:1.形状:2.定义构造方法,给形状赋值:3.定义两个抽象方法:计算面积和计算周长:4.定义一个显示方法:显示图像 ...
随机推荐
- POJ-2109 Power of Cryptography(数学或二分+高精度)
题目链接: https://vjudge.net/problem/POJ-2109 题目大意: 有指数函数 k^n = p , 其中k.n.p均为整数且 1<=k<=10^9 , 1< ...
- Checkbutton
#tkinter之Checkbutton篇 #Checkbutton又称为多选按钮,可以表示两种状态,On和Off,可以设置回调函数,每当点击此按钮时回调函数被调用. 1.一个简单的Checkbutt ...
- RTKLIB源码解析(一)——单点定位(pntpos.c)
RTKLIB源码解析(一)--单点定位(pntpos.c) 标签: GNSS RTKLIB 单点定位 [TOC] pntpos int pntpos (const obsd_t *obs, int n ...
- R语言-ggplot初级
ggplot2简介: 在2005年开始出现,吸取了基础绘图系统和lattice绘图系统的优点,并利用一个强大的模型来对其进行改进,这一模型基于之前所述的一系列准则, 能够创建任意类型的统计图形 1.导 ...
- Xshell实现Windows上传文件到Linux主机
我是怎么操作的: 1.打开一台本地Linux虚拟机,使用mount 挂载Windows的共享文件夹到Linux上,然后拷贝数据到Linux虚拟机里面:(经常第一步都不顺利,无法挂载Windows的文件 ...
- [HNOI2012]双十字
题目描述 在C 部落,双十字是非常重要的一个部落标志.所谓双十字,如下面两个例子,由两条水平的和一条竖直的”1“线段组成,要求满足以下几个限制: ![] 我们可以找到 5 个满足条件的双十字,分别如下 ...
- [BZOJ]1031 字符加密Cipher(JSOI2007)
持续划水中…… 感觉BZOJ上AC人数多的基本都是一些模板题,也就是某些算法的裸题.这些题目mark一下到时候回来复习也是不错的选择. Description 喜欢钻研问题的JS同学,最近又迷上了对加 ...
- [BZOJ]3672 购票(Noi2014)
革命尚未成功,同志还需努力. Description 今年夏天,NOI在SZ市迎来了她30周岁的生日.来自全国 n 个城市的OIer们都会从各地出发,到SZ市参加这次盛会. 全国的城市构成了一棵以SZ ...
- [bzoj1041][HAOI2008]圆上的整点
我能想得出怎么做才奇怪好吗 题解:http://blog.csdn.net/csyzcyj/article/details/10044629 #include<iostream> #inc ...
- 运行C++程序是出现错误:cannot open Debug/1.exe for writing
今天,打开VC6.0环境编了个小程序,谁知给我报了“cannot open Debug/1.exe for writing”这样一个错,然后,我就纳闷了,这是什么错丫? 想了半天,后想通,为什么会这样 ...