日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Matlab控制精度

發布時間:2023/12/2 编程问答 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Matlab控制精度 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
控制精度

matlab控制運算精度用的是digits和vpa這兩個函數
digits用于規定運算精度,比如:

? digits(20);

? 這個語句就規定了運算精度是20位有效數字。但并不是規定了就可以使用,因為實際編程中,我們可能有些運算需要控制精度,而有些不需要控制。vpa就用于解決這個問題,凡是用需要控制精度的,我們都對運算表達式使用vpa函數。例如:
? digits(5);
? ? a=vpa(sqrt(2));
? 這樣a的值就是1.4142,而不是準確的1.4142135623730950488016887242097
又如:

? digits(5);

? ? a=vpa(sqrt(2));

? b=sqrt(2);

? 這樣a的值是1.4142,b沒有用vpa函數,所以b是1.4142135623730950488016887242097......

? vpa函數對其中每一個運算都控制精度,并非只控制結果。

? digits(11);

? a=vpa(2/3+4/7+5/9);

? b=2/3+4/7+5/9;

? a的結果為1.7936507936,b的結果為1.793650793650794......也就是說,計算a的值的時候,先對2/3,4 /7,5/9這三個運算都控制了精度,又對三個數相加的運算控制了精度。而b的值是真實值,對它取11位有效數字的話,結果為1.7936507937,與a不同,就是說vpa并不是先把表達式的值用matlab本身的精度求出來,再取有效數字,而是每運算一次,都控制精度。例子不太好,因為加法不太會增加數字位數。

總結

以上是生活随笔為你收集整理的Matlab控制精度的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。