UDF宏有兩種方式可以被Fluent所接受:編譯和解釋。其中有一些宏既可以被解釋也可以被編譯,而一些宏則只能被解釋。有一些場(chǎng)合只接受編譯后的UDF(如動(dòng)網(wǎng)格中的一些宏),而有些場(chǎng)合既可以接受編譯的UDF,還能接受解釋后的UDF。那么解釋型的UDF與編譯型的UDF到底存在何種差異?本文主要描述解釋型UDF,而編譯型UDF涉及到的問(wèn)題更多,我們留到下次再說(shuō)。
解釋型UDF不需要額外的編譯器,利用Fluent軟件自身即可解釋源代碼。在解釋過(guò)程中,UDF源代碼被C預(yù)處理器解釋成中間的,獨(dú)立于計(jì)算機(jī)體系之外的機(jī)器代碼。之后在調(diào)用UDF的過(guò)程中,這些被解釋器生成的機(jī)器代碼將在內(nèi)部仿真器或解釋器上被執(zhí)行。當(dāng)然,這種以解釋的方式運(yùn)行無(wú)可避免的會(huì)損失計(jì)算性能。但是以解釋方式運(yùn)行的UDF有個(gè)好處:其可以不加修改的在不同體系的計(jì)算機(jī)上、不同的操作系統(tǒng)以及不同的Fluent版本中運(yùn)行。
當(dāng)UDF的計(jì)算性能很重要時(shí),建議以編譯的形式運(yùn)行UDF。所有解釋型UDF都可以以編譯的方式被Fluent加載。
在UDF被解釋后保存cas文件,之后再打開cas文件時(shí),UDF能夠直接被加載,而無(wú)需重新解釋。
解釋型的最大優(yōu)勢(shì)是一次解釋,到處可以執(zhí)行,能夠跨平臺(tái)、跨架構(gòu)、跨操作系統(tǒng)、跨版本。但是解釋型UDF也存在其局限性。主要體現(xiàn)在:
在訪問(wèn)FLUENT求解器數(shù)據(jù)的方式上解釋式UDF也有限制。解釋式UDF不能直接訪問(wèn)存儲(chǔ)在FLUENT結(jié)構(gòu)中的數(shù)據(jù)。它們只能通過(guò)使用Fluent提供的宏間接地訪問(wèn)這些數(shù)據(jù)。另一方面,編譯式UDF沒(méi)有任何C編程語(yǔ)言或其它注意的求解器數(shù)據(jù)結(jié)構(gòu)的限制。
在Fluent中解釋UDF非常簡(jiǎn)單。通??刹捎靡韵虏襟E:
需要說(shuō)明的是,在網(wǎng)絡(luò)式多機(jī)并行Fluent中,用戶必須共享包含udf源文件、cas文件以及data文件的文件夾。具體共享方法為: 鼠標(biāo)右鍵選擇要共享的工作文件夾,選擇彈出菜單Sharing and Security,并選擇Share this folder。
彈出如下圖所示的對(duì)話框。
在彈出的文件選擇對(duì)話框中選擇UDF源文件。對(duì)話框中的其他參數(shù)一般情況下可保持默認(rèn)設(shè)置。
源文件解釋過(guò)程中,TUI窗口會(huì)有解釋信息。若有錯(cuò)誤的話,會(huì)出現(xiàn)錯(cuò)誤信息。
當(dāng)源代碼被解釋后,在相應(yīng)的GUI窗口中就可以看到被解釋的UDF了,此時(shí)可以選擇使用。