| 查看: 5195 | 回复: 116 | |||
| 当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖 | |||
[交流]
激光反射吸收热源模型!!!!代码重量爆料!!!!!求解答!!!!!!!!!
|
|||
|
代码有点错误,我现在是想用最小二乘法拟合自由表面的曲线,首先轮循所有自由表面网格,计算自由表面网格数量N,开辟数值存储自由表面上网格的重心(优良拟合三次曲线方程),gt,GS,max三个函数是用来求三次曲线方程y=a+bx+cx2+dx*x*x四个系数。然后把求出的四个系数保存到C_UDMI中,用于与离散的激光光线求交。代码编译之后有错误,可能思路上都已经与udf编程思想向偏离了,求各路大神指点,重谢!!!!!!!!!!!至少400金币!!!!呵呵 #include "udf.h" #include "sg.h" #include "sg_mphase.h" #include "flow.h" #include <math.h> double gt(double x[],double y[]); double GS(double a[4][4],double b[4],double x[4]); double max(double array[4]); DEFINE_ADJUST(store_gradient,domain) { int phase_domain_index = 0; real xc[ND_ND],xd[ND_ND],x[4],n1,n2,thita_l,thita_g; Thread *t; Thread **pt; cell_t c; Domain *pDomain = DOMAIN_SUB_DOMAIN(domain,phase_domain_index); { Alloc_Storage_Vars(pDomain,SV_VOF_RG,SV_VOF_G,SV_NULL); Scalar_Reconstruction(pDomain, SV_VOF,-1,SV_VOF_RG,NULL); Scalar_Derivatives(pDomain,SV_VOF,-1,SV_VOF_G,SV_VOF_RG,Vof_Deriv_Accumulate); } mp_thread_loop_c(t,domain,pt) { if (FLUID_THREAD_P(t)) { int N=0; Thread *ppt = pt[phase_domain_index]; begin_c_loop (c,t) { C_CENTROID(xd,c,t); if(C_VOF(c, ppt)>0.1&&C_VOF(c, ppt)<0.9&&fabs(xd[0]-0)>0.0005) N++; } end_c_loop (c,t) double a[N],b[N],c[N],d[N],e[N],f[N],g[N]; int i; for(i=0; i<N; i++) { a=1; } int j=0; begin_c_loop (c,t) { C_CENTROID(xc,c,t); if(C_VOF(c, ppt)>0.1&&C_VOF(c, ppt)<0.9&&fabs(xc[0]-0)>0.0005) { b[j]=xc[0]; e[j]=xc[1]; c[j]=b[j]*b[j]; d[j]=b[j]*b[j]*b[j]; j++; } } end_c_loop (c,t) f[0]=gt(a,a);f[1]=gt(a,b);f[2]=gt(a,c);f[3]=gt(a,d);f[4]=gt(b,b);f[5]=gt(b,c);f[6]=gt(b,d); f[7]=gt(c,c);f[8]=gt(c,d);f[9]=gt(d,d);g[0]=gt(a,e);g[1]=gt(b,e);g[2]=gt(c,e);g[3]=gt(d,e); double array[4][4]={{f[0],f[1],f[2],f[3]},{f[1],f[4],f[5],f[6]},{f[2],f[5],f[7],f[8]},{f[3],f[6],f[8],f[9]}}; GS(array,g,x); C_UDMI(c,t,0) = x[0]; C_UDMI(c,t,1) = x[1]; C_UDMI(c,t,2) = x[2]; C_UDMI(c,t,3) = x[3]; } } Free_Storage_Vars(pDomain,SV_VOF_RG,SV_VOF_G,SV_NULL); } double gt(double x[],double y[]) { double sum=0; int i; for(i=0;i<N;i++) sum=x*y+sum; return sum; } double GS(double a[4][4],double b[4],double x[4]) { double c[4]={0}; double x0[4]={0}; int i,j,k; double sum=0; for(k=1;;k++) { for(i=0;i<4;i++) { for(j=0;j<4;j++) { sum=a[j]*x0[j]+sum; } x=x0+(b-sum)/a; c=fabs(x-x0); x0=x; sum=0; } r=max(c); if(r<0.0001) { break; } } return 0; } double max(double array[4]) { double a=array[0]; int i; for(i=0;i<4;i++) { if(a<array) a=array; } return a; } |
» 猜你喜欢
基元I理论下三大核心空间现象精准推导与细节解析
已经有0人回复
基于基元 I 统一理论的反重力理论推导
已经有0人回复
物理学I论文润色/翻译怎么收费?
已经有131人回复
基于基元I统一理论的量子力学本源推导
已经有1人回复
推荐一款可以AI辅助写作的Latex编辑器SmartLatexEditor,超级好用,AI润色,全免费
已经有20人回复
【EI|Scopus 双检索】第六届智能机器人系统国际会议(ISoIRS 2026)
已经有0人回复
2026年第四届电动车与车辆工程国际会议(CEVVE 2026)
已经有0人回复
» 抢金币啦!回帖就可以得到:
医学超声影像负责人招聘-中国科学院赣江创新研究院
+1/974
西湖大学2026年秋季入学物理学、光学、电子信息方向博士生有名额速来!!!
+2/230
贺电中定位于“积极作用”,是不是对基金委工作不够满意?
+1/79
一个陌生女人的来信
+1/72
北京-89175-事业单位-诚征女友
+1/63
海法大学线上开放日
+1/40
国家级青年人才课题组招收2026级硕士研究生
+1/39
海南大学海洋技术与装备学院-科研助理招聘(可读博)膜分离水处理方向
+1/34
南京医科大学国家级高层次青年人才团队招收博士后
+1/17
湖南大学-分析检测技术和生物柔性传感器-招收1名博士研究生 (2026年,第二批)
+1/12
中科院深圳先进技术研究院招联培学生 -- 多中心大队列数据已就绪,助你快车道产出成果
+1/9
国家“双一流”建设高校-南京林业大学-国家级青年人才团队 招2026级申请考核制博士
+1/8
宁波诺丁汉大学招收26年秋/27年春固废协同转化与低碳冶金方向全奖博士生
+1/7
上海大学生物有机电子材料及器件团队博士研究生招聘
+1/6
电子科技大学李世彬课题组招聘传感器方向博士及博士后
+1/6
澳门理工大学 2026 Fall 奖学金博士招生 (AI药物与蛋白质设计,干湿结合)
+1/6
华南师范大学(211)- 光电科学与工程学院 - 申请审核制(2026年4-5月份面试考核)
+2/6
中北大学冯瑞教授*开山大弟子*招募
+1/6
【东南大学博士后、科研助理招聘】
+1/5
墨尔本大学(QS13)急招CSC博士(补齐全奖)/访问学者/博士后(生物医学材料/器官芯片)
+1/3
37楼2013-12-03 10:27:32













回复此楼