num4diff 0.5.3 → 0.5.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +11 -1
- data/lib/num4diff.rb +45 -8
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 1f22447667552b56f6587f9527db0b507d8aba23950b51c5c4147faf98cdfca2
|
4
|
+
data.tar.gz: b49d8659719af6ea4f61f19831788e386f3827aa7d1f6dbabe845a5ef9b3e093
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: eed61a4c91d4ae17b6e9e583377a27a00056fe3612d2ab8b7ed03800bce9912477dde0b2ab45284c8398c4aaf95caee8f0175a4e310c50c7f7897e8588ca74da
|
7
|
+
data.tar.gz: 31256c73dd2639ec3a6f412ba99675ae7dead4fe19274aa1c3a24ae50ed1ebb6755813ef79ed5e9db68c57b78bcea7f905310661ee4ebfff22ac72e0d931842f
|
data/CHANGELOG.md
CHANGED
@@ -2,7 +2,17 @@
|
|
2
2
|
|
3
3
|
## Unreleased
|
4
4
|
|
5
|
-
## [0.5.
|
5
|
+
## [0.5.5] - 2023-09-02
|
6
|
+
|
7
|
+
### Changed
|
8
|
+
- chg sample of yardoc
|
9
|
+
|
10
|
+
## [0.5.4] - 2023-08-29
|
11
|
+
|
12
|
+
### Changed
|
13
|
+
- chg add sample of yardoc
|
14
|
+
|
15
|
+
## [0.5.3] - 2023-07-02
|
6
16
|
|
7
17
|
### Fixed
|
8
18
|
- change bug for adamsBashforthMethod and adamsMoultonMethod.
|
data/lib/num4diff.rb
CHANGED
@@ -15,39 +15,60 @@ module Num4DiffLib
|
|
15
15
|
# @return [double] xiに対するyの値
|
16
16
|
callback :f, [:double], :double
|
17
17
|
|
18
|
-
#
|
19
18
|
# オイラー法による数値計算
|
19
|
+
#
|
20
20
|
# @overload eulerMethod(yi, xi, h, func)
|
21
|
-
# yi_1 = eulerMethod(yi, xi, h, func)
|
22
21
|
# @param [double] yi xiに対するyiの値
|
23
22
|
# @param [double] xi xiの値
|
24
23
|
# @param [double] h 刻み幅
|
25
24
|
# @param [callback] func xiに対する傾きを計算する関数
|
26
25
|
# @return [double] xi+hに対するyi_1の値
|
26
|
+
# @example
|
27
|
+
# yi = 1.0
|
28
|
+
# h = 0.001
|
29
|
+
# a = 1
|
30
|
+
# func = Proc.new{|x|
|
31
|
+
# 1.0 + a * x
|
32
|
+
# }
|
33
|
+
# yi_1 = Num4DiffLib::eulerMethod(yi, 0.0, h, func)
|
27
34
|
#
|
28
35
|
attach_function :eulerMethod,
|
29
36
|
:CNum4Diff_Tier_eulerMethod, [:double, :double, :double, :f], :double
|
30
|
-
#
|
31
37
|
# ホイン法による数値計算
|
38
|
+
#
|
32
39
|
# @overload heunMethod(yi, xi, h, func)
|
33
|
-
# yi_1 = heunMethod(yi, xi, h, func)
|
34
40
|
# @param [double] yi xiに対するyiの値
|
35
41
|
# @param [double] xi xiの値
|
36
42
|
# @param [double] h 刻み幅
|
37
43
|
# @param [callback] func xiに対する傾きを計算する関数
|
38
44
|
# @return [double] xi+hに対するyi_1の値
|
45
|
+
# @example
|
46
|
+
# yi = 1.0
|
47
|
+
# h = 0.001
|
48
|
+
# a = 1
|
49
|
+
# func = Proc.new{|x|
|
50
|
+
# 1.0 + a * x
|
51
|
+
# }
|
52
|
+
# yi_1 = Num4DiffLib::heunMethod(yi, 0.0, h, func)
|
39
53
|
#
|
40
54
|
attach_function :heunMethod,
|
41
55
|
:CNum4Diff_Tier_heunMethod, [:double, :double, :double, :f], :double
|
42
|
-
#
|
43
56
|
# 4次のルンゲ=クッタ法による数値計算
|
57
|
+
#
|
44
58
|
# @overload rungeKuttaMethod(yi, xi, h, func)
|
45
|
-
# yi_1 = rungeKuttaMethod(yi, xi, h, func)
|
46
59
|
# @param [double] yi xiに対するyiの値
|
47
60
|
# @param [double] xi xiの値
|
48
61
|
# @param [double] h 刻み幅
|
49
62
|
# @param [callback] func xiに対する傾きを計算する関数
|
50
63
|
# @return [double] xi+hに対するyi_1の値
|
64
|
+
# @example
|
65
|
+
# yi = 1.0
|
66
|
+
# h = 0.001
|
67
|
+
# a = 1
|
68
|
+
# func = Proc.new{|x|
|
69
|
+
# 1.0 + a * x
|
70
|
+
# }
|
71
|
+
# yi_1 = Num4DiffLib::rungeKuttaMethod(yi, 0.0, h, func)
|
51
72
|
#
|
52
73
|
attach_function :rungeKuttaMethod,
|
53
74
|
:CNum4Diff_Tier_rungeKuttaMethod, [:double, :double, :double, :f], :double
|
@@ -61,12 +82,20 @@ module Num4DiffLib
|
|
61
82
|
# @param [double] h 刻み幅
|
62
83
|
# @param [callback] func xiに対する傾きを計算する関数
|
63
84
|
# @return [double] [a,b]の積分値
|
85
|
+
# @example
|
86
|
+
# yi = 1.0
|
87
|
+
# h = 0.001
|
88
|
+
# a = 1
|
89
|
+
# func = Proc.new{|x|
|
90
|
+
# 1.0 + a * x
|
91
|
+
# }
|
92
|
+
# yi_1 = Num4DiffLib::adamsBashforthMethod(2, 0, 1, yi, h, func)
|
64
93
|
#
|
65
94
|
attach_function :adamsBashforthMethod,
|
66
95
|
:CNum4Diff_Multistage_adamsBashforthMethod, [:int, :double, :double, :double, :double, :f], :double
|
67
|
-
#
|
68
96
|
# アダムス・ムルトン法(k段)による数値計算
|
69
|
-
#
|
97
|
+
#
|
98
|
+
# @overload adamsMoultonMethod(k, a, b, y0, h, func)
|
70
99
|
# @param [int] k k段アダムス法
|
71
100
|
# @param [double] a 下限値
|
72
101
|
# @param [double] b 上限値
|
@@ -74,6 +103,14 @@ module Num4DiffLib
|
|
74
103
|
# @param [double] h 刻み幅
|
75
104
|
# @param [callback] func xiに対する傾きを計算する関数
|
76
105
|
# @return [double] [a,b]の積分値
|
106
|
+
# @example
|
107
|
+
# yi = 1.0
|
108
|
+
# h = 0.001
|
109
|
+
# a = 1
|
110
|
+
# func = Proc.new{|x|
|
111
|
+
# 1.0 + a * x
|
112
|
+
# }
|
113
|
+
# yi_1 = Num4DiffLib::adamsMoultonMethod(2, 0, 1, yi, h, func)
|
77
114
|
#
|
78
115
|
attach_function :adamsMoultonMethod,
|
79
116
|
:CNum4Diff_Multistage_adamsMoultonMethod, [:int, :double, :double, :double, :double, :f], :double
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: num4diff
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.5.
|
4
|
+
version: 0.5.5
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- siranovel
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-
|
11
|
+
date: 2023-09-02 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: ffi-compiler
|
@@ -69,7 +69,7 @@ licenses:
|
|
69
69
|
- MIT
|
70
70
|
metadata:
|
71
71
|
changelog_uri: http://github.com/siranovel/num4different/blob/main/CHANGELOG.md
|
72
|
-
documentation_uri: https://rubydoc.info/gems/num4diff/0.5.
|
72
|
+
documentation_uri: https://rubydoc.info/gems/num4diff/0.5.5
|
73
73
|
homepage_uri: http://github.com/siranovel/num4different
|
74
74
|
wiki_uri: https://github.com/siranovel/mydocs/tree/main/num4different
|
75
75
|
post_install_message:
|