Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1408285
  • 博文数量: 143
  • 博客积分: 10005
  • 博客等级: 上将
  • 技术积分: 1535
  • 用 户 组: 普通用户
  • 注册时间: 2006-10-23 17:25
个人简介

淡泊明志 宁静致远

文章分类

全部博文(143)

文章存档

2011年(2)

2009年(1)

2007年(22)

2006年(118)

我的朋友

分类: C/C++

2006-12-06 10:01:26

C语言库函数源代码】

【本程序在Dev C++ 4.9.9.2 下编译通过】

double atan2 (double x, double y)

{

   register double ret;

   __asm__(

      "fpatan\n\t"

      "fld %%st(0)"

      : "=t" (ret)

      : "0" (y), "u" (x)

   );

  

   return ret;

}//求x / y的反正切值。

 

double my_asin(double x)

{

   return atan2 (x, sqrt (1.0 - x * x));

}//求x的反正弦值。

int main()

{

   double a = 0.5;

   printf("asin(%f)    = %f\n",a,asin(a));

   printf("my_asin(%f) = %f\n",a,my_asin(a));

   a = -0.5;

   printf("asin(%f)    = %f\n",a,asin(a));

   printf("my_asin(%f) = %f\n",a,my_asin(a));

 

   system("pause");

   return 0;

}

阅读(3295) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~