fixed dependencies
This commit is contained in:
96
vendor/github.com/nuknal/goNum/IntegralCompositeNewtonCotes.go
generated
vendored
Normal file
96
vendor/github.com/nuknal/goNum/IntegralCompositeNewtonCotes.go
generated
vendored
Normal file
@@ -0,0 +1,96 @@
|
||||
// IntegralCompositeNewtonCotes
|
||||
/*
|
||||
------------------------------------------------------
|
||||
作者 : Black Ghost
|
||||
日期 : 2018-12-12
|
||||
版本 : 0.0.0
|
||||
------------------------------------------------------
|
||||
1-8级复化Newton-Cotes求积分公式
|
||||
理论:
|
||||
对于积分
|
||||
b n
|
||||
|f(x)dx ~= Sum Ak*f(xk)
|
||||
a k=0
|
||||
|
||||
(n)
|
||||
Ak = (b-a)C
|
||||
k
|
||||
|
||||
(n) (-1)^(n-k) n
|
||||
C = ------------ |t(t-1)(t-2)...(t-(k-1))(t-(k+1))...(t-n)dt
|
||||
k k!(n-k)!n 0
|
||||
|
||||
特别的,n=1为复化梯形公式;
|
||||
n=2为复化Simpson(辛浦生)公式;
|
||||
n=4为复化Cotes(科特斯)公式
|
||||
|
||||
将区间[a, b]等分为Nn个子区间,每个子区间上使用Newton-Cotes求积分公式
|
||||
|
||||
参考 李信真, 车刚明, 欧阳洁, 等. 计算方法. 西北工业大学
|
||||
出版社, 2000, pp 155-156.
|
||||
------------------------------------------------------
|
||||
输入 :
|
||||
fun 被积分函数
|
||||
a, b 积分范围
|
||||
n Newton-Cotes公式级数
|
||||
Nn 子区间数
|
||||
输出 :
|
||||
sol 解
|
||||
err 解出标志:false-未解出或达到步数上限;
|
||||
true-全部解出
|
||||
------------------------------------------------------
|
||||
注意 :
|
||||
由于误差得不到有效控制,稳定性无法保证,故而并不是n值越
|
||||
大越好,实际应用中很少使用n值较大的Newton-Cotes公式
|
||||
------------------------------------------------------
|
||||
*/
|
||||
|
||||
package goNum
|
||||
|
||||
// IntegralCompositeNewtonCotes 1-8级复化Newton-Cotes求积分公式
|
||||
func IntegralCompositeNewtonCotes(fun func(float64) float64, a, b float64, n, Nn int) (float64, bool) {
|
||||
/*
|
||||
1-8级复化Newton-Cotes求积分公式
|
||||
输入 :
|
||||
fun 被积分函数
|
||||
a, b 积分范围
|
||||
n Newton-Cotes公式级数
|
||||
Nn 子区间数
|
||||
输出 :
|
||||
sol 解
|
||||
err 解出标志:false-未解出或达到步数上限;
|
||||
true-全部解出
|
||||
*/
|
||||
//判断n
|
||||
if (n < 1) || (n > 8) {
|
||||
panic("Error in goNum.IntegralNewtonCotes: n is not correct")
|
||||
}
|
||||
//判断a, b
|
||||
if a == b {
|
||||
return 0.0, true
|
||||
}
|
||||
//判断Nn
|
||||
if Nn < 1 {
|
||||
panic("Error in goNum.IntegralNewtonCotes: Nn is less than one")
|
||||
} else if Nn == 1 {
|
||||
return IntegralNewtonCotes(fun, a, b, n)
|
||||
}
|
||||
|
||||
var sol float64
|
||||
var err bool = false
|
||||
|
||||
//子区间长度
|
||||
Hh := (b - a) / float64(Nn)
|
||||
|
||||
//调用IntegralNewtonCotes循环累加
|
||||
for i := 1; i < Nn+1; i++ {
|
||||
soltemp, errtemp := IntegralNewtonCotes(fun, a+Hh*float64(i-1), a+Hh*float64(i), n)
|
||||
if errtemp != true {
|
||||
panic("Error in goNum.IntegralNewtonCotes: Error in calling IntegralNewtonCotes")
|
||||
}
|
||||
sol += soltemp
|
||||
}
|
||||
|
||||
err = true
|
||||
return sol, err
|
||||
}
|
||||
Reference in New Issue
Block a user