用泰勒级数计算正弦值时出现的问题
Problems while calculating value of sine with Taylor series
我正在计算
使用以下代码。
#define PI 3.14
double ans;
double input1;
void toRad() {
input1 = input1 * PI / 180.0;
}
void sine(void) {
toRad();
ans = input1;
int i = 1;
for (; i < 15; i++) {
if (i % 2 == 0)
ans = ans + (ans * input1 * input1) / 2 * i * (2 * i + 1);
else
ans = ans - (ans * input1 * input1) / 2 * i * (2 * i + 1);
}
printf("%lf", ans);
}
我使用迭代运算而不是 pow
和阶乘函数来获得更精确的值和更多的迭代。
但是,出于某种原因,我得到了不同的输出,例如 -4000000E
。这段代码可能有什么问题?
你在写 logic.check 之前犯了一个小错误,直到 i=4。
if (i % 2 == 0)
ans = ans + (ans * input1 * input1) / 2 * i * (2 * i + 1);
else
ans = ans - (ans * input1 * input1) / 2 * i * (2 * i + 1);
而不是这个,你应该创建一个阶乘函数,这样它就可以被替换为
if (i % 2 == 0)
ans = ans + (ans * input1 * input1) / factorial(2 * i + 1);
else
ans = ans - (ans * input1 * input1) / factorial(2 * i + 1);
我正在计算
使用以下代码。
#define PI 3.14
double ans;
double input1;
void toRad() {
input1 = input1 * PI / 180.0;
}
void sine(void) {
toRad();
ans = input1;
int i = 1;
for (; i < 15; i++) {
if (i % 2 == 0)
ans = ans + (ans * input1 * input1) / 2 * i * (2 * i + 1);
else
ans = ans - (ans * input1 * input1) / 2 * i * (2 * i + 1);
}
printf("%lf", ans);
}
我使用迭代运算而不是 pow
和阶乘函数来获得更精确的值和更多的迭代。
但是,出于某种原因,我得到了不同的输出,例如 -4000000E
。这段代码可能有什么问题?
你在写 logic.check 之前犯了一个小错误,直到 i=4。
if (i % 2 == 0)
ans = ans + (ans * input1 * input1) / 2 * i * (2 * i + 1);
else
ans = ans - (ans * input1 * input1) / 2 * i * (2 * i + 1);
而不是这个,你应该创建一个阶乘函数,这样它就可以被替换为
if (i % 2 == 0)
ans = ans + (ans * input1 * input1) / factorial(2 * i + 1);
else
ans = ans - (ans * input1 * input1) / factorial(2 * i + 1);