本代码转载自:http://www.codeforge.cn/read/260028/keti_2d_b.c__html

#include
"udf.h"

#define Rho 1002

#define g 9.81

#define s 2.65

#define m 0.4

#define d 0.0005

#define C 2

#define N
1000

DEFINE_GRID_MOTION(wall_motion,domain,dt,time,dtime)

{

Thread
*tf=DT_THREAD(dt);

face_t
f;

Node
*v;

real
A[ND_ND];

real
area,wall_shear_force;

real
Theta_cr0,Phi,Gamma;

real
Theta[N]={0.0};

real
Theta_cr[N]={0.0};

real
X[N]={0.0};

real
Y[N]={0.0};

real
Qo[N]={0.0};

real
Delta_h[N]={0.0};

real
Delta_h_v[N]={0.0};

real
wall_shear_stress[N]={0.0};

real
X1,X2,Y1,Y2;

real
a,b,c,e,z1,z2,z3,z4,w1,w2,w3,w4,v1,v2,v3,v4,p1,p2,p3;

real
NV_VEC(Delta_y);

int
i,j,n;

i=0;

j=0;

X2=0;

Y2=0;

NV_D(Delta_y,=,0.0,0.0,0.0);

Theta_cr0=0.047;

Phi=(32.5+1.27*d*1000)/180;

SET_DEFORMING_THREAD_FLAG(THREAD_T0(tf));

begin_f_loop(f,tf)

{

i++;

j++;

F_AREA(A,f,tf);

area=NV_MAG(A);

wall_shear_force=F_STORAGE_R_N3V(f,tf,SV_WALL_SHEAR)[0];

wall_shear_stress[i]=wall_shear_force/area;

Theta[i]=fabs(wall_shear_stress[i])/(g*(s-1)*d*Rho);

}

end_f_loop(f,tf)

i=0;

begin_f_loop(f,tf)

{

i++;

f_node_loop(f,tf,n)

{

X1=X2;

Y1=Y2;

v=F_NODE(f,tf,n);

X2=NODE_X(v);

Y2=NODE_Y(v);

if(n!=0)

{

Gamma=atan(fabs(Y2-Y1)/fabs(X2-X1));

a=1-0.85*0.85*tan(Phi)*tan(Phi);

b=-sin(Gamma)+tan(Phi)*tan(Phi)*0.85*cos(Gamma);

c=sin(Gamma)*sin(Gamma)-tan(Phi)*tan(Phi)*cos(Gamma)*cos(Gamma);

e=tan(Phi)*(1-0.85*tan(Phi));

Theta_cr[i]=Theta_cr0*((sqrt(b*b-a*c)-b)/e);

}

}

}

end_f_loop(f,tf)

i=0;

begin_f_loop(f,tf)

{

i++;

if(Theta[i]>Theta_cr[i])

Qo[i]=12*sqrt(g*(s-1)*pow(d,3.0)*Theta[i])*(Theta[i]-Theta_cr[i]);

else

Qo[i]=0;

}

end_f_loop(f,tf)

i=1;

begin_f_loop(f,tf)

{

i++;

f_node_loop(f,tf,n)

{

v=F_NODE(f,tf,n);

if(n!=0)

{

X[i]=NODE_X(v);

Y[i]=NODE_Y(v);

}

}

}

end_f_loop(f,tf)

i=1;

begin_f_loop(f,tf)

{

i++;

if(i<j-1)

{

p1=(Qo[i+1]-Qo[i-1])/(2*(X[i+1]-X[i]));

p2=(Y[i+1]-Y[i-1])/(2*(X[i+1]-X[i]));

p3=(Y[i+1]-2*Y[i]+Y[i-1])/((X[i+1]-X[i])*(X[i+1]-X[i]));

if(wall_shear_stress[i]>0)

Delta_h[i]=dtime*(-p1+C*p1*p2+C*Qo[i]*p3)/(m-1);

else

Delta_h[i]=dtime*(p1+C*p1*p2+C*Qo[i]*p3)/(m-1);

}

}

end_f_loop(f,tf)

i=4;

begin_f_loop(f,tf)

{

i++;

f_node_loop(f,tf,n)

{

if(i<j-4)

{

z1=(X[i-2]+X[i-1])/2;

z2=(X[i-1]+X[i])/2;

z3=(X[i]+X[i+1])/2;

z4=(X[i+1]+X[i+2])/2;

w1=(X[i]-z2)*(X[i]-z3)*(X[i]-z4);

w2=(X[i]-z1)*(X[i]-z3)*(X[i]-z4);

w3=(X[i]-z1)*(X[i]-z2)*(X[i]-z4);

w4=(X[i]-z1)*(X[i]-z2)*(X[i]-z3);

v1=(z1-z2)*(z1-z3)*(z1-z4);

v2=(z2-z1)*(z2-z3)*(z2-z4);

v3=(z3-z1)*(z3-z2)*(z3-z4);

v4=(z4-z1)*(z4-z2)*(z4-z3);

Delta_h_v[i]=w1*Delta_h[i-2]/v1+w2*Delta_h[i-1]/v2+w3*Delta_h[i]/v3+w4*Delta_h[i+1]/v4;

}

}

}

end_f_loop(f,tf)

i=4;

begin_f_loop(f,tf)

{

i++;

f_node_loop(f,tf,n)

{

v=F_NODE(f,tf,n);

if(i>4&&NODE_POS_NEED_UPDATE(v)&&i<j-5)

{

NODE_POS_UPDATED(v);

Delta_y[1]=Delta_h_v[i];

NV_V(NODE_COORD(v),+=,Delta_y);

}

}

}

end_f_loop(f,tf)

}

应用fluent二维单向流泥沙冲刷作用下河床变形代码【转载】的更多相关文章

  1. HDU 3316 My Brute(二维费用流)经典

    My Brute Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  2. 关于TRIANGLE二维三角网格生成器在windows下的配置说明

    近期须要用到三角网格生成的一些东西,所以就把TRIANGLE这个库编译了一下,发现编译过程还是略微有些纠结,于是就想到写下来.希望以后有些童鞋看到少走一些弯路. 首先很感谢eryar的帮助,很感谢! ...

  3. java生成二维码(带logo)

    之前写过一篇不带logo的二维码实现方式,採用QRCode和ZXing两种方式 http://blog.csdn.net/xiaokui_wingfly/article/details/3947618 ...

  4. 利用phpqrcode二维码生成类库和imagecopymerge函数制拼接图片的经验

    前期准备 引入phpqrcode类库(下载地址:https://sourceforge.net/projects/phpqrcode/) PHP开启GD扩展库支持 1.利用phpqrcode生成二维码 ...

  5. Android应用--QR的生成(二维码)

    二维码的定义: 二维码(2-dimensional bar code),是用某种特定的几何图形按一定规律在平面(二维方向上)分布的黑白相间的图形记录数据符号信息的. 在许多种类的二维条码中,常用的码制 ...

  6. java 二维码生成

    直接上代码: 二维码生成核心类: package com.bbkj.wechat.tool; import java.awt.image.BufferedImage; import java.io.F ...

  7. 阐述二维码的原理以及使用google api和PHP QR Code来生成二维码

    一.什么是二维码:二维码 (2-dimensional bar code),是用某种特定的几何图形按一定规律在平面(二维方向上)分布的黑白相间的图形记录数据符号信息的.在许多种类的二维条码中,常用的码 ...

  8. java实现二维码的生成与解析

    简单介绍下二维码:二维码其实就是一种编码技术,只是这种编码技术是用在图片上了,将给定的一些文字,数字转换为一张经过特定编码的图片,而解析二维码则相反,就是将一张经过编码的图片解析为数字或者文字. 当然 ...

  9. Java生成二维码连接

    本文使用的是Goodge的zxing 添加maven依赖 <dependency> <groupId>com.google.zxing</groupId> < ...

随机推荐

  1. .NET中AOP实现

    静态织入,如:PostSharp(收费)动态织入1.使用Castle DynamicProxy不太方便的是需要在AOP的方法上加上virual关键字,配置较繁琐https://blog.csdn.ne ...

  2. 结合python实现的netcat与python实现的tcp代理,建立一个流量隧道

    在proxy中 python2 proxy.py 127.0.0.1 3334 192.158.1.111 80 true 作为服务器在本地3334端口进行监听, 作为客户端连接远程web服务器192 ...

  3. maven项目打包和编译跳过单元测试和javadoc

    代码中可能由于单元测试.注释(方法中的参数)或者maven javadoc插件的问题导致无法打包,影响工作,为避免这两种情况可以在打包时输入命令: mvn clean install -Dmaven. ...

  4. 什么是DDOS

    什么是DDOS?分布式拒绝服务攻击(Distributed Denial of Service).百度的解释有一个形象的例子我认为比较好理解,照搬如下:   一群恶霸试图让对面那家有着竞争关系的商铺无 ...

  5. sql根据一个表查询的数据作为条件查询另一个表

    代码格式如下: ) 要注意的是:in后面的查询语句必须是查询一个字段跟前面的表相对应的.比如要根据订单号orderID,OpenBills 这个表就需要查询到orderID这个字段,BillConsu ...

  6. [Docker][Hadoop]基于Docker1.12.3 搭建Hadoop 2.7.2 集群以及简单分析

    一 Hadoop简介 Hadoop 2.7.2 Doc refer to http://hadoop.apache.org/docs/r2.7.2/ HDFS (The following is a ...

  7. I2C总线、设备、驱动

    I2C总线.设备.驱动 框架 I2C驱动框架可分为3个部分,分别是:I2C核心层.I2C总线驱动层(适配器层)以及I2C设备驱动层: I2C核心层 提供了统一的I2C操作函数,主要有两套函数smbus ...

  8. python3 random

    一.random 1.生成伪随机数 2.伪随机数是可预测的,严格意义上不具有随机性质,通常用数学公式的方法(比如统计分布,平方取中等)获得 3.正如数列需要有首项,产生伪随机数需要一个初值用来计算整个 ...

  9. Mysql读写分离 及高可用高性能负载均衡实现

    什么是读写分离,说白了就是mysql服务器读的操作和写的操作是分开的,当然这个需要两台服务器,master负责写,slave负责读,当然我们可以使用多个slave,这样我们也实现了简单意义上的高可用和 ...

  10. thinkphp session跨域

    1 .在config.PHP中添加 'SESSION_OPTIONS'=>array('domain'=>'.caizhimofang.con'),//session配置    'COOK ...