标题:高手帮忙看看。。。。。。。
只看楼主
yuki
Rank: 2
等 级:新手上路
威 望:5
帖 子:508
专家分:0
注 册:2005-2-4
 问题点数:0 回复次数:0 
高手帮忙看看。。。。。。。

#include <iostream> #include <cmath>

using namespace std;

const double epsilon = 1E-14; const double PI = 3.141592653589793;

double factorial(int n); double dbl_factorial(int n); double arcsin(double x); double rad2deg(double x); double max(double x,double y); bool approx_equal(double x,double y);

int main() { //测试驱动 for (double i = -1 ; i <= 1; i += 0.2) { cout << rad2deg(arcsin(i)); if (approx_equal(i,sin(arcsin(i)))) { cout << " approx equal!" << endl; } else { cout << " not equal!" << endl; } } return 0; }

double factorial(int n) { //阶乘 double result = 1; if (n == 0) return 1;

for (int i = 1 ; i <= n; i++) { result *= i; }

return result; }

double dbl_factorial(int n) { //奇数的双阶乘 double result = 1; int i = n; if (n % 2 == 0) return 0; if (n == 1) return 1;

do { i -= 2; result *= i; } while ( i > 1);

return result; }

double arcsin(double x) { //反正弦函数的泰勒级数公式 double xnew; int i = 1; double result = 0;

if (x < -1 || x > 1) return -255; do { xnew = (pow(x,i) * pow(dbl_factorial(i),2)) / (1.0 * factorial(i)); result += xnew; i += 2; } while (xnew > epsilon);

return result; }

double rad2deg(double x) { //弧度转成角度 return x / PI * 180; }

double max(double x,double y) { //两数最大值 //数学库中居然没有,真是晕。。。。 return x > y ? x : y; }

bool approx_equal(double x,double y) { if (x == 0 && y != 0) return fabs(y) <= epsilon; if (y == 0 && x != 0) return fabs(x) <= epsilon; if (x == 0 && y == 0) return true; return fabs(x - y) / max(fabs(x),fabs(y)) <= epsilon; } 为什么有一半以上的计算得的反正弦值不能精确的用sin函数还原???为什么精度差那么多。。。。请高手赐教,谢谢。。。。。。

搜索更多相关主题的帖子: double int arcsin epsilon 
2005-02-04 11:51



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-11985-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.529933 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved