24小时热门版块排行榜    

Znn3bq.jpeg
查看: 2970  |  回复: 9
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

xiaoguai3

新虫 (初入文坛)

[求助] UDF程序,形参t重定义等ERROR求教

编译时报错,查了程序没发现重定义啊。。后两条ERROR也不明白,说的是这几句b =a/24;
d = Get_Domain(1);
int i=(int)((int)a/24);

..\..\src\123.c(25) : error C2082: 形参“t”的重定义
..\..\src\123.c(32) : error C2143: 语法错误 : 缺少“;”(在“类型”的前面)
..\..\src\123.c(33) : error C2059: 语法错误 : “类型”
求教~!谢谢!!
CODE:
#include "udf.h"
#define cp 800
#define density 2180

DEFINE_PROFILE (unsteady_temp,t,i)
{
real tempn, templ, volume, Q,Q_tot,time,a,b,tempad;
real Heat[5]={278.5,280.7,278.5,280.5,285.2};
Domain *d;
Thread *t,*ct,*t0;
cell_t c,c0;
face_t f;
time = RP_Get_Real("flow-time");
a =time/3600;
b =a/24;
d = Get_Domain(1);
int i=(int)((int)a/24);
if (int(b)==b)   /*如果b是实数,Q_tot归零,否则在以往计算的基础上累加[color=Red]我这样表达正确么?[/color]*/
Q_tot=0;
thread_loop_c(ct,d)  /*Compute Q */ /*Loop over all cells循环DOMAIN上所有THREAD */
{
        begin_c_loop(c,ct) /*Loop over all cells循环所有THREAD上所有CELL */
       {
volume=C_VOLUME(c,ct); /* get cell volume */
templ=C_T_M1(c,ct); /*Get cell tempertuare of previous step有问题!!!!!!!!*/
tempn=C_T(c,ct);   /*Get cell tempertuare*/
Q=cp*density*volume*(tempn-templ);
Q_tot +=Q;
       }
     end_c_loop(c,ct)
}
if (Q_tot<= Heat[i])
  begin_f_loop(f,t)
{   
    F_PROFILE(f,t,i)=333;  /*BC:Temp=333K*/
}
end_f_loop(f,t)
else
begin_f_loop(f,t)
{   
c0 = F_C0(f,t);
t0 = THREAD_T0(t);
tempad=C_T(c0,t0); /*temperature of adjacent cell  [color=Red]这样取相邻CELL温度正确吗?可不可以直接取相邻FACE的温度值呢?查了MANUAL没有看到F_T(f0,t)的表达啊[/color]*/
F_PROFILE(f,t,i)=tempad;
}
end_f_loop(f,t)
}

[ Last edited by xiaoguai3 on 2012-1-8 at 14:12 ]
回复此楼

» 本帖@通知

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiaoguai3

新虫 (初入文坛)

引用回帖:
7楼: Originally posted by 47425804 at 2012-01-10 08:55:29:
UDF里好像没法用fprintf,至少我试过没成功。
不过存文件能办到的,一般也可以用全局变量实现。

你好,我试着用全局变量来实现数据存储,但是程序运行结果仍不是我想要的。为了查出是什么问题,我想观察Q_tot值的累加情况,试了PRINTF 和MASSEGE的命令,在CONSOLE里面全都没有显示。请问可能是什么原因?
另外,我的程序有什么问题么?UDF和C语言我都是小白。。痛苦挣扎中。
CODE:
#include "udf.h"
#define cp 800.
#define density 2180.
FILE *fp;
static Q_tot=0;

DEFINE_PROFILE(unsteady_temp,t,index)
{
float tempn,templ,volume,Q,Q_tot,time,a,b,tempad;
int i;
float Heat[5]={2780000.,        280.7,        278.5,        280.5,        285};  /*数组*/
Domain *d;
Thread *ct,*t0;
cell_t c,c0;
face_t f;
time = RP_Get_Real("flow-time");
a = time/3600;
b = a/24;
d = Get_Domain(1);
i=((int)a)/24;
if ((int)b==b)   
Q_tot=0;
thread_loop_c(ct,d)  
{
        begin_c_loop(c,ct) /*Loop over all cells循环所有THREAD上所有CELL */
       {
volume=C_VOLUME(c,ct); /* get cell volume */
templ=C_T_M1(c,ct); /*Get cell tempertuare of previous step*/
tempn=C_T(c,ct);   /*Get cell tempertuare*/
Q=cp*density*volume*(tempn-templ);
Q_tot +=Q;
       }
     end_c_loop(c,ct)
}
if (Q_tot<= Heat[i])
  begin_f_loop(f,t)
{   
    F_PROFILE(f,t,index)=333;  /*BC:Temp=333K*/
}
end_f_loop(f,t)
else
begin_f_loop(f,t)
{   
c0 = F_C0(f,t);
t0 = THREAD_T0(t);
tempad=C_T(c0,t0); /*temperature of adjacent cell*/
F_PROFILE(f,t,index)=tempad;
}
end_f_loop(f,t)
}

8楼2012-01-10 11:15:36
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 10 个回答

gyctju

金虫 (正式写手)


xiegangmai(金币+1): 谢谢参与! 2012-01-08 22:55:18
不确定 建议查一下这一句的语法,
int i=(int)((int)a/24);
3楼2012-01-08 21:16:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

47425804

木虫 (正式写手)


【答案】应助回帖

★ ★
感谢参与,应助指数 +1
xiegangmai(金币+2): 谢谢应助! 2012-01-08 22:55:42
变量 t 和 i 都是主程序传递过来的形参,而你在程序里面又定义了一遍,所以重定义了。
你说的那几条语句应该没有问题。
4楼2012-01-08 22:41:25
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiaoguai3

新虫 (初入文坛)

引用回帖:
4楼: Originally posted by 47425804 at 2012-01-08 22:41:25:
变量 t 和 i 都是主程序传递过来的形参,而你在程序里面又定义了一遍,所以重定义了。
你说的那几条语句应该没有问题。

谢谢指点。我之后修改了程序,编译通过,但是结果不是我所想要的。我试图用fprintf将前一步累加的Q值存入文件之后调用,但运行后发现TXT文件中数字一直是零,不知道哪里出错了。
http://muchong.com/bbs/viewthread.php?tid=4015455&pid=17&page=2###
5楼2012-01-09 21:24:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 268分085602化学工程调剂 +12 月照花林。 2026-04-09 12/600 2026-04-09 14:15 by sxx1988
[考研] 289 分105500药学专硕求调剂(找B区学校) +5 白云123456789 2026-04-09 6/300 2026-04-09 14:04 by 白云123456789
[考研] 一志愿厦大生物学332求调剂 +8 池池池池池池 2026-04-08 8/400 2026-04-09 09:53 by 天籁战国策
[考研] 求助071001调剂!!! +7 黄守松 2026-04-05 8/400 2026-04-09 09:07 by 徐良白眉大侠
[考研] 机械专硕273请求调剂 +6 庚申壬申 2026-04-07 6/300 2026-04-08 22:41 by bljnqdcc
[考研] 296求调剂 +3 汪!?! 2026-04-08 3/150 2026-04-08 21:46 by 土木硕士招生
[考研] 368化学求调剂 +12 wwwwabcde 2026-04-07 13/650 2026-04-08 20:48 by LiuXingYu星星
[考研] 机械工程313分找工科调剂 +3 双一流本科机械 2026-04-08 3/150 2026-04-08 20:41 by 土木硕士招生
[考研] 275 求调剂 +8 Lei812514 2026-04-07 8/400 2026-04-08 12:46 by chemisry
[考研] 一志愿生物与医药,296分,求调剂 +14 66鹿 2026-04-03 16/800 2026-04-08 10:38 by tjzhao
[考研] 305求调剂 +3 77Qi 2026-04-07 3/150 2026-04-07 23:18 by jp9609
[考研] 求调剂 +4 电气小神童 2026-04-04 6/300 2026-04-07 00:14 by guanxin1001
[考研] 327考研调剂推荐 +6 呜呜呜呜呢 2026-04-06 6/300 2026-04-06 21:39 by 啵啵啵0119
[考研] 338求调剂 +4 我想上岸ii 2026-04-05 4/200 2026-04-06 21:04 by 木子君1218
[考研] 081200-11408-276学硕求调剂 +5 崔wj 2026-04-05 5/250 2026-04-06 15:40 by lin-da
[考研] 0855求调剂材料 +11 红桃灼灼 2026-04-04 12/600 2026-04-06 10:26 by 蓝云思雨
[考研] 一志愿西北农林畜牧专硕336分求调剂 +3 5ourr 2026-04-03 3/150 2026-04-05 10:40 by JOKER0401
[考研] 400分求调剂 +3 尴尬且挠头 2026-04-04 3/150 2026-04-04 08:41 by jp9609
[考研] 293求调剂 +5 末未mm 2026-04-02 6/300 2026-04-03 15:20 by 王保杰33
[考研] 一志愿大工学硕,求调剂 +4 yub0811 2026-04-02 4/200 2026-04-02 21:36 by 百灵童888
信息提示
请填处理意见