hive 中某个字段等于0_为什么matlab中cos(pi/2) 不等于 0?

今天在使用matlab计算过程中,发生了一个很奇怪的事。当我让两个矩阵相乘时,本该为0的位置居然出现一段很长的分号表达式,如下图:

1a366a0c7c485090921ddae0e6660586.png

我左思右想,到底哪里出现了问题,一番摸索后,我发现A矩阵中的的数字有点不一样,为什么0要表示成0.000?于是我直接输入矩阵A,把0.000改为0重新计算,就获得想要的结果。

9bbf409a71ed90bb7bacd7e789f2bf08.png

我不禁思考,这是怎么回事呢?一顿摸索后,发现最终问题出现在cos(pi/2)这个函数。在matlab中我们输入cos(pi/2)获得的结果如下:

6d91e09dd55478a04fa1fac50be0869c.png

这个发现让我有点惊讶,于是我又输入了sin(pi/2)、cos(pi)、sin(pi)等函数,结过发现sin(pi)也不等于0。于是我去找度娘寻找答案,知道应该数据储存类型有关,计算结果存在一定误差。同时怎么样可以让结果显示为0呢?,我找到了一种解决办法。我们可以定义一个符号变量 pi,然后再运行cos(pi)就能得到想要的结果

38ae6c7e91766fd839028dc9ca7603bf.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
原创Matlab通过ODBC的方式调用数据库-CreateSchema.m 以下内容为Matlab文论坛会员,Godman原创。 如果需要转载,请联系Godman会员: 如有疑问可以邮件联系 tntuyh@163.com Godman 2009.3.30 晚 Good Luck! —————————————————————————————————————————— Matlab数据库编程指南-Godman Matlab与数据库链接有三种方法,本文只讲述其以ODBC的方式进行链接。 本文件包含四部分,其第三部分为我自己写的一些数据库函数操作的函数,第四部分为网上的一些资料。 第一部分:读取数据其相关信息查看 1.        配置数据源 “控制面板”----“管理工具”——“数据源(ODBC)”——“添加”——“创建数据源名称和选择数据库文件”(具体操作见GIF图片操作)。 2.        建立链接对象——database 调用格式: conna=database; 如conna=database;其SampleDB为上文创建的数据源名称,当默认情况下,数据库文件的username和password为空。 3.        建立并打开游标——exec 调用格式: curs=exec; 如curs=exec 其conna为上文链接对象,select * from database表示从表database选择所有的数据. 4.        把数据库的数据读取到Matlab——fetch 调用格式: curs=fetch; Data=curs.Data;%把读取到的数据用变量Data保存. 如curs=fetch; 把所有的数据一次全部读取到Matlab,RowLimit为每次读取的数据参数的行数,默认为全部读取,但是全部读取会很费时间(和计算机性能很大关系)。 上述四点是matlab从数据库文件读取数据到matlab的基本步骤。 5.        数据返回类型 从数据库读取数据到matlab有三种数据类型(默认为元胞类型cellarray),分别为元胞类型(cellarray),数字型(numeric),结构型(structure)。可以在链接数据库之前通过setdbprefs函数来进行设置。如果数据库文件全部是数值型数据时最好采用numeric型的数据,这样可以使得读取速度大幅提高,特别是在大型数据读取时非常明显。我曾经从数据库读取过100万个数据,用cellarray时用了16s,但是用numeric时却只用了8s,速度提高很大啊,对电脑配置不好的来说,很有帮助的。(还有我的电脑很烂,1.3GHz,384M内存,可能让大家见笑了…….) 调用格式: setdbprefs 6.        养成良好习惯,随手关闭链接对象和游标——close 当不再使用数据库的链接对象时要及时关闭,这样才能及时的释放出内存,而且每次链接后所需要的内存量是非常大的,要是不及时关闭的话对后续计算的影响将非常非常的大。 调用格式: close close 7.        查看数据相关信息 Rows-查看数据行数 调用格式:numrows=rows Cols——查看数据列数 调用格式:numcols=cols Attr——查看数据属性 调用格式:attribute=attr
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值