24小时热门版块排行榜    

Znn3bq.jpeg
查看: 2975  |  回复: 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的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿211 0703化学 346分求调剂 +15 土豆er? 2026-04-09 15/750 2026-04-09 18:43 by l_paradox
[考研] 284求调剂 +6 archer.. 2026-04-09 7/350 2026-04-09 18:27 by vgtyfty
[考研] 一志愿中国科学院上海有机所,有机化学356分找调剂 +11 Nadiums 2026-04-09 11/550 2026-04-09 18:04 by lijunpoly
[考研] 一志愿中科院105500专业总分315求调剂 +6 lallalh 2026-04-09 7/350 2026-04-09 17:51 by lallalh
[考研] 一志愿电子科技大学085600材料与化工 329分求调剂 +14 Naiko 2026-04-04 14/700 2026-04-09 16:56 by luoyongfeng
[考研] 314求调剂 +20 wakeluofu 2026-04-09 21/1050 2026-04-09 16:14 by zhuimr
[考研] 085501机械英二77总分294求调剂,接受跨专业学习 +6 守法公民亓纪 2026-04-08 6/300 2026-04-09 15:55 by wp06
[考研] 085400 328分 求调剂 +7 喂你一个大橙子 2026-04-09 11/550 2026-04-09 15:51 by GSGSQ
[考博] 博士自荐 +3 可可小胖 2026-04-08 3/150 2026-04-09 11:25 by juanzi_88
[考研] 材料307分求大佬组收留 +17 Hll胡 2026-04-07 17/850 2026-04-09 10:53 by liuhuiying09
[考研] 材料专硕调剂 +15 哈哈哈吼吼吼哈 2026-04-07 16/800 2026-04-09 08:33 by byk122723822
[考研] 324求调剂 +17 想上学求调 2026-04-03 17/850 2026-04-08 20:04 by 我减肥1
[考研] 一志愿生物与医药,296分,求调剂 +14 66鹿 2026-04-03 16/800 2026-04-08 10:38 by tjzhao
[考研] 263分B区求调剂 +6 李nihao 2026-04-08 6/300 2026-04-08 09:38 by 南开小綦
[考研] 生物医药调剂|SCI中科院三区一作+多项科研成果 +8 likangxing 2026-04-07 11/550 2026-04-08 00:02 by lys0704
[考研] 材料工程专业日语生求调剂 +9 111623 2026-04-07 9/450 2026-04-07 23:31 by 一只好果子?
[考研] 081700,311,求调剂 +17 冬十三 2026-04-04 18/900 2026-04-07 12:50 by Sammy2
[考研] 081200-11408-276学硕求调剂 +5 崔wj 2026-04-05 5/250 2026-04-06 15:40 by lin-da
[考研] 材料调剂 +13 一样YWY 2026-04-03 14/700 2026-04-05 18:20 by 蓝云思雨
[考研] 材料专业383求调剂 +8 郭阳阳阳成 2026-04-03 8/400 2026-04-04 10:29 by Rednal.
信息提示
请填处理意见