前言:

前些日子,因为工作原因,接触到了求解曲线周长,真的是搞了很久,学生时代真的很简单,但是如今的我来说,忘记了....很多人跟我应该一样。

所以来巩固加强一下记忆。一开始的时候,求周长嘛,找公式呗,什么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# 定积分求周长&面积原理 代码实现的更多相关文章

  1. c++-面向对象类的示例-求周长面积,判断体积相等-文件操作和一般操作

    面向对象编程示例:求周长和面积 #define _CRT_SECURE_NO_WARNINGS #include <iostream> using namespace std; //圆的周 ...

  2. 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( ...

  3. 按要求编写一个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 ...

  4. C#使用多态求方形面积周长和圆的面积周长

    class class1 { public static void Main(string[] args) { //使用多态求矩形面积与周长和圆的面积与周长 Shape cl = ); double ...

  5. java求三角形面积以及周长---封装

    /*时间: 2012-10-08作者: 烟大程序要求: 1.封装一类三角形对象Triangle,该类对象具有三条边的属性, 具有初始化三角形的功能.修改边长的功能.判断三条边能否构成三角形的功能. 求 ...

  6. 微信群里一道六年级数学题,求阴影面积,那我只能用python代码了

    前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取http ...

  7. 编写一个Shape类,具有属性:周长和面积; 定义其子类三角形和矩形,分别具有求周长的方法。 定义主类E,在其main方法中创建三角形和矩形类的对象, 并赋给Shape类的对象a、b,使用对象a、b来测试其特性。

    package shape; public class Shape { //定义成员变量 private double zhouchang; private double mianji; public ...

  8. UVa 11437:Triangle Fun(计算几何综合应用,求直线交点,向量运算,求三角形面积)

    Problem ATriangle Fun Input: Standard Input Output: Standard Output In the picture below you can see ...

  9. (1)定义闭合图形抽象类ClosedFigure定义属性:1.形状;2.定义构造方法,给形状赋值;3.定义两个抽象方法:计算面积和计算周长;4.定义一个显示方法:显示图像形状,周长,面积;

    题目显示不全,完整题目描述: (1)定义闭合图形抽象类ClosedFigure定义属性:1.形状:2.定义构造方法,给形状赋值:3.定义两个抽象方法:计算面积和计算周长:4.定义一个显示方法:显示图像 ...

随机推荐

  1. Linux:crontab组件部署linux定时任务

    crontab简介 crond 是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务 工具,并且会自动启动c ...

  2. Eclipse中JavaSwing图形插件安装

    1.在百度中搜索WindowBuilder,找到http://www.eclipse.org/windowbuilder/ 2.点击Download调转到页面: 因为我的eclipse版本是 3.点击 ...

  3. .Net中Web增加加密狗管理

    由于业务中最近需要使用到加密狗,增加对Web代码的管控,所以需要进行加密狗使用的研究 首先,对于没有接触使用过加密狗的人需要有个大致的认识,加密狗分为 MasterDog, 1.下载加密狗的开发套件, ...

  4. Java集合框架的四个接口

    接口 [四个接口  collection  list  set  map 的区别] collection 存储不唯一的无序的数据 list 存储有序的不唯一的数据 set   存储无序的唯一的数据 m ...

  5. 用js来实现那些数据结构06(队列)

    其实队列跟栈有很多相似的地方,包括其中的一些方法和使用方式,只是队列使用了与栈完全不同的原则,栈是后进先出原则,而队列是先进先出(First In First Out). 一.队列    队列是一种特 ...

  6. DDCTF 2018线上赛writeup

    第一题: d4e8e1f4a0f7e1f3a0e6e1f3f4a1a0d4e8e5a0e6ece1e7a0e9f3baa0c4c4c3d4c6fbb9b2b2e1e2b9b9b7b4e1b4b7e3e ...

  7. seacms6.5 注入漏洞1

    ---恢复内容开始--- 需要开启/data/admin/isapi.txt   ,当里面的数值为1时,就可以报错注入 存在漏洞的页面:zyapi.php function cj() { global ...

  8. [HNOI 2011]数矩形

    Description 题库链接 给出平面上 \(n\) 个点,选出四个点作为矩形顶点.求出矩形最大面积. \(1\leq n\leq 1500\) Solution 转载自 Z-Y-Y-S dark ...

  9. [SDOI2017]数字表格

    Description Doris刚刚学习了fibonacci数列.用f[i]表示数列的第i项,那么 f[0]=0 f[1]=1 f[n]=f[n-1]+f[n-2],n>=2 Doris用老师 ...

  10. [AHOI2005]洗牌

    题目描述 为了表彰小联为Samuel星球的探险所做出的贡献,小联被邀请参加Samuel星球近距离载人探险活动. 由于Samuel星球相当遥远,科学家们要在飞船中度过相当长的一段时间,小联提议用扑克牌打 ...