|
[Sponsors] |
Define Profile, time dependent flow variation query |
|
LinkBack | Thread Tools | Search this Thread | Display Modes |
February 11, 2013, 08:35 |
Define Profile, time dependent flow variation query
|
#1 |
New Member
Simon DeSmet
Join Date: Feb 2013
Posts: 3
Rep Power: 13 |
Hello
I'm trying to send a wave down a tank/conduit that is 100m long and 5x5m and filled with 1m of water. To do this im using a UDF to vary the flow at the input face of the tank (one end). essentially all the UDF is supposed to do is check the time, as an if statement to the effect of; if the time is greater than A, but less than B, then set input mass kg/s to x, else set input mass kg/s to y. This is my first attempt at using fluent or indeed any CFD and im having problems getting it working. I've written two UDFs; one that just inputs a constant flow. I figured if i could get it working at least i would know the basic syntax etc. And one that inputs a wave/flow rise and decline. The first UDF does load in to fluent but doesnt produce the desired result (i don't get any water flowing down the tank), the second wont load as there are syntax issues with the If statement (im not a very experienced programmer and no little about c). heres my code, can any one give me some pointers? ============ UDF 1 a constant flow #include “udf.h” DEFINE_PROFILE(constant_in, t, nv) { real x[ND_ND]; real v; face_t f; begin_f_loop(f,t) { F_CENTROID(x,f,t); v=2; F_PROFILE(f,t,nv) =v; } end_f_loop(f,t) #include “udf.h” DEFINE_PROFILE(wave_in, t, nv) { real x[ND_ND]; real v =5; face_t f; real T; real a =2; real b=4; begin_f_loop(f,t) { F_CENTROID(x,f,t); T=RP_Get_real(“flow-time”); if (T>=a, T<=b); { F_PROFILE(f,t,nv) =v; } else { F_PROFILE(f,t,nv) =2; } } end_f_loop(f,t) } |
|
February 15, 2013, 11:45 |
similar
|
#2 |
Member
Nick Cleveland
Join Date: Mar 2012
Posts: 35
Rep Power: 14 |
Hi SDesmond,
I'm trying to do the same thing: have the UDF "turn on" at a certain time in the simulation, with IF statements. Here is my UDF, which seemed to turn on at right time. notice the 1e-4 seconds (when it turns on). The UDF doesn't change rho unless time > 1e-4 s. ================================================== ===== #include"udf.h" #define BMODULUS 1.1e15 #define rho_ref 1060 DEFINE_PROPERTY(superfluid_density,c,t) { real rho; real p, dp; real p_operating; real time; p_operating = RP_Get_Real("operating-pressure"); time = CURRENT_TIME; p = C_P(c,t); dp = p-p_operating; rho = rho_ref/(1.0-dp/BMODULUS); if (dp > BMODULUS/2) rho = rho_ref; if (dp < 0) rho = rho_ref; if (time < 1e-4) rho = rho_ref; return rho; } ================================================== ================== Hope this helps! I think in your UDF you have two IF conditions like if (dp < 0, dp > x). Try writing it so its just one like if (dp < 0). That might help, but also you may be right: if that is how to say "if this or this" in C+ let me know ! |
|
February 15, 2013, 22:11 |
|
#3 |
New Member
Simon DeSmet
Join Date: Feb 2013
Posts: 3
Rep Power: 13 |
I managed to get my UDF working. Reading the user manuals for fluent, i realised that the UDF code was based on C, so i asked google how you write double clause if statements in C.
you use && symbols between each statement so; if ( y >= a && Y <= b) is the correct syntax. also for some reason you have to multiply your eventual flow mass rate by the vector. This means creating a vector variable y=x[1] and then when defining my F_PROFILE i must multiply my flow by it so if flow rate =F F_PROFILE = F*Y. apart from those two errors i think most of my UDF above is fine |
|
March 2, 2013, 21:58 |
UDF to read velocity from a text file
|
#4 |
New Member
Join Date: Mar 2013
Posts: 4
Rep Power: 13 |
Hello,
I would like to set the boundary conditions for LES that can read velocity data from a text file and adapt the boundary conditions accordingly. Any help regarding how to read the data file (velocity.txt) and distribute the values on a grid of points at the input will be appreciated. |
|
March 3, 2013, 05:13 |
|
#5 |
Senior Member
SSL
Join Date: Oct 2012
Posts: 226
Rep Power: 14 |
You can use fscanf to read a text file and use it's information as you want.
|
|
March 3, 2013, 11:13 |
|
#6 |
New Member
Join Date: Mar 2013
Posts: 4
Rep Power: 13 |
Could you please help me find the error in this UDF:
#include "udf.h" #include "para.h" #include "prf.h" const int maxz=10, maxy=10, SIZE = 10 * 10; real u[100],v[100],w[100]; int ind[100]; FILE *fp1, *fp2; DEFINE_ON_DEMAND(my_init_func) { #if RP_NODE if (I_AM_NODE_ZERO_P) { Domain *domain; domain = Get_Domain(1); fp1 = fopen("u.txt", "r"); fp2 = fopen("index.txt","r"); int i; for(i = 0;i < SIZE;i++) { fscanf(fp2,"%d",&ind[i]); } printf("Files opened\n"); } #endif } DEFINE_EXECUTE_AT_END(velo_update) { #if RP_NODE if (I_AM_NODE_ZERO_P) { Domain *domain; domain = Get_Domain(1); static const int SIZE = maxy * maxz; int i; for(i = 0;i < SIZE;i++) fscanf(fp1, "%f", &u[i]); } #endif } DEFINE_PROFILE(u_velocity,thread,index) { #if RP_NODE if (I_AM_NODE_ZERO_P) { face_t f; int i = 0; begin_f_loop(f,thread) { F_PROFILE(f,thread,index) = u[ind[i]]; i++; } end_f_loop(f,thread) } #endif } I would like to read the values of u from the file u.text each time step and distribute that on the input (input bc is varing with time). Thanks |
|
Tags |
define_profile, if statement, time dependent |
Thread Tools | Search this Thread |
Display Modes | |
|
|
Similar Threads | ||||
Thread | Thread Starter | Forum | Replies | Last Post |
TimeVaryingMappedFixedValue | irishdave | OpenFOAM Running, Solving & CFD | 32 | June 16, 2021 06:55 |
Moving mesh | Niklas Wikstrom (Wikstrom) | OpenFOAM Running, Solving & CFD | 122 | June 15, 2014 06:20 |
Installing OF 1.6 on Mac OS X | gschaider | OpenFOAM Installation | 129 | June 19, 2010 09:23 |
Modeling in micron scale using icoFoam | m9819348 | OpenFOAM Running, Solving & CFD | 7 | October 27, 2007 00:36 |
fluid flow fundas | ram | Main CFD Forum | 5 | June 17, 2000 21:31 |