24小时热门版块排行榜    

查看: 442  |  回复: 0

zwb565055403

新虫 (小有名气)

[交流] 编程为什么结果出来不对啊

编程为什么结果出来不对啊

我写的程序如下(虽然能运行出来,结果却不对 大家帮我看下程序是否有问题):
% Example 1
clear;clc
%%%%%%%%%%%%%%%%%%%% 方程里的参数设置 %%%%%%%%%%%%%%%%%%%%%%%%%%%%
alpha=0.5;
beta=0.5;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
L=1;   %区间x的长度[0,1]
Mx=L/0.0025;  %区间x的等分的份数
h=L/Mx;  %区间x的划分小区间长度
x=[0:Mx]*h;  % x的点值
%上面给出了x的点值,结合t点的点值和函数 u(x,t)的值就可以画出 曲面u(x,t),三维数组
N=1000;   %时间t的等分份数
tau=0.0025; % 时间t的划分小区间长度
t=[0:N]*tau;  %时间t的点值 0点和1点 101个
  %%%%%%%%%%%%%%%%%%%%%%%%%%% 系数矩阵里面的常数定义 r R(i) %%%%%%%%%%%%%%%%%%
   R=(tau^alpha)*(gamma(2-alpha))/(h*h); % r常数
   %计算 r(j)
for j=1:Mx-1
  r(j)=beta*R/j;  % 变数 r_j
end
r;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%分数阶系数矩阵%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
v0=1+2*R-r;  %主对角线上元素
A=diag(v0);
v1=r-R ;   
v1=v1(2:end);%下次对角线上的元素
B=diag(v1,-1);
v3=-R*ones(1,Mx-2); %上次对角线上的元素
C=diag(v3,1);
D=A+B+C;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%非齐次项f(x,t)=2\sqrt(t/pi) sin(pi x)-pi t ((cos pi x)/(2x)-pi sin(pi x))
for k=1:size(t,2)       %size(a,2)指行向量元素个数
F(k, =2*(t(k)^(1/2)/pi^(1/2)).*sin(pi*x) + pi*t(k).*(pi*sin(pi.*x) - cos(pi*x)./(2*x));
%第k行向量 时间不变而空间位置变化
end
F=F(2:end-1,2:end-1);
F=F';
%去掉第一行和最后一行 去掉第一列和最后一列 对应 t=0 x=0
%%%%%%%%%%%%%%%%%%下面用递推关系式得到关于 u 的数表 %%%%%%%%%%%%%%%%%%%%%%%%%%%
u(:,1)=inv(D)*((tau^alpha)*gamma(2-alpha)*F(:,1));            
% D*u1=u0+ tau^alpha)F1   例一中 u0=0 即初值函数为0函数
%定义 w(k)=(1+k)^(1-alpha)-k^(1-alpha);d(k)=w(k)-w(k+1)
for k=1:N
    w(k)=(1+k)^(1-tau)-k^(1-tau);
end
for k=1:N-1
d(k)=w(k)-w(k+1);      %系数 d(k)
end
d;
%%%%%%%%%%%%%%%%%%%%%%%%%% 单独算出 u2 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
u(:,2)=inv(D)*((1-w(1))*u(:,1)+(tau^alpha)*gamma(2-alpha)*F(:,1));
%%%%%求和 \sum d(k)*u^(n-k) 列和 sum(A(:,a:b);2)
for n=2:N-2
    for k=1:n-1
        s(:,k)=d(n-k)*u(:,k);
    end
   u(:,n+1)=inv(D)*((tau^alpha)*gamma(2-alpha)*F(:,n+1)+(1-w(1))*u(:,n)+sum(s(:,1:n-1),2));
% u0=0
end
h=x(2:end-1);
g=t(2:end-1);
[h,g]=meshgrid(h,g);%生成网格
mesh(h,g,u');%画出曲面图
xlabel('x')  %添加坐标轴
ylabel('t')
zlabel('u(x,t)')
for k=1:N-1
for j=1:Mx-1
    plot3(x(j),t(k),u(j,k))
e(j,k)=u(j,k)-t(k)*sin(pi*x(j));  %误差函数
end
end
e=max(max(abs(e)))      %最大误差
回复此楼

» 猜你喜欢

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

智能机器人

Robot (super robot)

我们都爱小木虫

找到一些相关的精华帖子,希望有用哦~

科研从小木虫开始,人人为我,我为人人
相关版块跳转 我要订阅楼主 学员J46msc 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 考研化学学硕调剂,一志愿985 +3 张vvvv 2026-03-15 5/250 2026-03-16 20:25 by 张vvvv
[考研] 材料专硕306英一数二 +4 z1z2z3879 2026-03-16 6/300 2026-03-16 19:38 by z1z2z3879
[考研] 304求调剂 +4 ahbd 2026-03-14 4/200 2026-03-16 16:48 by 我的船我的海
[考研] 0856求调剂 +3 刘梦微 2026-03-15 3/150 2026-03-16 10:00 by houyaoxu
[考研] 311求调剂 +6 冬十三 2026-03-15 6/300 2026-03-16 08:00 by wang_dand
[考研] 085601材料工程315分求调剂 +3 yang_0104 2026-03-15 3/150 2026-03-15 10:58 by peike
[考研] 266求调剂 +4 学员97LZgn 2026-03-13 4/200 2026-03-14 08:37 by zhukairuo
[考研] 0703求调剂 +7 jtyq001 2026-03-10 7/350 2026-03-14 01:06 by JourneyLucky
[考研] 调剂 +3 13853210211 2026-03-10 3/150 2026-03-14 00:47 by JourneyLucky
[考研] 336求调剂 +6 Iuruoh 2026-03-11 6/300 2026-03-13 22:06 by JourneyLucky
[考研] 求材料调剂 +5 隔壁陈先生 2026-03-12 5/250 2026-03-13 22:03 by 星空星月
[考研] 304求调剂 +7 7712b 2026-03-13 7/350 2026-03-13 21:42 by peike
[考研] 293求调剂 +3 世界首富 2026-03-11 3/150 2026-03-13 16:27 by JourneyLucky
[考研] 工科278分求调剂 +5 周慢热啊 2026-03-12 7/350 2026-03-13 15:49 by JourneyLucky
[考研] 295求调剂 +3 小匕仔汁 2026-03-12 3/150 2026-03-13 15:17 by vgtyfty
[考研] 328化工专硕求调剂 +4 。,。,。,。i 2026-03-12 4/200 2026-03-13 14:44 by JourneyLucky
[考研] 0857环境调剂 +5 熠熠_11 2026-03-10 5/250 2026-03-11 10:59 by wang_dand
[考研] 298求调剂 +3 Vv呀! 2026-03-10 3/150 2026-03-10 22:40 by 剑诗杜康
[考博] 26申博求助 +3 跳跃饼干 2026-03-10 4/200 2026-03-10 21:15 by Tntcnn
[考研] 求调剂材料专硕293 +6 段_(:з」∠)_ 2026-03-10 6/300 2026-03-10 18:22 by ms629
信息提示
请填处理意见