这里我介绍一种比较简单的方法,首先我们从ANSYS
Fluent UDF
Manual上随便找一段正确的UDF,下面这段UDF取自ANSYS
18的ANSYS Fluent UDF Manual,位于2.3.23.3.
Example 1 - Pressure Profile

/
***********************************************************************

UDF
for specifying steady-state parabolic pressure profile
boundary

profile
for a turbine vane

************************************************************************/

#include
"udf.h"

DEFINE_PROFILE(pressure_profile,t,i)

{

real x[ND_ND]; / * this will hold the position vector */

real y;

face_t f;

begin_f_loop(f,t)

{

F_CENTROID(x,f,t);

y = x[1];

F_PROFILE(f,t,i) = 1.1e5 - y*y/(.0745*.0745)*0.1e5;

}

end_f_loop(f,t)

}

我们将上面的UDF源代码存为prepare.c

我们启动Fluent

然后我们直接编译我们刚才保存的prepare.c





















我们打开Visual
Studio(我是Visual Studio 2013英文版)















DLL的代码很简单,就是输出Hello
Fluent,这里有一点需要注意一下Solution
PlatForms一定要根据Fluent的位数来选择,默认是编译为Win32,而我们现在的一般使用的是64位的Fluent,所以我们需要改变为x64才行(见截图)

#include
/ *包含输入输出流头文件*/

using
namespace std;

/
*一定要这样写,以c语言的形式导出,在Fluent当中才能识别*/

extern
"C" __declspec(dllexport) void CppDynamicLinkLibrary()

{

cout << "Hello Fluent" << endl; / *输出“Hello
Fluent”*/

}





然后准备真实需要编译且加载了加载第三方动态链接库的UDF源文件,代码如下:

#include
"udf.h"

/
*链接我们刚才动态链接库的函数*/

extern
void CppDynamicLinkLibrary();

/
*******************************************

*我们在每次迭代完成以后,

*用动态链接库中的函数输出一次“Hello
Fluent”

********************************************/

DEFINE_ADJUST(my_adjust,d)

{

CppDynamicLinkLibrary(); / *调用动态链接库中的函数*/

}

将源代码也保存为prepare.c





































然后前面动态链接库项目文件夹下

















重新打开Fluent

导入网格,设置好各种求解参数

加载刚才编译的UDF(注意:此处只需要加载(Load),而不需要编译(Build)了!见截图)









求解运行算例

附:

makefile文件的注释说明

###########################################################

##

## Copyright 2003-2011 ANSYS, Inc.

## All Rights Reserved

##

###########################################################

#

# purpose:

#   
This file is the makefile for NT UDF builds.

#

# usage:

#   
Change file name 'makefile_nt.udf' to 'makefile'.

#   
Place the makefile file in the target dir.

#   
Place the helper file 'user_nt.udf' in same directory.

#   
Edit user_nt.udf file.

#   
Execute an 'nmake'  (no arguments
needed).

#

# notes:

#   
The user should not need to change this file.

#   
The following macros are expected to be in the user_nt.udf
file:

#     
SOURCES, VERSION, PARALLEL_NODE and USER_OBJECTS.

#   
The macro FLUENT_LIB is automatically defined here based on
VERSION

#     
and PARALLEL_NODE.

#   
Only this makefile and the helper file 'user_nt.udf' needs to
be

#     
the target dir, all other files are automatically
generated,

#     
and removed in an 'nmake clean'.

#   
The source file is expected in ..\..\src directory.

#   
Make sure the VC compiler is set up for command line mode,
use

#     
the file Vcvars32.bat from Visual Studio to assist this.

#   
This makefile uses the public domain program 'sed', make
sure

#     
sed is in your executable path.

#   
The '^' char in the SRC literal is a quote for the '\'
char,

#     
otherwise interpretted as a line continuation char.

#   
Use the 'nmake clean' command to restart builds.

###########################################################

#包含user_nt.udf文件

!INCLUDE user_nt.udf

# These need to be updated for each
release.

LIB_RELEASE=1800

RELEASE=18.0.0

# If a local path can be found, use it

!IF (("$(FLUENT_INC_LOCAL_RESERVED)" != "")
&& ("$(FLUENT_INC)" == ""))

FLUENT_INC =
$(FLUENT_INC_LOCAL_RESERVED)

!ENDIF

# it is assumed $(FLUENT_INC)is already
set.

!IF !DEFINED(FLUENT_INC)

!  ERROR You need to
define the environmental variable FLUENT_INC.

!ENDIF

!IF !DEFINED(FLUENT_ARCH)

!IF ("$(PROCESSOR_ARCHITECTURE)" ==
"ALPHA")

FLUENT_ARCH = ntalpha

!ENDIF

!IF ("$(PROCESSOR_ARCHITECTURE)" ==
"x86")

FLUENT_ARCH = ntx86

!ENDIF

!IF ("$(PROCESSOR_ARCHITECTURE)" ==
"AMD64")

FLUENT_ARCH = win64

!ENDIF

!IF ("$(PROCESSOR_ARCHITEW6432)" ==
"AMD64")

!  MESSAGE You seem to
be working on a 64-bit machine, but in a 32-bit build
environment.

!  MESSAGE If you really
want to build the UDF for the "ntx86" FLUENT_ARCH, then
please

!  MESSAGE set the
"FLUENT_ARCH" environment variable to "ntx86" before calling
this.

!  ERROR  
Aborting.

!ENDIF

!ENDIF

# set FLUENT_LIB based on VERSION macro

!IF (("$(VERSION)" == "2d") || ("$(VERSION)" ==
"3d") || \

("$(VERSION)" == "2ddp") || ("$(VERSION)" == "3ddp"))

FLUENT_LIB = fl$(LIB_RELEASE).lib

LIBS =
/Libpath:"$(FLUENT_INC)"\fluent$(RELEASE)\$(FLUENT_ARCH)\$(VERSION)

!ENDIF

!IF (("$(VERSION)" == "2d_host") || ("$(VERSION)"
== "3d_host") || \

("$(VERSION)" == "2ddp_host") || ("$(VERSION)" ==
"3ddp_host"))

COMM = net

FLUENT_LIB =  mport.lib
fl$(LIB_RELEASE).lib

LIBS =
/Libpath:"$(FLUENT_INC)"\fluent$(RELEASE)\$(FLUENT_ARCH)\$(VERSION) 
/Libpath:"$(FLUENT_INC)"\fluent$(RELEASE)\multiport\$(FLUENT_ARCH)\$(COMM)\shared

!ENDIF

!IF (("$(VERSION)" == "2d_node") || ("$(VERSION)"
== "3d_node") || \

("$(VERSION)" == "2ddp_node") || ("$(VERSION)" ==
"3ddp_node"))

!IF (("$(PARALLEL_NODE)" != "none") &&
("$(PARALLEL_NODE)" != "net"))

PARALLEL_NODE = mpi

!ENDIF

COMM = mpi

FLUENT_LIB =  mport.lib
fl_$(PARALLEL_NODE)$(LIB_RELEASE).lib

LIBS =
/Libpath:"$(FLUENT_INC)"\fluent$(RELEASE)\$(FLUENT_ARCH)\$(VERSION) 
/Libpath:"$(FLUENT_INC)"\fluent$(RELEASE)\multiport\$(FLUENT_ARCH)\$(COMM)\shared

!ENDIF

###########################################################

#定义变量SRC,其中^表示回车符成为字符串的一部分,其实就是表示字符串..\..\src\

SRC = ..\..\src^\

#使用vc的编译器

CC = cl

#CFLAGS用来指定头文件的路径

# compile flags

#  /c for compile
only,  /Za
for ansi c and __STDC__ is set

CFLAGS = /c /Za /DUDF_EXPORTING /DUDF_NT
/DWIN64

#目标文件为libudf.dll动态链接库

TARGET = libudf.dll

UDFDATA = udf_names.c

# generate object names from source
names

#".cpp=.obj"的意思是做一个替换

#把变量比如$CSOURCES,$SOURCES2,$SRC_OBJECT,$UDFDATA

#所有的[.cpp]的字符串转换为[.obj]字符串

SOURCES2 = $(CSOURCES:..\..\src\=)
#这里实际上就是test.c

SRC_OBJECT = $(SOURCES2:.cpp=.obj)
#这里实际上如果是cpp文件就是test.obj,否则默认不发生变化

SRC_OBJECT =
$(SRC_OBJECT:.c=.obj)#这里如果是c文件就是test.obj

UDF_OBJECT = $(UDFDATA:.c=.obj)  #这里实际上是udf_name.obj

OBJECTS = $(UDF_OBJECT) $(SRC_OBJECT)
$(USER_OBJECTS) #

#此处为包含的头文件

INCLUDES= -I. \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\$(FLUENT_ARCH)\$(VERSION)
\

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\main \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\addon-wrapper \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\io \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\species \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\pbns \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\numerics \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\sphysics \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\storage \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\mphase \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\bc \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\models \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\material \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\amg \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\util \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\mesh \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\udf \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\ht \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\dx \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\turbulence \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\parallel \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\etc \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\ue \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\dpm \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\src\dbns \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\cortex\src \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\client\src \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\tgrid\src \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\multiport\src \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\multiport\mpi_wrapper\src

GPU_LIB=

!IF ("$(GPU_SUPPORT)" == "on")
#如果开启了GPU加速,那么久将GPU的头文件也包含到INCLUDE里面,默认为off的

INCLUDES = $(INCLUDES) \

-I"$(FLUENT_INC)"\fluent$(RELEASE)\multiport\gpu_wrapper\include

GPU_LIB = OpenCL.lib

LIBS = $(LIBS)
/Libpath:"$(FLUENT_INC)"\fluent$(RELEASE)\multiport\gpu_wrapper\$(FLUENT_ARCH)\stub

!ENDIF

default:  
$(TARGET) #假想目标,每次更新$(TARGET)即libudf.dll

$(UDF_OBJECT): $(UDFDATA) #从udf_name.c编译生成目标文件udf_name.obj

$(CC) $(CFLAGS) $(INCLUDES)  $**

#采用cl编译器

替换(编译但不链接

禁用语言扩展
定义预处理器)
包含头文件
编译所有的文件

$(SRC_OBJECT): $(CSOURCES) #从test.c编译生成目标文件test.obj

@echo # Generating ud_io1.h

resolve.exe -udf $(CSOURCES) -head_file ud_io1.h

$(CC) $(CFLAGS) $(INCLUDES)  $**

#采用cl编译器

替换(编译但不链接

禁用语言扩展
定义预处理器)
包含头文件
编译所有的文件

$(TARGET): makefile user_nt.udf $(UDF_OBJECT)
$(SRC_OBJECT)  #生成目标文件libudf.dll

@echo # Linking $@ because of $?

link 
$(LIBS) /dll  
/out:$(TARGET) \   
#/dll表示生成dll文件

$(OBJECTS) 
$(FLUENT_LIB) $(GPU_LIB) #需要链接文件

$(UDFDATA): makefile $(SRC_OBJECT)

#自动生成udf_name.c文件

@echo # Generating $@ because of $?

@echo > $@

@echo >> $@

@echo #include "udf.h" >> $@

@echo #include "prop.h" >> $@

@echo #include "dpm.h" >> $@

@sed
-n "s/^ *\(DEFINE_[_A-Z]*(.*)\)/extern \1;/p" $(CSOURCES) >>
$@

@echo __declspec(dllexport) UDF_Data udf_data[] = { >>
$@

@sed
-n "s/^ *DEFINE_\([_A-Z]*\)( *\([_a-zA-Z0-9]*\).*)/\{\"\2\", (void
(*)(void))\2, UDF_TYPE_\1\},/p" $(CSOURCES) >> $@

@echo }; >> $@

@echo __declspec(dllexport) int n_udf_data =
sizeof(udf_data)/sizeof(UDF_Data); >> $@

@echo #include "version.h" >> $@

@echo __declspec(dllexport) void UDF_Inquire_Release(int *major,
int *minor, int *revision) >> $@

@echo { >> $@

@echo  
*major = RampantReleaseMajor; >> $@

@echo  
*minor = RampantReleaseMinor; >> $@

@echo  
*revision = RampantReleaseRevision; >> $@

@echo } >> $@

#清理输出文件

clean:

@del  *.dll
*.obj *.ilk *.exp *.lib *.pdb *.c

tellfluentarch:

@echo FLUENT_ARCH: $(FLUENT_ARCH)

@echo PROCESSOR_ARCHITECTURE: $(PROCESSOR_ARCHITECTURE)

@echo PROCESSOR_ARCHITEW6432: $(PROCESSOR_ARCHITEW6432)

$(OBJECTS): $(HSOURCES)

fluent加载第三方(C++,Fortan等)动态链接库的更多相关文章

  1. tp5 加载第三方扩展类库与手动加载的问题

    =============================================================== <?phpnamespace my; /*** 加载第三方类库*/ ...

  2. ArcGIS JS 4加载第三方矢量切片

        现在矢量切片越来越普及,对于地图渲染能更轻更快.ArcGIS JS 4.13可以实现加载第三方矢量切片,以下为代码示例,最下方是我之前切的建筑物数据.     当切片大小在1M左右,加载效果还 ...

  3. 13 —— node 获取文件属性 —— 加载第三方模块

    以加载第三方时间处理模块( moment )为例 : 一,加载 npm install moment 二,使用介绍 1,点击进入npm官网 https://www.npmjs.com/ 2,搜索 mo ...

  4. 菊花加载第三方--MBprogressHUD

    上次说到了网络请求AFN,那么我们在网络请求的时候,等待期间,为了让用户不认为是卡死或程序出错,一般都会放一个菊花加载,系统有一个菊花加载类叫UIProgressHUD.但是我今天要说的是一个替代它的 ...

  5. 菊花加载第三方--MBprogressHUD 分类: ios技术 2015-02-05 19:21 120人阅读 评论(0) 收藏

    上次说到了网络请求AFN,那么我们在网络请求的时候,等待期间,为了让用户不认为是卡死或程序出错,一般都会放一个菊花加载,系统有一个菊花加载类叫UIProgressHUD.但是我今天要说的是一个替代它的 ...

  6. thinkphp 3.2 加载第三方库 第三方命名空间库

    tp 自动加载的介绍: http://document.thinkphp.cn/manual_3_2.html#autoload 第三方库不规范库 不适用命名空间的库 可以使用import函数导入,其 ...

  7. swift -- 单例+ lazy懒加载 + 第三方库

    //工具类单例 static let goods : NHGoods = { let good = NHGoods() return good }() //懒加载 lazy var registerB ...

  8. maven 手动加载第三方jar、zip包

    使用maven搭建工程时,难免要加载大量的第三方的jar包.zip包比较少用,而maven的官网提供的jar往往不能满足需求,这时需要我们手动加载到我们本地或nexus私服的仓库中. 1.加载jar包 ...

  9. appcloud 加载第三方页面loading效果

    apiready = function() { var header = $api.byId('header'); $api.fixIos7Bar(header); var headerPos = $ ...

随机推荐

  1. HTML实用文本框样式

    输入框景背景透明: <input style="background:transparent;border:1px solid #ffffff"> 鼠标划过输入框,输入 ...

  2. log4j使用指北

    背景 工作一直使用日志组件,但是配置却一直看的糊里糊涂的,只记得个日志级别,其他的都不太理解,例如,一个页面日志太多,怎么样能单独打印?所以就找机会整理了一下. 本文参考:https://www.cn ...

  3. js正则表达式【续】(相关字符的解释含义)

    1.字符类[直接量] . (点号,小数点) 匹配任意单个字符,但是行结束符除外\d 匹配一个0-9之间的阿拉伯数字.等价于[0-9]\D    匹配任意一个不是0-9之间阿拉伯数字的字符.等价于[^0 ...

  4. 正则表达式修饰符 i、g、m、s、U、x、a、D、e 等。

    正则表达式中常用的模式修正符有i.g.m.s.U.x.a.D.e 等. 它们之间可以组合搭配使用. i 不区分(ignore)大小写: 例如: /abc/i 可以匹配 abc.aBC.Abc g 全局 ...

  5. 英语Bisynes商务

    英语bisynes商务概念的提出是改革的产物,有一个演变的过程:贸易部--商业部.外贸部--内贸部--内贸局--商务部.是内外贸一体化的概念. 中文名:商务 外文名:Business,Bisynes商 ...

  6. day 05 预科

    目录 文本处理 什么是文件 什么是文本 视频/音频文件(多媒体文件) 我们如何通过文本编辑器去控制txt文件 文本高级 文本处理+高级分析 文本处理 什么是文件 文件是操作系统提供的一个特殊概念,拿来 ...

  7. MySQL Replication--复制延迟03--Seconds_Behind_Master计算

    Seconds_Behind_Master计算原理 当从库上复制IO进程和复制SQL进程正常运行,且SQL线程处于执行状态而非等待IO进程同步BINLOG时,复制延迟时间计算如下: 复制延迟时间(Se ...

  8. PHP 接口输出 图片

    html: <img src="{eq name='v.miniqrcode' value=""}{:url('makeMiniQrcode_do')}?id={$ ...

  9. Flask入门很轻松(三)—— 模板

    Jinja2模板引擎 转载请在文章开头附上原文链接地址:https://www.cnblogs.com/Sunzz/p/10959471.html Flask内置的模板语言,它的设计思想来源于 Dja ...

  10. Docker04-镜像

    目录 镜像介绍 获取镜像 案例:获取 redis 5.0.0的镜像 查询本地镜像 搜索镜像 删除镜像 案例:删除redis:latest镜像 镜像加速 镜像介绍 镜像是Docker的三大核心概念之一. ...