#include "stdio.h"
#include "math.h"
double mathlog(double x);
void main(void)
{
double M1=0,M2=0,sum=0,x;
printf("Type x(0<x<=2^16)...\nx=");
bool req=true,ack=true,dataready=true;
while(ack&& dataready) //while循环实现握手协议功能
{
dataready=false;
scanf("%lf",&x);
while(x>0)
{
if(req)
{
req=false;
M1=mathlog(x);
ack=true;
}
if(ack)
{
req=true;
M2=mathlog(x+5);
ack=false;
}
sum=M1+M2;
printf("ln(%f)+ln(%f) = %f.\n",x,x+5,sum);
dataready=true;
ack=true;
break;
}
}
}
double mathlog(double x) //mathlog函数功能是通过泰勒级数展开实现求ln(x);
{
unsigned int i;
double ln1_x,pox,dlt;
if(x>-1.0 && x<=1.0) //实现x在(0 1)取值范围的ln(x)值
{
for(ln1_x=0.0,dlt=pox=i=1;fabs(dlt)>1.0e-6;i++)
{
dlt=(pox*=x)/i;
i&1 ? ln1_x+=dlt : ln1_x-=dlt;
}
printf("ln(%f) = %f.\n",x+1,ln1_x);
}
else if(x>1.0) // //实现x在(1 +00)取值范围的ln(x)值
{
x=1/x;
for(ln1_x=0.0,dlt=pox=i=1;fabs(dlt)>1.0e-8;i++)
{
dlt=(pox*=(x-1))/i;
i&1 ? ln1_x+=dlt : ln1_x-=dlt;
}
ln1_x=-ln1_x;
printf("ln(%f) = %f.\n",1/x,ln1_x);
}
else
{
printf("输入数据不在求值范围内,请重新输入");
}
return ln1_x;
}
泰勒级数展开求log(x)
2星 需积分: 41 51 浏览量
2015-07-31
19:59:59
上传
评论 3
收藏 799B ZIP 举报
qq_24076559
- 粉丝: 0
- 资源: 4
最新资源
- springboot-mavenBaseDemo 内容包含:springboot的maven基础状态,1.8JDK可以直接运行
- otis rsl远程串行接口协议标准.pdf
- buildx构建镜像时所需的镜像文件
- F103-霸道开发板2.8寸电阻触摸屏例程.rar
- Google(高德)地图瓦片python代码下载
- Python实现输出杨辉三角形
- polsarpro官方教程、操作说明 PolSARpro v5.0 Software Training Course
- STM32 TouchGFX的使用二图片显示
- buildx镜像文件,也可以通过网上其他方式获取
- 【中级软件设计师】上午题12-软件工程(2):单元测试、黑盒测试、白盒测试、软件运行与维护
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈