Error using plot Vectors must be the same lengths.意思是t和h1,h2,h3的长度不是一致的。到底问题出在哪里?你的h1的值计算是没有错的,长度是一致的,但是你的h2和h3的值所得出来的矩阵元素个数却大的惊人,h2 =
首先,x=-pi:-pi/10:pi;这句有问题,由-pi到pi,但步距为-pi/10,这样会得到空矩阵。怀疑应为x=pi:-pi/10:pi;。虽然报错在第三句,但问题其实在前面。其次,y=(sin(x)+cos(x))/(tan(x));这句也很可疑
[I map]=imread('c:\美女\杨明菲131027 1.jpg','jpg'); %图像数据的读取,将图像数据放入矩阵A中,颜色数据放入矩阵M中 imshow(I,map);
可能的原因是,这段程序本来用于处理别的图像文件,被你换了一张图片。程序原来处理的图片应该是索引色的(indexed image),图像数据是二维数组,而你现在的图片是真彩色(RGB image),图像数据是三维数组,所以,在上面一行
你这里面错误好多,应该根据程序的提示好好检查一下。clear;clc;SNR=10; %信噪比fl=128; %设置FFT长度Ns=6; %设置一个祯结构中OFDM信号的个数para=128; %设置并行传输的子载波个数sr=250000; %符号
matlab Error in ==> Untitled3 at 4 ich3=[ich2(para-gl+1:para,:);ich2]; 真的是要疯了 到底哪里错了呀
那么很显然你的错误就是,没有把当前定义好。下面给出代码:H1=20;H2=20;H3=20;g=9.8;h1 =[ ];h2=[ ];h3=[];i=0;for t =0:0.01:10i=i+1;%%设置下标,来表示当前h1,h2,h3的元素if (sqrt(H1)-0.
一、右击 授予访问权限 二、点击特定用户 三、将everyone那里改为读取/写入,就可以了
可能的原因是,这段程序本来用于处理别的图像文件,被你换了一张图片。程序原来处理的图片应该是索引色的(indexed image),图像数据是二维数组,而你现在的图片是真彩色(RGB image),图像数据是三维数组,所以,在上面一行
应该是c或c++了,VB和Delphi也接触过,我想版面(matlab版)大部分人也差不多),如果你抱着“把其他语言的思想运用在matlab里面”的话,那么我想,即使程序运行不 出错,也很难把握matlab的精髓,也就很难发挥matlab的作
你的目的是将data1加载为变量名为c1的变量,但这里可能出了问题。将load data1 c1换为 s=load('data1.mat');sc=struct2cell(s);c1=cell2mat(sc);如果你知道data1里变量的名称且不想改为另外的名字的话,直接load
Matlab老是报错出错untitled>QPSKsave(’signal.mat’,’m’)
数组越界了,看看wz{c(1)}中c(1)的值,再看看wz的长度
function [db,mag,pha,grd,w] = freqz_m(b,a);[H,w] = freqz(b,a,1000,'whole');H = (H(1:1:501))'; w = (w(1:1:501))';mag = abs(H);db = 20*log10((mag+eps)/max(mag));pha = an
[I map]=imread('c:\美女\杨明菲131027 1.jpg','jpg'); %图像数据的读取,将图像数据放入矩阵A中,颜色数据放入矩阵M中 imshow(I,map);
可能的原因是,这段程序本来用于处理别的图像文件,被你换了一张图片。程序原来处理的图片应该是索引色的(indexed image),图像数据是二维数组,而你现在的图片是真彩色(RGB image),图像数据是三维数组,所以,在上面一行
MATLAB程序执行后出现这种情况,请大神知道,急急急!!!Error in ==> Untitled at 10 if mask(i,j)==0;
第一个错误 x=imresize(imread('C:/MATLAB7/work/bridge.gif');少一个右括号,其次,应该加一个参数scalar,可以改为 scalar=1.5;x=imresize(imread('C:/MATLAB7/work/bridge.gif'),scalar);m=imresize(imread('
MATLAB程序运行错误后,切换到MATLAB命令行中,观察命令行中的错误信息,确定错误原因。1、你可能写了个脚本程序文件,其中定义了子函数,在运行时就弹出了这个提示。一般情况下,在函数文件中才能定义子函数,在脚本文件中不
1.你的程序里是zd按照符号运算的。符号运算不用plot,好像用要用ezplot的。2.我不知道版你程序里的权物理概念,但改一下就行:syms L I Rs Rr a Rg Z x y I=1000 L=2 Rg=15 Rs=0.026 Rr=0.0001 Z=(Rg
运行:n=1;while prod(1:n) < 1e100 n=n+1;end n 结果:n = 70 后面加个n就ok。
可能的原因是,这段程序本来用于处理别的图像文件,被你换了一张图片。程序原来处理的图片应该是索引色的(indexed image),图像数据是二维数组,而你现在的图片是真彩色(RGB image),图像数据是三维数组,所以,在上面一行
Untitled7 是指你所编写代码的文件名,该名称为默认命名的。at 19一般指错误在Untitled7.m文件的第19行~给你个建议,提问时题目最好叙述的详细一些,以方便网友回答,祝好。
这个是提示第7行出现了错误。根据题主的问题 错误发生在f1=(99*cos(x)*(99*sin(x) + 15))/((99*sin(x) + 15)^2 + 24025)^(1/2) - 99*sin(x); 这一句当中 根据分析表达式,错误应该是矩阵乘法中维数不
Matlab 程序运行后出现Untitled at 7是什么错误
修改建议 把程序原来的第一行 img=double(imread('C:\Users\lenovo\Desktop\wj.jpg'));改为 img=imread('C:\Users\lenovo\Desktop\wj.jpg');if ndims(img) > 2 [img,map] = rgb2ind(img, 256);endimg =
下面是具体解决步骤:打开MATLAB2009,点击菜单栏的“File”,选择“新建”->“模型”,生成一个模型文件。连接好原理图,点击运行按钮,却弹出下面的对话框,显示这样的语句:“Simscape components in untitled are not
这个是提示第7行出现了错误。根据题主的问题 错误发生在f1=(99*cos(x)*(99*sin(x) + 15))/((99*sin(x) + 15)^2 + 24025)^(1/2) - 99*sin(x); 这一句当中 根据分析表达式,错误应该是矩阵乘法中维数不
1.你的程序里是zd按照符号运算的。符号运算不用plot,好像用要用ezplot的。2.我不知道版你程序里的权物理概念,但改一下就行:syms L I Rs Rr a Rg Z x y I=1000 L=2 Rg=15 Rs=0.026 Rr=0.0001 Z=(Rg
所谓untitled的意思就是“没有命名的文件”,属于matlab默认文件名。当你保存文件时,如果不修改文件名,系统以untitled为名字保存。
n=1;while prod(1:n) < 1e100 n=n+1;end n 结果:n = 70 后面加个n就ok。
Matlab 显示untitled
这个是提示第7行出现了错误。根据题主的问题 错误发生在f1=(99*cos(x)*(99*sin(x) + 15))/((99*sin(x) + 15)^2 + 24025)^(1/2) - 99*sin(x); 这一句当中 根据分析表达式,错误应该是矩阵乘法中维数不匹配造成,原表达式应改为: f1=(99*cos(x).*(99*sin(x) + 15))./((99*sin(x) + 15)^2 + 24025).^(1/2) - 99*sin(x);所谓untitled的意思就是“没有命名的文件”,属于matlab默认文件名。当你保存文件时,如果不修改文件名,系统以untitled为名字保存。
Untitled7 是当前m文件的文件名字 at 19应该是在这个程序的17行
Untitled7 是指你所编写代码的文件名,该名称为默认命名的。at 19一般指错误在Untitled7.m文件的第19行~ 给你个建议,提问时题目最好叙述的详细一些,以方便网友回答,祝好。
这个是提示第7行出现了错误。根据题主的问题 错误发生在f1=(99*cos(x)*(99*sin(x) + 15))/((99*sin(x) + 15)^2 + 24025)^(1/2) - 99*sin(x); 这一句当中 根据分析表达式,错误应该是矩阵乘法中维数不匹配造成,原表达式应改为: f1=(99*cos(x).*(99*sin(x) + 15))./((99*sin(x) + 15)^2 + 24025).^(1/2) - 99*sin(x);
将Figure需要改为小写哈figure;另外Inshow函数应该是Imshow函数哈
MATLAB是一种对技术计算高性能的语言。 它集成了计算,可视化和编程于一个易用的环境中,在此环境下,问题和解答都表达为我们熟悉的数学符号。 典型的应用有: 数学和计算 算法开发 建模,模拟和原形化 数据分析,探索和可视化 科学与工程制图 应用开发,包括图形用户界面的建立 MATLAB是一个交互式的系统,其基本数据元素是无须定义维数的数组。 这让你能解决很多技术计算的问题,尤其是那些要用到矩阵和向量表达式的问题。而要花的时间则只是用一种标量非交互语言(例如C或Fortran)写一个程序的时间的一小部分。
一、字符和字符串 在MATLAB中不管是字符,还是字符串都是用单引号。而在C、C++、C#、Java等语言中,字符是用单引号的,字符串则必须用双引号。因此在MATLAB中如果需要在字符串中用到单引号的话,就要用两个单引号来代替。 如: >> a='this''is an apple' a = this'is an apple 同理,如果字符串中需要双引号的话,可以用四个单引号来代替。如下: >> b='I''''am Tim' b = I''am Tim 在MATLAB中的字符串连接,我们可以使用一对中括号。当然,这种连接方式也适用于向量、矩阵等的连接。如下: >> c=[a b] c = this'is an appleI''am Tim >> a1=[1 2];b1=[3 4]; >> c1=[a1 b1] c1 = 1 2 3 4 >> c2=[a1;b1] c2 = 1 2 3 4 但是,对于字符串的连接不能使用加号(+)来进行。这点和在C++、C#、Java等语言中是不一样的。因为在MATLAB中这些字符串也是以矩阵的形式存储的,你要是用加号的话,需要两个矩阵的大小一致。比如: >> a2='hello';b2='mustb'; >> a2+b2 ans = 213 218 223 224 209 但是,很明显,加完之后都是一系列的值了。本来,这些字符串也是以数值的形式存储的。而我们要取的字符串中某一个字符的时候,也是很方便的,直接像引用矩阵的元素一样。如下: >> a2(1) ans = h >> a2(4) ans = l >> find(a2>'i') ans = 3 4 5 可以看到,a2里面在字母i后面的字符有第3、4、5个字符,也就是llo了。 在MATLAB中要将一个数字转换为字符可以用num2str,将字符转换为数字可以用str2num。如下: >> stra1=num2str(a1) stra1 = 1 2 >> class(stra1) ans = char >> strb1='[3 4]'; >> str2num(strb1) ans = 3 4 对于strb1,我们可以使用eval函数,该函数可以将字符串作为一个MATLAB命令去执行。如下: >> p=eval(strb1) p = 3 4 相当于p=[3 4]。 当然了,C语言里面的sprintf、fprintf函数我们都是可以在MATLAB中使用的。比如: >> sprintf('Tim is %d years old.',24) ans = Tim is 24 years old. 至于fprintf函数,则需要用fopen去打开一个文件,然后写入数据进去。如下: >> fd=fopen('a.txt','w+'); >> fprintf(fd,'I am Tim.\n'); >> fprintf(fd,'My age is %d\n',24); >> fclose(fd); 然后,用MATLAB Editor打开MATLAB当前目录下的a.txt就可以看到: 但是,当你用记事本打开的时候会看到: 这是因为在Windows上要想换行需要\r\n,而不能单是\n。 二、if语句、for语句、switch语句、while语句、try-catch语句都以end结尾 在MATLAB中,没有goto和do…loop和do…while语句。而且语句的结尾都是以end结尾的。 >> t=4; >> if(t<5),disp('t is smaller than 5.'),end t is smaller than 5. 当然,if语句也可以有else语句。 >> if(t>5),disp('t is bigger than 5.'),else,disp('t is smaller than 5.'),end t is smaller than 5. 还可以用elseif。 >> if(t>5),disp('t is bigger than 5.'),elseif(t==5),disp('t is equal 5.'),else,disp('t is smaller than 5.'),end t is smaller than 5. 在MATLAB中,由于矩阵的索引都是从1开始的,这点和C、C++、C#、JAVA等语言是不一样的。所以,在循环的时候建议从1开始循环,而且循环的时候不推荐用变量i和j。因为这两个变量在MATLAB中表示的是复数的虚部变量。当然,如果你的程序里面没有复数,就不用怕。如果有复数,就要小心了。 之所以从1开始,是因为大多数时候我们使用循环是为了依次能访问到矩阵的每一个元素,所以,如果矩阵的索引出现了0,那么就会报出错误。所以,从1开始循环,是一种很好的习惯,而不是要求你必须这样做。 而且,在for循环中,你的循环变量不仅可以是一个数,也可以是一个向量。看下面的程序: >> aa=[1 2;3 4; 5 6;7 8]; >> for i=aa,disp(i),end 1 3 5 7 2 4 6 8 >> aa aa = 1 2 3 4 5 6 7 8 也就是说,i第一次的值是aa的第一列,i第二次的值是aa的第二列。这样的话,这个循环变量i就不仅仅是一个数了,二是一列数。 在MATLAB中,switch语句中是不用break的,而且默认的选项不是default,而是otherwise。如下: a=5; switch(a), case 1, disp('a is 1.'); case 2, disp('a is 2.'); case 5, disp('a is 5.'); otherwise, disp('sorry, i do not know.'); end 还需要注意的是case后面没有分号,而C、C++、C#、Java等语言中是必须是分号的。在MATLAB中可是没有分号,我程序中的逗号,也可以是没有的。指向上面的程序,在MATLAB中的输出是: a is 5. 至于while语句的使用和C、C++、C#、Java等语言中的while基本上是一致的。如下: a=5; b=0; while a>0 b=b+a; a=a-1; end b a Matlab命令窗口的输出是这样的: b = 15 a = 0 try-catch语句一般是用来捕捉错误的。 try a=input('Input a number: '); catch error('unknown error.'); end 当运行上面的程序,在MATLAB中输入: Input a number: # ??? Error using ==> tim_try at 4 unknown error. 三、变量不用声明 在MATLAB中的变量是可以不用声明的,这点和C类语言和Java是有很大区别的。但是,为了程序更清晰和加快程序的执行速度,提供初始化和声明有时是必要的。不如, b=[]; for i=1:10 b=[b i]; end b 在MATLAB命令窗口的输出如下: b = 1 2 3 4 5 6 7 8 9 10 如果你不初始化b为空的话,如下: for i=1:10 b=[b i]; end b 在命令窗口的输出如下:??? Undefined function or variable 'b'. 上面说过了,中括号[]可以用来合并向量的,这里变量b不存在,因此不能合并。所以会出错。 四、没有++、--操作符 在MATLAB中是没有++和--操作符的,因此需要转换。如a++; 可以转化为a=a+1;至于++a;你只需要将a=a+1的位置放到前面就可以了。 五、点乘、点除,但没有点加、点减 在点乘,是矩阵中的对应元素相乘。而不是矩阵的乘法。点除也是同样道理,对应元素想除。至于点加,就相当于加法。因为加减法本身就是对应元素的加减。 六、左除和右除 在C类和Java等语言中,除法就是一个操作符(/),但在MATLAB中(/)和(\)是有区别的。/代表的是右除,\代表的是左除。 >> A=[1 2;3 4];B=[5 6;7 8]; >> C1=A\B C1 = -3 -4 4 5 所以A左除B,就相当于A的逆矩阵乘B。 >> inv(A)*B ans = -3.0000 -4.0000 4.0000 5.0000 那么可想而知,A右除B,就相当于A乘B的逆矩阵。 >> A/B ans = 3.0000 -2.0000 2.0000 -1.0000 >> A*inv(B) ans = 3.0000 -2.0000 2.0000 -1.0000 七、MATLAB的编程思想 当你用MATLAB来写程序的时候,尽量以向量、矩阵为单位来考虑问题。也就是在MATLAB中常常能用一个点乘来代替多个循环的操作。也就是用向量化的操作来代替循环,这样能够大大的提高MATLAB程序的运行速度。 举个简单的例子: clear all clc a=round(rand(100)*100); b=round(rand(100)*100); tic f1=a.*b; toc tic for i=1:100, for j=1:100, f2(i,j)=a(i,j)*b(i,j); end end toc 在命令窗口的输出如下: Elapsed time is 0.000035 seconds. Elapsed time is 0.001871 seconds. 如果我们给f2初始化下,看看能不能加快速度。 clear all clc a=round(rand(100)*100); b=round(rand(100)*100); tic f1=a.*b; toc f2=zeros(100); tic for i=1:100, for j=1:100, f2(i,j)=a(i,j)*b(i,j); end end toc 此时,命令窗口的输出如下: Elapsed time is 0.000024 seconds. Elapsed time is 0.000147 seconds. 可以看到后面的循环的时间明显提高了很多。那么我们为上面的点乘运算的f1也初始化的话,速度会如何? Elapsed time is 0.000022 seconds. Elapsed time is 0.000146 seconds. 可以看到速度提升的不是很明显。如果你将a和b的维数增长到10000的话,提示的速度就明显了很多了。
function [ output_args ] = Untitled1( input_args ) %UNTITLED1 Summary of this function goes here % Detailed explanation goes here %数据调制采用QPSK clear; clc; %clc是清除当前command区域的命令,表示清空,看着舒服些 。而clear用于清空环境变量 SNR=10; % 信噪比 Nfft=128; % 设置FFT长度 Ns=6; %设置一个祯结构中OFDM信号的个数 para=128;%设置并行传输的子载波个数 sr=250000; %符号速率 br=sr.*2;% 每个子载波的比特率 gl=32; %保护时隙的长度 Signal=rand(1,para*Ns*2)>0.5;%产生0,1 随即序列,符号数为para*Ns*2 %(子信道个数×调制水平×每个子信道中有用符号个数) for i=1:para for j=1:Ns*2 SigPara(i,j)=Signal(i*j);%串并变换 %将随机产生的二进制矩阵变换为行数为para,列数为2*Ns的矩阵 end end %QPSK调制,将数据分为两个通道 for j=1:Ns ich(:,j)=SigPara(:,2*j-1); qch(:,j)=SigPara(:,2*j); end kmod=1./sqrt(2); ich1=ich.*kmod; qch1=qch.*kmod; x=ich1+qch1.*sqrt(-1); %频域数据变时域 y=ifft(x); ich2=real(y); qch2=imag(y); %插入保护间隔 ich3=[ich2(Nfft-gl+1:Nfft,:);ich2]; qch3=[qch2(Nfft-gl+1:Nfft,:);qch2]; %并串变换 ich4=reshape(ich3,1,(Nfft+gl)*Ns); qch4=reshape(qch3,1,(Nfft+gl)*Ns); %形成复数发射数据 TrData=ich4+qch4.*sqrt(-1); %接收机 %加入高斯白噪声 ReData=awgn(TrData,SNR,'measured'); %接收端 %移去保护间隔 idata=real(ReData); qdata=imag(ReData); idata1=reshape(idata,Nfft+gl,Ns); qdata1=reshape(qdata,Nfft+gl,Ns); idata2=idata1(gl+1:gl+Nfft,:); qdata2=qdata1(gl+1:gl+Nfft,:); %FFT Rex=idata2+qdata2*sqrt(-1); ry=fft(Rex); ReIChan=real(ry); ReQChan=imag(ry); ReIchan=ReIChan/kmod; ReQchan=ReQChan/kmod; %QPSK逆映射 for j=1:Ns RePara(:,2*j-1)=ReIChan(:,j); RePara(:,2*j)=ReQChan(:,j); end ReSig=reshape(RePara,1,para*Ns*2); %符号抽样判决 ReSig=ReSig>0.5; figure(1); subplot(2,1,1),stem(ReSig(1:20)),grid minor; title('resignal'); xlabel('x'),ylabel('y'); subplot(2,1,2),stem(Signal(1:20)),grid; title('signal'); 你的程序缺好多参数,已补全~
检查一下for和end有没有对应。我眼花怎么觉得你写了两个for,却有三个end