UDF編譯錯(cuò)誤解決方法經(jīng)驗(yàn)之談
2017-02-21 by:CAE仿真在線 來(lái)源:互聯(lián)網(wǎng)
Fluent中UDF的存在無(wú)疑大大強(qiáng)化了其軟件功能和適用性。但UDF編譯易出現(xiàn)很多錯(cuò)誤,寫(xiě)這篇博文,全為經(jīng)驗(yàn)之談,可能一些解決方法FLUENT 的UDF幫助中已有提及。如果是 nmake 之類(lèi)的錯(cuò)誤,則必須重裝編譯器或者更改系統(tǒng)環(huán)境變量,參見(jiàn)本博客另外一篇博文。下述純針對(duì)已經(jīng)成功執(zhí)行過(guò)UDF的電腦而言。
1、Fatal Error:Access Violation
這是fluent編譯UDF過(guò)程中最常見(jiàn)的一個(gè)錯(cuò)誤。原因極多。就目前所知,列舉如下:
a、如果build和load都已成功,但在初始化的過(guò)程中出現(xiàn)此提示,則考慮是否引用了自定義內(nèi)存C_UDMI而忘記在case設(shè)置中釋放給Fluent充足的內(nèi)存空間??赏ㄟ^(guò) User-Defined---->Memory……查看賦予的自定義內(nèi)存?zhèn)€數(shù)。必須不少于udf中使用的 UDMI 個(gè)數(shù).
b、若在UDF中使用了時(shí)間相關(guān)變量,如CURRENT_TIME,CURRENT_TIMESTEP等,則計(jì)算中必須使用Unsteady模型。
c、在Fluent的結(jié)構(gòu)數(shù)據(jù)中,秉承domain, thread, c/f的順序。值得注意的是,一些數(shù)據(jù)僅僅在邊界處才有值,一些數(shù)據(jù)卻在邊界處不存在。當(dāng)調(diào)用了模型domain內(nèi)部的一個(gè)變量,而這個(gè)變量?jī)H在邊界處才會(huì)有,便會(huì)出現(xiàn)錯(cuò)誤。許多關(guān)于面的變量都是如此,如F_U.F_V F_W F_UDSI.當(dāng)然還有其他。
d、在自定義fluent中的對(duì)流項(xiàng)時(shí),常會(huì)用到許多面變量。面變量是最容易出錯(cuò)的地方。在fluent中的case邊界處,注意F_C1和F_C1_THREAD都是非法操作,因?yàn)榇颂幐静淮嬖赾1。
2、編譯過(guò)程中,有些系統(tǒng)變量明明已經(jīng)聲明類(lèi)型,但在Build時(shí)系統(tǒng)卻仍提示未聲明,或者有時(shí)候明明一句語(yǔ)句的末尾有分號(hào),系統(tǒng)卻一直提示缺少分號(hào),那么很有可能是在獲取區(qū)域指針的語(yǔ)句放得過(guò)于靠前。建議獲取區(qū)域指針的語(yǔ)句 Get_Domain(1)盡量往后放,最好下一句便要用到。
3、有時(shí)候,udf的編譯不成功和代碼本身無(wú)任何關(guān)系,僅是由于文件名稱取得過(guò)于復(fù)雜。建議永遠(yuǎn)不取復(fù)雜的文件名。
4、在FLUENT中的UDF宏中,有些宏并不被包含在udf.h中,需要另行包含。如果不在文件開(kāi)頭即 #include,系統(tǒng)將無(wú)法識(shí)別這些宏,便會(huì)報(bào)錯(cuò)
5、在一些情況下,可能會(huì)使用UDF寫(xiě)出部分?jǐn)?shù)據(jù)到指定文件中,經(jīng)檢測(cè),如果寫(xiě)出到不同的文件中不會(huì)出現(xiàn)編譯錯(cuò)誤,但在計(jì)算執(zhí)行過(guò)程中卻會(huì)中斷迭代。具體解決方法還未找到。目前建議是盡量寫(xiě)出到一個(gè)文件中去。
相關(guān)標(biāo)簽搜索:UDF編譯錯(cuò)誤解決方法經(jīng)驗(yàn)之談 Fluent培訓(xùn) Fluent流體培訓(xùn) Fluent軟件培訓(xùn) fluent技術(shù)教程 fluent在線視頻教程 fluent資料下載 fluent分析理論 fluent化學(xué)反應(yīng) fluent軟件下載 UDF編程代做 Fluent、CFX流體分析 HFSS電磁分析