01
題目
由于西門子PLC本身并沒有帶求立方根的指令,我們用SCL來寫一個求立方根的FB塊。
02
分析
利用牛頓迭代法求立方根,通過迭代次數(shù)可以帶近正確的值,迭代次數(shù)越多,求出的值越準(zhǔn)確
利用牛頓迭代法可推導(dǎo)出求立方根公式如下
x = (2 * x + num / (x * x)) / 3.0
具體推導(dǎo)過程可參考網(wǎng)上搜索:C#求立方根牛頓迭代法。這里就不再詳細解釋了。有興趣的朋友 可以到網(wǎng)頁自行搜索了解
03
程序
X是被求數(shù),Y是結(jié)果,由于要不斷迭代,在此設(shè)置為INOUT類型
SCL程序:
程序大體就是根據(jù)上面2中推出出的公式來指導(dǎo)編程,利用FOR循環(huán)進行循環(huán)迭代次數(shù)。
在這里要強調(diào),由于迭代次數(shù)越多,會占用大量PLC掃描時間,所以,在實際應(yīng)用中,迭代次數(shù)盡量小于1000
在OB1中調(diào)用程序如下:
審核編輯:劉清
-
plc
+關(guān)注
關(guān)注
5007文章
13109瀏覽量
461470 -
SCL
+關(guān)注
關(guān)注
1文章
239瀏覽量
17025
原文標(biāo)題:西門子SCL語言編程系列講37-寫立方根FB塊
文章出處:【微信號:PLC 工控微課,微信公眾號:PLC 工控微課】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論