欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

计算曲线与坐标轴的面积

程序员文章站 2022-07-02 15:14:13
根据坐标点,计算曲线与坐标轴的面积。 1. trapz函数 利用梯度规则(Trapezoidal rule)求解积分。 2. simps函数 利用辛普森积分法(Simpson's rule),以二次曲线逼近的方式取代矩形或梯形积分公式,以求得定积分的数值近似解。 3. 利用多边形求解 利用Shoel ......

 根据坐标点,计算曲线与坐标轴的面积。

import numpy as np
import matplotlib.pyplot as plt
x = np.arange(0,1,0.001)
y = np.sqrt(1-x**2)
plt.close('all')
plt.plot(x, y)
plt.show()

 

 计算曲线与坐标轴的面积

1. trapz函数

利用梯度规则(trapezoidal rule)求解积分。

from numpy import trapz
trapz(y, x, dx=0.001)

2. simps函数

利用辛普森积分法(simpson's rule),以二次曲线逼近的方式取代矩形或梯形积分公式,以求得定积分的数值近似解。

from scipy.integrate import simps
simps(y, x, dx=0.001)

 

3. 利用多边形求解

def polyarea(x,y):
    return 0.5*np.abs(np.dot(x,np.roll(y,1))-np.dot(y,np.roll(x,1)))
polyarea(np.append(x, 0), np.append(y, 0))

 利用shoelace formula,可以理解为是把每个顶点向x轴做垂线,每个边和坐标轴构成的梯形面积矢量和,结果就是多边形面积。也可理解为用最大矩形的面积减去各个三角形面积得到中间的多边形面积。