24小时热门版块排行榜    

查看: 2924  |  回复: 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

新虫 (初入文坛)

2楼2012-01-08 14:13:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

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的回帖

gy846608002

金虫 (正式写手)

【答案】应助回帖


感谢参与,应助指数 +1
臭水沟(金币+1): 谢谢交流~~ 2012-01-10 17:24:29
UDF这么难啊。。。需要学习一下。。
开心快乐每一天
6楼2012-01-09 21:53:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

47425804

木虫 (正式写手)


【答案】应助回帖


臭水沟(金币+1): 谢谢交流~~ 2012-01-10 17:24:35
引用回帖:
5楼: Originally posted by xiaoguai3 at 2012-01-09 21:24:58:
谢谢指点。我之后修改了程序,编译通过,但是结果不是我所想要的。我试图用fprintf将前一步累加的Q值存入文件之后调用,但运行后发现TXT文件中数字一直是零,不知道哪里出错了。
[url]http://muchong.com/bbs/vie ...

UDF里好像没法用fprintf,至少我试过没成功。
不过存文件能办到的,一般也可以用全局变量实现。
7楼2012-01-10 08:55:29
已阅   回复此楼   关注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的回帖

NaOHWTO

金虫 (小有名气)


xiegangmai(金币+1): 谢谢参与! 2012-01-11 21:46:10
引用回帖:
8楼: Originally posted by xiaoguai3 at 2012-01-10 11:15:36:
你好,我试着用全局变量来实现数据存储,但是程序运行结果仍不是我想要的。为了查出是什么问题,我想观察Q_tot值的累加情况,试了PRINTF 和MASSEGE的命令,在CONSOLE里面全都没有显示。请问可能是什么原因?
另 ...

你这个UDF怎么这么乱啊,要用两个循环吗,一会循环体,一会又循环面,你把这个UDF用到哪里?
9楼2012-01-11 21:32:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

47425804

木虫 (正式写手)



xiegangmai(金币+1): 谢谢参与。 2012-01-16 13:29:31
引用回帖:
8楼: Originally posted by xiaoguai3 at 2012-01-10 11:15:36:
你好,我试着用全局变量来实现数据存储,但是程序运行结果仍不是我想要的。为了查出是什么问题,我想观察Q_tot值的累加情况,试了PRINTF 和MASSEGE的命令,在CONSOLE里面全都没有显示。请问可能是什么原因?
另 ...

这样看UDF蛮头疼的,而且也不知道你的模型具体是啥样子。
给个小建议,尽量给每一行都标上注释,写上作用和思路等等。这样看起来很快就能明白,不然还得自己猜。而且在写注释的过程中说不定你自己就能找到问题在哪,我就一直是这么做的,很管用。
10楼2012-01-15 22:48:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 xiaoguai3 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085601材料工程专硕求调剂 +7 慕寒mio 2026-03-16 7/350 2026-03-19 10:57 by w沐阳w
[考研] 一志愿天大材料与化工(085600)总分338 +5 蔡大美女 2026-03-13 5/250 2026-03-19 10:44 by 是小刘呀~
[考研] 一志愿985,本科211,0817化学工程与技术319求调剂 +10 Liwangman 2026-03-15 10/500 2026-03-19 10:25 by 无际的草原
[考研] 085600材料与化工调剂 324分 +9 llllkkkhh 2026-03-18 9/450 2026-03-19 07:40 by BruceLiu320
[考研] 0703化学 305求调剂 +4 FY_yy 2026-03-14 4/200 2026-03-19 05:54 by anny19840123
[考研] 311求调剂 +4 冬十三 2026-03-18 4/200 2026-03-18 21:47 by 尽舜尧1
[考研] 26调剂/材料/英一数二/总分289/已过A区线 +7 步川酷紫123 2026-03-13 7/350 2026-03-18 17:12 by 尽舜尧1
[考研] 工科材料085601 279求调剂 +6 困于星晨 2026-03-17 6/300 2026-03-18 10:21 by kkcoco25
[考研] 307求调剂 +3 冷笙123 2026-03-17 3/150 2026-03-18 09:55 by macy2011
[考研] 301求调剂 +9 yy要上岸呀 2026-03-17 9/450 2026-03-18 08:58 by 无际的草原
[考研] 有没有道铁/土木的想调剂南林,给自己招师弟中~ +3 TqlXswl 2026-03-16 7/350 2026-03-17 15:23 by TqlXswl
[考研] 材料与化工专硕调剂 +5 heming3743 2026-03-16 5/250 2026-03-17 14:03 by 勇敢太监王公公
[考研] 211本,11408一志愿中科院277分,曾在中科院自动化所实习 +6 Losir 2026-03-12 7/350 2026-03-17 12:09 by danranxie
[考研] 考研调剂 +3 淇ya_~ 2026-03-17 5/250 2026-03-17 09:25 by Winj1e
[考研] 283求调剂 +3 听风就是雨; 2026-03-16 3/150 2026-03-17 07:41 by 热情沙漠
[考研] 0856求调剂 +3 刘梦微 2026-03-15 3/150 2026-03-16 10:00 by houyaoxu
[考研] 求老师收留调剂 +4 jiang姜66 2026-03-14 5/250 2026-03-15 20:11 by Winj1e
[考研] 一志愿哈工大材料324分求调剂 +5 闫旭东 2026-03-14 5/250 2026-03-14 14:53 by 木瓜膏
[考研] 土木第一志愿276求调剂,科研和技能十分丰富,求新兴方向的导师收留 +3 土木小天才 2026-03-12 3/150 2026-03-13 15:01 by JourneyLucky
[考研] 0817化学工程与技术考研312分调剂 +3 T123 tt 2026-03-12 3/150 2026-03-13 10:49 by houyaoxu
信息提示
请填处理意见