- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《测量程序设计》实验报告编写参考案例
测量程序设计
实验报告
(2012—2013学年第 2 学期)
实验名称: 《常用测量函数编写》实验
实验时间: 2013年3月15日
实验地点: 临潼9#205(机房)
指导教师: 陈宪冬
专业班级: 测绘工程1005
姓 名: 刁田田
学 号: 1010020502
西安科技大学测绘学院测绘系(教研室)
二〇一一年二月
一、实验目的
通过本次试验,复习C语言的基本语法和函数的编写技能,掌握测量常用函数编写技巧及其需要注意的问题,通过编码调试进一步加深和理解测量常用计算函数的数学模型和使用过程,并能编制的函数正确、实用。
二、实验内容
1.编写角度变弧度的函数
2.编写弧度变角度的函数
3.编写坐标正算函数
4.设计并编制对话框程序,实现简单的坐标正算。
三、实验平台
实验在测绘学院实验中心GIS实验室进行,使用GIS实验室的计算机,Microsoft Visual C++ 6.0软件平台进行编程调试。
四、实验成果
1.编写角度变弧度的函数
double CADlg::ang2hd(double ang)
{
if(ang0)
{
int du = int(ang);
int fen = int( (ang-du)*100 );
double miao = ((ang - du)*100 - fen)*100;
return ( du + fen/60. + miao/3600. )*TOPI;
}
if( ang0)
{
ang = fabs(ang);
int du = int(ang);
int fen = int( (ang-du)*100 );
double miao = ((ang - du)*100 - fen)*100;
double arc = ( du + fen/60. + miao/3600. )*TOPI;
return -arc;
}
return 0;
}
2.编写弧度变角度的函数
void CADlg::hudu2dfm(const double hudu, int *du, int *fen, double *miao)
{
double arc = 0.0;
if (hudu0) //isnagtive
{
arc = fabs(hudu);
double sec = (arc)*648000.0/PI;
*du = (int)(sec/3600.0);
*fen = (int)((sec-(*du)*3600.0)/60.0);
*miao = sec - (*du)*3600 - (*fen)*60;
*du = -*du;
}
else //positive
{
arc = hudu;
double sec = (arc)*648000.0/PI;
*du = (int)(sec/3600.0);
*fen = (int)((sec-(*du)*3600.0)/60.0);
*miao = sec - (*du)*3600 - (*fen)*60;
}
return;
}
CString CADlg::hd2ang(double hd)
{
int du, fen;
double miao;
hudu2dfm( hd, du, fen, miao);
CString str;
if (hd0) //isnagtive
{
double ang = (-du*10000 + fen*100 + miao)/10000. ;
str.Format( %10.6lf, ang);
str.TrimLeft();
str = - + str;
}
else //positive
{
double ang = (du*10000 + fen*100 + miao)/10000. ;
str.Format( %10.6lf, ang);
}
return str;
}
3.编写坐标正算函数
static double HDist(double x1,double y1,double x2,double y2)
{
double dx = x2 - x1;
double dy = y2 - y1;
return sqrt( dx * dx + dy * dy );
}
stati
文档评论(0)