MATLAB 这个代码出现矢量长度必须相同,是哪里出错了

%建立符号变量a(发展系数)和b(灰作用量)symsab;c=[ab]';%原始数列AA=[57254,58231,66159,75272,84417,96718,111... %建立符号变量a(发展系数)和b(灰作用量)
syms a b;
c = [a b]';

%原始数列 A
A = [57254, 58231, 66159, 75272, 84417, 96718, 111779, 111063, 120379, 132252];
n = length(A);

%对原始数列 A 做累加得到数列 B
B = cumsum(A);

%对数列 B 做紧邻均值生成
for i = 2:n
C(i) = (B(i) + B(i - 1))/2;
end
C(1) = [];

%构造数据矩阵
B = [-C;ones(1,n-1)];
Y = A; Y(1) = []; Y = Y';

%使用最小二乘法计算参数 a(发展系数)和b(灰作用量)
c = inv(B*B')*B*Y;
c = c';
a = c(1); b = c(2);

%预测后续数据
F = []; F(1) = A(1);
for i = 2:(n+10)
F(i) = (A(1)-b/a)/exp(a*(i-1))+ b/a;
end

%对数列 F 累减还原,得到预测出的数据
G = []; G(1) = A(1);
for i = 2:(n+10)
G(i) = F(i) - F(i-1); %得到预测出来的数据
end

disp('预测数据为:');
G

%模型检验

H = G(1:10);
%计算残差序列
epsilon = A - H;

%法一:相对残差Q检验
%计算相对误差序列
delta = abs(epsilon./A);
%计算相对误差Q
disp('相对残差Q检验:')
Q = mean(delta)

%法二:方差比C检验
disp('方差比C检验:')
C = std(epsilon, 1)/std(A, 1)

%法三:小误差概率P检验
S1 = std(A, 1);
tmp = find(abs(epsilon - mean(epsilon))< 0.6745 * S1);
disp('小误差概率P检验:')
P = length(tmp)/n

%绘制曲线图
t1 = 2007:2027;
t2 = 2007:2027;

plot(t1, A,'ro'); hold on;
plot(t2, G, 'g-');
xlabel('1'); ylabel('1');
legend('1','1');
title('1');
grid on;
展开
 我来答
lhmhz
高粉答主

2019-02-02 · 专注matlab等在各领域中的应用。
lhmhz
采纳数:7264 获赞数:17021

向TA提问 私信TA
展开全部

出错的原因是:A数据的个数为10,而t1数据的个数为21。可能t1对应A的年份写错了。同样t2也有错误。G数据的个数为20,而t2的个数为21。

如t1、t2改为

t1 = 2007:1:2016;

t2 = 2007:1:2026;

可以得到如下图形

追问
那请问各个年份对应的具体数值能显示出来吗?
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式