- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为了获得更多使用C++的实践,我决定不使用数学库就做一些基本的数学函数。我已经完成了功能和阶乘功能,它们似乎运行良好。但是,我的泰勒级数余弦函数存在很多问题。
Wikipedia Cosine Taylor Series
它在cos(1),cos(2)处输出良好的近似值,并在cos(3)和cos(4)处开始失去精度。除此之外,它的答案变得完全错误。以下是来自./a.out的结果
Input an angle in radians, output will be its cosine
1
Output is: 0.540302
Input an angle in radians, output will be its cosine
2
Output is: -0.415873
Input an angle in radians, output will be its cosine
3
Output is: -0.974777
Input an angle in radians, output will be its cosine
4
Output is: -0.396825 <-------------Should be approx. -0.654
Input an angle in radians, output will be its cosine
5
Output is: 2.5284 <-------------Should be approx. 0.284
#include <iostream>
#include <iomanip>
using std::cout;
using std::cin;
using std::endl;
int factorial(int factorial_input) {
int original_input = factorial_input;
int loop_length = factorial_input - 1;
if(factorial_input == 1 || factorial_input == 0) {
return 1;
}
for(int i=1; i != loop_length; i++) {
factorial_input = factorial_input - 1;
original_input = original_input * factorial_input;
}
return original_input;
}
double power(double base_input, double exponent_input) {
double power_output = base_input;
if(exponent_input == 0) {
return 1;
}
if(base_input == 0) {
return 0;
}
for(int i=0; i < exponent_input -1; i++){
power_output = power_output * base_input;
}
return power_output;
}
double cos(double user_input) {
double sequence[5] = { 0 }; //The container for each generated elemement.
double cos_value = 0; //The final output.
double variable_x = 0; //The user input x, being raised to the power 2n
int alternating_one = 0; //The (-1) that is being raised to the nth power,so switches back and forth from -1 to 1
int factorial_denom = 0; //Factorial denominator (2n)!
int loop_lim = sizeof(sequence)/sizeof(double); //The upper limit of the series (where to stop), depends on size of sequence. Bigger is more precision.
for(int n=0; n < loop_lim; n++) {
alternating_one = power(-1, n);
variable_x = power(user_input, (n*2));
factorial_denom = factorial((n*2));
sequence[n] = alternating_one * variable_x / factorial_denom;
cout << "Element[" << n << "] is: " << sequence[n] << endl; //Prints out the value of each element for debugging.
}
//This loop sums together all the elements of the sequence.
for(int i=0; i < loop_lim; i++) {
cos_value = cos_value + sequence[i];
}
return cos_value;
}
int main() {
double user_input = 0;
double cos_output;
cout << "Input an angle in radians, output will be its cosine" << endl;
cin >> user_input;
cos_output = cos(user_input);
cout << "Output is: " << cos_output << endl;
}
Input an angle in radians, output will be its cosine
1
Element[0] is: 1
Element[1] is: -0.5
Element[2] is: 0.0416667
Element[3] is: -0.00138889
Element[4] is: 2.48016e-05
Element[5] is: -2.75573e-07
Element[6] is: 2.08768e-09
Element[7] is: -7.81894e-10
Element[8] is: 4.98955e-10
Element[9] is: 1.11305e-09
Element[10] is: -4.75707e-10
Element[11] is: 1.91309e-09
Element[12] is: -1.28875e-09
Element[13] is: 5.39409e-10
Element[14] is: -7.26886e-10
Element[15] is: -7.09579e-10
Element[16] is: -4.65661e-10
Element[17] is: -inf
Element[18] is: inf
Element[19] is: -inf
Output is: -nan
最佳答案
您有以下问题:
在图中,您显示的是图片k
包含在总和中,而您将其排除在代码中。因此,Desmos图中的k=5
等于您代码中的double sequence[6] = { 0 }
。
这将修复user_input = 4
的输出。
然后,对于user_input = 5
,您可以将其与图表进行比较,以查看它也给出了相似的结果(与真实值相差很远)
然后,您将遇到大量术语的错误,因为阶乘函数输出int
,但是阶乘增长得如此之快,以至于int
可以快速容纳的值超出了范围,并且很快超出了任何范围整数类型。如果要支持(尽管不是很多)更大的输入范围,则应返回double
并将original_input
也设置为double
。
在power
中,您将指数作为double
,但是将其当作整数使用。特别是将它用于循环迭代的限制。只要这些值足够小以可由double
准确表示,就可以正常工作。一旦值变大,循环迭代次数将变得不精确。
请使用int
作为power
的第二个参数。
如果要用这种方法实现cos
,通常首先要使用cos
对称性,以将范围缩小到较小的范围,例如首先使用例如[0,pi/2]
该cos(x + 2pi) = cos(x)
和cos(x+pi) = - cos(x)
以及cos(-x) = cos(x)
等。
关于c++ - C++-使用泰勒级数逼近估算cos(x),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59230783/
考虑函数 y=1/((1-x^5)(1-x^7)(1-x^11)) WolframAlpha 在几秒钟内计算出 MacLaurin 级数展开的前 1000 个元素: https://www.wolfr
(C) 计算序列 y = x - x3/3! + x5/5! - x7/7! + ..... 其中停止标准是 | xi/i! | #include int fact(int x){ if(x
我是一名优秀的程序员,十分优秀!