MATLAB程序出现 Index exceeds matrix dimensions. 错误 为什么?求高手解答

Numusers=1;
Nc=16; %扩频因子
ISI_Length=1; %每径延时为ISI_Length/2(码间干扰)
Tlen=5000;%数据长度
EbN0db = [0:2:100];
Bit_Error_Number1=0;%误比特率的初始值
a1=0.8;%每径幅度衰减
a2=0.2;
a3=0.1;
power_unitary_factor1=sqrt(a1);%每径功率因子
power_unitary_factor2=sqrt(a2);
power_unitary_factor3=sqrt(a3);
s_initial=randsrc(1,Tlen);%数据源,以1/2的概率随机产生1或-1的1行Tlen列矩阵
%产生Walsh矩阵
Wal2=[1 1;1 -1];
Wal4=[Wal2 Wal2;Wal2 Wal2*(-1)];
Wal8=[Wal4 Wal4;Wal4 Wal4*(-1)];
Wal16=[Wal8 Wal8;Wal8 Wal8*(-1)];
%扩频
s_spread=zeros(Numusers,Tlen*Nc);
ray1=zeros(Numusers,2*Tlen*Nc);
ray2=zeros(Numusers,2*Tlen*Nc);
ray3=zeros(Numusers,2*Tlen*Nc);
ray4=zeros(Numusers,2*Tlen*Nc);
ray5=zeros(Numusers,2*Tlen*Nc);
for i=1:Numusers
x0=s_initial(i,:).'*Wal16(8,:);
x1=x0.';
s_Spread(i,:)=(x1(:)).';
end
%将每个扩频后输出重复为两次,有利于下面的延迟(延迟了半个码元)
ray1(1:2:2*Tlen*Nc-1)=s_Spread(1:Tlen*Nc);
ray1(2:2:2*Tlen*Nc)=ray1(1:2:2*Tlen*Nc-1);

%产生第二径和第三径信号
ray2(ISI_Length+1:2*Tlen*Nc)=ray1(1:2*Tlen*Nc-ISI_Length);
ray3(2*ISI_Length+1:2*Tlen*Nc)=ray1(1:2*Tlen*Nc-2*ISI_Length);
ray4(1:2*Tlen*Nc-ISI_Length)=ray1(2:2*Tlen*Nc);%表示减小1个时延
ray5(1:2*Tlen*Nc-2*ISI_Length)=ray1(3:2*Tlen*Nc);
for nEN = 1:length(EbN0db)
en = 10^(EbN0db(nEN)/10);% 将 Eb/N0 的dB值转换为普通十进制数值
sigma = sqrt((32/(2*en)));
sig=32/(2*en);
%接收到的信号demp
demp1=a1*ray1 + a2*ray2 + a3*ray3 + (randn(1,2*Tlen*Nc) + randn(1,2*Tlen*Nc)*i)*sig;
%接收到的信号进行时间反转技术处理
demp=(a1*a1+a2*a2+a3*a3)*ray1+(a1*a2+a2*a3)*ray2+a1*a3*ray3+(a1*a2+a2*a3)*ray4+a1*a3*ray5+(randn(1,2*Tlen*Nc) + randn(1,2*Tlen*Nc)*i)*sigma;

dt=reshape(demp,32,Tlen)';
%将Walsh码重复为两次
Wal16_d(1:2:31)=Wal16(8,1:16);
Wal16_d(2:2:32)=Wal16(8,1:16);
%解扩后的输出
rdata1=dt*Wal16_d(1,:).';
rd_m=0.2*32;
%判决输出
r_Data1=sign(rd_m)';
%计算误比特率
Bit_Error_Number1=length(find(r_Data1(1:Tlen)~=s_initial(1:Tlen)));
Bit_Error_Rate1(nEN)=Bit_Error_Number1/(Tlen);
end
semilogy(EbN0db,Bit_Error_Rate1,'*-');hold on;
xlabel('信噪比');
ylabel('误比特率');
title('时间反转技术接收性能');
我想知道为什么是在最后出的问题 在at 59出错的{%计算误比特率
Bit_Error_Number1=length(find(r_Data1(1:Tlen)~=s_initial(1:Tlen)));
Bit_Error_Rate1(nEN)=Bit_Error_Number1/(Tlen)};,求高手帮忙改改
谢谢

Bit_Error_Number1=length(find(r_Data1(1:Tlen)~=s_initial(1:Tlen)));
你的r_Data是一个1乘1的数据,没有那么多。
Tlen=5000,明显是不行的。
帮你从逻辑上简单debug了一下:
Numusers=1;
Nc=16; %扩频因子
ISI_Length=1; %每径延时为ISI_Length/2(码间干扰)
Tlen=5000;%数据长度
EbN0db = [0:2:100];
Bit_Error_Number1=0;%误比特率的初始值
a1=0.8;%每径幅度衰减
a2=0.2;
a3=0.1;
power_unitary_factor1=sqrt(a1);%每径功率因子
power_unitary_factor2=sqrt(a2);
power_unitary_factor3=sqrt(a3);
s_initial=randsrc(1,Tlen);%数据源,以1/2的概率随机产生1或-1的1行Tlen列矩阵
%产生Walsh矩阵
Wal2=[1 1;1 -1];
Wal4=[Wal2 Wal2;Wal2 Wal2*(-1)];
Wal8=[Wal4 Wal4;Wal4 Wal4*(-1)];
Wal16=[Wal8 Wal8;Wal8 Wal8*(-1)];
%扩频
s_spread=zeros(Numusers,Tlen*Nc);
ray1=zeros(Numusers,2*Tlen*Nc);
ray2=zeros(Numusers,2*Tlen*Nc);
ray3=zeros(Numusers,2*Tlen*Nc);
ray4=zeros(Numusers,2*Tlen*Nc);
ray5=zeros(Numusers,2*Tlen*Nc);
for i=1:Numusers
x0=s_initial(i,:).'*Wal16(8,:);
x1=x0.';
s_Spread(i,:)=(x1(:)).';
end
%将每个扩频后输出重复为两次,有利于下面的延迟(延迟了半个码元)
ray1(1:2:2*Tlen*Nc-1)=s_Spread(1:Tlen*Nc);
ray1(2:2:2*Tlen*Nc)=ray1(1:2:2*Tlen*Nc-1);

%产生第二径和第三径信号
ray2(ISI_Length+1:2*Tlen*Nc)=ray1(1:2*Tlen*Nc-ISI_Length);
ray3(2*ISI_Length+1:2*Tlen*Nc)=ray1(1:2*Tlen*Nc-2*ISI_Length);
ray4(1:2*Tlen*Nc-ISI_Length)=ray1(2:2*Tlen*Nc);%表示减小1个时延
ray5(1:2*Tlen*Nc-2*ISI_Length)=ray1(3:2*Tlen*Nc);
for nEN = 1:length(EbN0db)
en = 10^(EbN0db(nEN)/10);% 将 Eb/N0 的dB值转换为普通十进制数值
sigma = sqrt((32/(2*en)));
sig=32/(2*en);
%接收到的信号demp
demp1=a1*ray1 + a2*ray2 + a3*ray3 + (randn(1,2*Tlen*Nc) + randn(1,2*Tlen*Nc)*i)*sig;
%接收到的信号进行时间反转技术处理
demp=(a1*a1+a2*a2+a3*a3)*ray1+(a1*a2+a2*a3)*ray2+a1*a3*ray3+(a1*a2+a2*a3)*ray4+a1*a3*ray5+(randn(1,2*Tlen*Nc) + randn(1,2*Tlen*Nc)*i)*sigma;

dt=reshape(demp,32,Tlen)';
%将Walsh码重复为两次
Wal16_d(1:2:31)=Wal16(8,1:16);
Wal16_d(2:2:32)=Wal16(8,1:16);
%解扩后的输出
rdata1=dt*Wal16_d(1,:).';
rd_m=0.2*32;
%判决输出
r_Data1=sign(rd_m)';
%计算误比特率
Bit_Error_Number1=length(find(rdata1(1:Tlen)'~=s_initial(1:Tlen))); %考虑到你可能输错了
%变量,再就是差一个“转置”
Bit_Error_Rate1(nEN)=Bit_Error_Number1/(Tlen);
end
semilogy(EbN0db,Bit_Error_Rate1,'*-');hold on;
xlabel('信噪比');
ylabel('误比特率');
title('时间反转技术接收性能');追问

问题还是没有解决 不过还是谢谢你了
不过程序里面的find(r_data1(1:Tlen)~=s_initial(1:Tlen))这里好像是不能加转置的,这里的两个相同行列的矩阵才能够找到不相同的地方,要不然这样出来的结果就是这误比特率为0了,那这个程序就一点意义都没有了
还有就是关于这个Tlen=5000应该是没有问题的,我这个程序是参照另外的一个程序编写的,那个程序能够完好的运行的 能加个qq253778040帮忙解答下么 我是个matlab新手

温馨提示:内容为网友见解,仅供参考
第1个回答  2011-05-06
j取值超出A的长度了。
i是从1到length(A)
j始终比i大1,所以从2到length(A)+1了,超出范围了。

循环那里用for i=1:length(A)-1就好了。追问

我想知道为什么是在最后出的问题 在at 59出错的,求高手帮忙改改

第2个回答  2011-05-06
Index exceeds matrix dimensions 问题补充:把从一个矩阵中提取某些元素作为子函数怎么写程序啊? index exceeds matrix dimensions 。说的是下标超过矩阵

matlab中利用DelaunayTri()建立约束三角网时函数参数输入后,出现错误...
The input must contain index values in the range 1 to num-points 你的范围超过了索引范围,必需在1到num-points点之间 例如:rand('state',0);x = rand(1,10);y = rand(1,10);TRI = delaunay(x,y);subplot(1,2,1),...triplot(TRI,x,y)axis([0 1 0 1]);hold on;plot(x...

list index out of bounds (18) 运行程序时出现这个提示,求高手解答...
这个错误并不会影响游戏的执行,仍然可以正常游戏。不必担心,只需手动结束launcher进程即可。 追问: 不是游戏的问题,是一个上报软件,导入数据的时候就出现这个问题 回答: 导入数据的时候 影响导入吗? 追问: 当然了 导不进去 不然就不管它了 回答: 你用的execel吗? 追问:...

MATLAB调用M文件时出错,出现Error: Function definitions are not...
temp(1)=[]; %删除第一个为零的误差 temp=abs(temp);rel=sum(temp)\/(n-1)*100;残差Gm(1,1)function [px0,ab,rel]=ccgm11(x0,number)[px0,ab,rel]=gm11(x0,number)px0为残差预测数列,ab为求得的系数,rel为平均相对误差(为百分比)默认的number参数为原数组大小 if nargin==1...

...可是不管怎么弄,都提示出现致命错误,求高手解答。
一,系统崩溃了,需要重装系统。二,硬件问题一般是内存问题或是硬盘问题。你可以先重装系统看看。或开机按F8进最后一次正确配置看看行不。重装系统不好就得排除硬件了。

MATLAB2010b在win7上怎么打开后马上消失了???出现如图所示的错误,求...
可能是这个系统不支持你安装的版本,之前我也装过一个,一部分功能能用,但是好像是不能运行和保存,之后安装到xp里的就全好了。

access violation ?C程序编写中出现的问题,求高手解答
cout<<"输入错误\\n"; break; } return 0;}不知道为什么输入3个字符字符是还能正常工作,但是输入4个或者以上时,就出现了access violation的问题,求真相啊。 展开  我来答 分享 微信扫一扫 新浪微博 QQ空间 举报 浏览52 次 可选中1个或多个下面的关键词,搜索相关资料。也可直接点“搜索资料”搜索整个...

急!求高手解答狂怒什么会应用程序错误
楼主你好,有可能是1:中了木马病毒。2:软件不兼容,3内存错误,楼主自己检测一下吧。如果楼主对于这方面知识不太懂的话建议来菜鸟网络注册个帐号多学习点电脑系统方面的知识。

...ArrayIndexOutOfBoundsException: 求高手解答,谢谢
你看看代码的第19行 else{ b[i][j]=b[i-1][j]+b[i-1][j-1]; \/\/这里。如果i=0;b[-1][j] +b[-1][j-1] 数组下标为 “-1” 。有问题,修正一下吧 }

...完成后打开应用程序时出现下面的错误,求高手解答啊~~~
你的product文件中没有导入相关插件。操作方法:打开product文件,打开依赖性视图,点击添加必须的插件

ode45求解高阶微分方程组,求高手解答
先用简单的方程熟悉函数使用方法。你显然是翻了基本语法错误,数组长度不对。

相似回答