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

* Created on : 2017-5-30
17:12

* author :
硫酸亚铜

*需要在solution->Run
Calculation->Options勾选Data Sampling for Time
Statistics

*否则会报错

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

#include "udf.h"

#define FLUID_ID 7  / *需要计算平均值的计算域的ID*/

DEFINE_ON_DEMAND(averageValue)

{

#if !RP_HOST

Domain* domain = Get_Domain(1); / *获取计算域*/

Thread* t; 
/ *获取指针*/

cell_t
c;   /
*标定单元*/

#else

int i;  /
*用来循环计数*/

#endif

#if !RP_NODE

FILE *fp = NULL;   
/ *定义一个文件指针*/

char filename[] = "average.txt";   
/ *文件名*/

#endif

#if PARALLEL

int size;   /
*传递变量的数据,实际上计算节点上的单元数*/

real* pAverage;    
/ *pAverage表示压力平均*/

real* uAverage;    
/ *uAverage表示x方向的速度分量*/

real* vAverage;    
/ *vAverage表示y方向的速度分量*/

real* wAverage;    
/ *wAverage表示z方向的速度分量*/

real position[ND_ND];   /
*记录单元的位置*/

int pe; / *用来保存主机和计算节点*/

#endif

#if !RP_HOST

t = Lookup_Thread(domain, FLUID_ID);

#endif

#if !RP_NODE

if ((fp = fopen(filename, "w")) == NULL)   
/ *判断文件是否打开成功*/

Message("\n Warning: Unable to open %s for writing\n",
filename);   /
*文件打开失败*/

else

Message("\nWriting averageValue to %s...", filename);   /
*打开文件成功*/

#endif

#if !PARALLEL   /
*在串行情况下,输出文件*/

begin_c_loop(c, t)

fprintf(fp,

"average pressure:%g\n  \

The average velocity in the x direction is:%g \n \

The average velocity in the y direction is:%g \n \

The average velocity in the x direction is:%g \n", \

C_STORAGE_R(c, t, SV_P_MEAN) /  delta_time_sampled,
\

C_STORAGE_R(c, t, SV_U_MEAN) /  delta_time_sampled,
\

C_STORAGE_R(c, t, SV_V_MEAN) /  delta_time_sampled,
\

C_STORAGE_R(c, t, SV_W_MEAN) / 
delta_time_sampled);

end_c_loop(c,t)

#endif

#if RP_NODE

size=THREAD_N_ELEMENTS_INT(t);  / *得到分块计算域内单元的数目*/

pAverage = (real *)malloc(size * sizeof(real)); /
*为平均压力分配空间*/

uAverage = (real *)malloc(size * sizeof(real)); /
*速度在x方向分量的平均值分配空间*/

vAverage = (real *)malloc(size * sizeof(real)); /
*速度在y方向分量的平均值分配空间*/

wAverage = (real *)malloc(size * sizeof(real)); /
*速度在z方向分量的平均值分配空间*/

begin_c_loop_int(c, t)

{

pAverage[c] = C_STORAGE_R(c, t, SV_P_MEAN) / 
delta_time_sampled;   
/ *得到压力的平均值*/

uAverage[c] = C_STORAGE_R(c, t, SV_U_MEAN) / 
delta_time_sampled;   
/ *得到速度x方向的速度分量的平均值*/

vAverage[c] = C_STORAGE_R(c, t, SV_V_MEAN) / 
delta_time_sampled;   
/ *得到速度y方向的速度分量的平均值*/

wAverage[c]
= C_STORAGE_R(c, t, SV_W_MEAN) / 
delta_time_sampled;   
/ *得到速度z方向的速度分量的平均值*/

}

end_c_loop_int(c, t)

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

*判断是否是0计算节点

*当前节点为0计算节点,则pe为node_host,

*通过0计算节点向主机节点发送数据

*当前节点为非0计算节点,则pe为node_zero

*其他计算节点向0计算节点发送数据

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

pe = (I_AM_NODE_ZERO_P) ? node_host: node_zero;

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

*当前节点为0节点,则当前节点向主机发送数据

*当前节点为非0节点,则当前节点向0节点发送数据

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

PRF_CSEND_INT(pe, &size, 1, myid);

PRF_CSEND_REAL(pe, pAverage, size, myid);

PRF_CSEND_REAL(pe, uAverage, size, myid);

PRF_CSEND_REAL(pe, vAverage, size, myid);

PRF_CSEND_REAL(pe, wAverage, size, myid);

/ *发送数据以后,释放内存*/

free(pAverage);

free(uAverage);

free(vAverage);

free(wAverage);

if (I_AM_NODE_ZERO_P)   /
*如果是0计算节点*/

{

compute_node_loop_not_zero(pe)  / *循环非0节点*/

{

PRF_CRECV_INT(pe, &size, 1, pe);   
/ *0计算节点从其他计算节点接收各分块节点的单元数*/

pAverage = (real *)malloc(size * sizeof(real)); /
*为平均压力分配空间*/

uAverage = (real *)malloc(size * sizeof(real)); /
*速度在x方向分量的平均值分配空间*/

vAverage = (real *)malloc(size * sizeof(real)); /
*速度在y方向分量的平均值分配空间*/

wAverage = (real *)malloc(size * sizeof(real)); /
*速度在z方向分量的平均值分配空间*/

/ *0计算节点从其他计算节点接收各结算节点的单元对应的变量*/

PRF_CRECV_REAL(pe, pAverage, size, pe);

PRF_CRECV_REAL(pe, uAverage, size, pe);

PRF_CRECV_REAL(pe, vAverage, size, pe);

PRF_CRECV_REAL(pe, wAverage, size, pe);

PRF_CSEND_INT(node_host, &size, 1, myid);   /
*0计算节点将从各分块节点单元数发送给主机节点*/

/ *0计算节点将从其他计算节点接收各结算节点的单元对应的变量发送给主机节点*/

PRF_CSEND_REAL(node_host, pAverage, size, myid);

PRF_CSEND_REAL(node_host, uAverage, size, myid);

PRF_CSEND_REAL(node_host, vAverage, size, myid);

PRF_CSEND_REAL(node_host, wAverage, size, myid);

/ *释放内存*/

free((char *)pAverage);

free((char *)uAverage);

free((char *)vAverage);

free((char *)wAverage);

}

}

#endif

#if RP_HOST

compute_node_loop(pe)   /
*仅仅作为一个循环计数器的角色*/

{

/ *接收各节点的数据*/

PRF_CRECV_INT(node_zero, &size, 1, node_zero);

pAverage = (real *)malloc(size * sizeof(real));

uAverage = (real *)malloc(size * sizeof(real));

vAverage = (real *)malloc(size * sizeof(real));

wAverage = (real *)malloc(size * sizeof(real));

PRF_CRECV_REAL(node_zero, pAverage, size, node_zero);

PRF_CRECV_REAL(node_zero, uAverage, size, node_zero);

PRF_CRECV_REAL(node_zero, vAverage, size, node_zero);

PRF_CRECV_REAL(node_zero, wAverage, size, node_zero);

/ *将数据写入文件当中*/

for (i=0; i

fprintf(fp,

"Time Sampled(s):%g \

\naverage pressure:%g  
\

\nThe average velocity in the x direction is:%g  \

\nThe average velocity in the y direction is:%g  \

\nThe
average velocity in the x direction is:%g \n", \

delta_time_sampled, \

pAverage[i], \

uAverage[i], \

vAverage[i], \

wAverage[i]);

/ *释放内存*/

free(pAverage);

free(uAverage);

free(vAverage);

free(wAverage);

}

#endif

#if !RP_NODE

fclose(fp); / *关闭文件*/

Message("Done\n");  / *输出关闭文件完成*/

#endif

}

fluent计算输出时均值的更多相关文章

  1. tp5页面输出时,搜索后跳转下一页的处理

    tp5页面输出时,搜索功能在跳转下一页时,如果不做任何处理,会返回原有是第二页输出的数据.为了保证跳转下一页时输出的是搜索到的数据,做以下处理. (要根据自己的搜索字段进行适当修改) 页面js代码,给 ...

  2. Java数字格式化输出时前面补0

    Java数字格式化输出时前面补0 星期日 2014年11月30日|  分类: Java     /** * 里数字转字符串前面自动补0的实现. * */ public class TestString ...

  3. js小功能合集:计算指定时间距今多久、评论树核心代码、字符串替换和去除。

    1.计算指定时间距今多久 var date1=new Date('2017/02/08 17:00'); //开始时间 var date2=new Date(); //当前时间 var date3=d ...

  4. PHP根据秒计算持续时长

    /** * 计算持续时长 * * @param int $second 秒数 * @return string $duration 5天10小时43分钟40秒 */ function second2d ...

  5. C-C++字符输出时遇到字符'\n','\0'区别

    #include "iostream" #include "stdio.h" #include "stdio_ext.h" #include ...

  6. 用墨卡托和GPS坐标计算距离时误差测试

    iOS墨卡托和GPS坐标计算距离时误差测试,测试结果: 墨卡托和gps坐标来回转换没有误差. 墨卡托坐标计算出的距离比gps坐标计算出的距离大,100/92*100 = 108米,每100米多算出8米 ...

  7. C语言:计算输出给定数组中每相邻两个元素的平均值的平方根之和。

    //计算输出给定数组中每相邻两个元素的平均值的平方根之和. #include <stdio.h> #include <math.h> ]) { double a,b,s=0.0 ...

  8. 编写python程序读入1到100之间的整数,然后计算每个数出现的次数,输入0表示结束输人,输入数据不包括0。如果数出现的大现如果大于1,输出时使用复数times

    #-*- coding:UTF-8 -*- #环境:python3 print("Enter the numbers between 1 and 100:") enterList= ...

  9. Caffe学习系列(12):不同格式下计算图片的均值和caffe.proto

    均值是所有训练样本的均值,减去之后再进行训练会提高其速度和精度. 1.caffe下的均值 数据格式是二进制的binaryproto,作者提供了计算均值的文件compute_image_mean, 计算 ...

随机推荐

  1. python基础知识(七)---数据类型补充、"雷区"、编码

    数据类型补充."雷区".编码 1.数据类型补充 str: #字符串数据类型补充 s1=str(123) #常用于类型转换 print(s1) #capitalize()首字母大写 ...

  2. 设置断点调式 fiddler

    1. 用IE 打开博客园的登录界面  http://passport.cnblogs.com/login.aspx 2. 打开Fiddler,  在命令行中输入bpu http://passport. ...

  3. Linu如何查看磁盘占用情况及处理办法

    free -h: 查看当前剩余的内存大小 df: 查看文件系统磁盘使用率,可能free -h得到的剩余空间还有很多,但是df查询得到的部分文件系统磁盘使用率较高 当发现磁盘使用率较高的时候,可以: 先 ...

  4. tp5中在where中使用in

    $where = array(); $where['id'] = array('in', $uid_str); $res = $this->db2->name('user')->wh ...

  5. JAVA 容器配置 JVM 监控

    目前世面上较流行的JAVA容器工具有:tomcat,jboss,weblogic 在日常工作中,经常会遇到开发需要查看JVM相关信息,这时就需要开启JVM. 一.tomcat 1 修改jdk认证配置文 ...

  6. JS使用Cookie

    包:https://www.npmjs.com/package/js-cookie 一.安装 npm install js-cookie --save 二.引用 import Cookies from ...

  7. IDA7.0安装findcrypt插件

    效果图附上 安装成功的话,快捷键Ctrl+Alt+F可以调出上图的窗口,识别一些常见的算法,上面识别出是Base64加密 插件链接放上:https://github.com/polymorf/find ...

  8. Unity进阶之:MVC编程思想

    版权声明: 本文原创发布于博客园"优梦创客"的博客空间(网址:http://www.cnblogs.com/raymondking123/)以及微信公众号"优梦创客&qu ...

  9. 4、markdown基本语法

    一.前言 由于有些语法无法在博客园展示,推荐使用Typora解锁全套,下载地址:https://www.typora.io/ 推荐使用jupyter,使用方法:https://www.cnblogs. ...

  10. Dynamics 365 On-premises和Online 的不同

    1.新建账号的不同:on-premises(下文简称op)是和ad绑定的,所以必须先在ad中新建账号后才能在CRM中新建.而online是和Office365(下文简称O365)绑定的,所以需在O36 ...