24小时热门版块排行榜    

查看: 2930  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 321求调剂 +8 何润采123 2026-03-18 8/400 2026-03-19 15:23 by 丁丁*
[考研] 286求调剂 +6 lemonzzn 2026-03-16 10/500 2026-03-19 14:31 by lemonzzn
[考研] 求调剂,一志愿:南京航空航天大学大学 ,080500材料科学与工程学硕,总分289分 +3 @taotao 2026-03-19 3/150 2026-03-19 14:07 by peike
[考研] 招收调剂硕士 +3 lidianxing 2026-03-19 9/450 2026-03-19 13:59 by lidianxing
[考研] 0703化学调剂 +5 pupcoco 2026-03-17 8/400 2026-03-19 13:58 by houyaoxu
[考研] 0817调剂 +3 没有答案_ 2026-03-14 3/150 2026-03-19 09:51 by Xu de nuo
[考研] 求材料调剂 +10 隔壁陈先生 2026-03-12 10/500 2026-03-19 09:15 by 无际的草原
[考研] 0703化学调剂 +8 妮妮ninicgb 2026-03-15 12/600 2026-03-19 05:55 by anny19840123
[考研] 271材料工程求调剂 +5 .6lL 2026-03-18 5/250 2026-03-19 03:07 by 无懈可击111
[考研] 330求调剂 +3 小材化本科 2026-03-18 3/150 2026-03-18 21:55 by 无懈可击111
[考研] 297求调剂 +8 戏精丹丹丹 2026-03-17 8/400 2026-03-18 14:30 by laoshidan
[考研] 收复试调剂生 +4 雨后秋荷 2026-03-18 4/200 2026-03-18 14:16 by elevennnne
[考研] 288求调剂,一志愿华南理工大学071005 +4 ioodiiij 2026-03-17 4/200 2026-03-18 12:36 by Linda Hu
[考研] 268求调剂 +6 简单点0 2026-03-17 6/300 2026-03-18 09:04 by 无际的草原
[考研] 26考研求调剂 +6 丶宏Sir 2026-03-13 6/300 2026-03-17 16:13 by 醉在风里
[考研] 有没有道铁/土木的想调剂南林,给自己招师弟中~ +3 TqlXswl 2026-03-16 7/350 2026-03-17 15:23 by TqlXswl
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考研] 297一志愿上交085600求调剂 +5 指尖八千里 2026-03-14 5/250 2026-03-14 17:26 by a不易
[考研] 招收0805(材料)调剂 +3 18595523086 2026-03-13 3/150 2026-03-14 00:33 by 123%、
[考研] 085600材料与化工 309分请求调剂 +7 dtdxzxx 2026-03-12 8/400 2026-03-13 14:43 by jxchenghu
信息提示
请填处理意见