MATLAB 实用教程 课后习题答案

MATLAB 实用教程 课后习题答案
MATLAB 实用教程 课后习题答案

第二章

1.计算复数3+4i与5-6i的乘积。

a=3+4i

b=5-6i

c=a*b

2.构建结构体Students,属性包含Name、age和Email,数据包括{’Zhang’,18,*‘Zhang@16

https://www.360docs.net/doc/009925412.html,’,’Zhang@https://www.360docs.net/doc/009925412.html,’+}、{’Wang’,21,[]}和{’Li’,[],[]},构建后读取所有Name属性值,并且修改’Zhang’的Age属性值为19。

Students(1).Age=18

Students(1).Email='zhang@https://www.360docs.net/doc/009925412.html,','zhang@https://www.360docs.net/doc/009925412.html,'

Students(2).Name='Wang'

Students(2).Age=21

Students(2).Email=[]

Students(3).Name='Li'

Students(3).Age=[]

Students(3).Email=[]

https://www.360docs.net/doc/009925412.html,

Student(1).Age(1)=19

Student.Age

3.用满矩阵和稀疏矩阵存储方式分别构造下属矩阵:

A=[0 1 0 0 0;1 0 0 0 0;0 0 0 0 0;0 0 0 1 0]

A=[0 1 0 0 0;1 0 0 0 0;0 0 0 0 0;0 0 0 1 0]

S=sparse(A)

S=sparse([2,1,4],[1,2,4],[1,1,1],4,5)

4.采用向量构造符得到向量[1,5,9....,41].

A=1:4:41

5.按水平和竖直方向分别合并下述两个矩阵:A=[1 0 0;1 1 0;0 0 1],B=[2 3 4;5 6 7;8 9 10]

A=[1 0 0;1 1 0;0 0 1]

B=[2 3 4;5 6 7;8 9 10]

C=[A B]

D=[A;B]

6.分别删除第五题两个结果的第2行。

A=[1 0 0;1 1 0;0 0 1]

B=[2 3 4;5 6 7;8 9 10]

C=[A B]

D=[A;B]

C(2,:)=[]

D(2,:)=[]

7.分别将第5题两个结果的第2行最后3列的数值改为[11 12 13]。

A=[1 0 0;1 1 0;0 0 1]

B=[2 3 4;5 6 7;8 9 10]

C=[A B]

D=[A;B]

C(2,4:6)=[11 12 13]

D(2,:)=[11 12 13]

8.分别查看第5题两个结果的各方向长度

A=[1 0 0;1 1 0;0 0 1]

B=[2 3 4;5 6 7;8 9 10]

C=[A B]

D=[A;B]

a=size(C)

b=size(D)

9.分别判断pi是否为字符串和浮点数。

tf=ischar(pi)

tf=isfloat(pi)

10.分别将第5题两个结果均转换为2*9的矩阵。

A=[1 0 0;1 1 0;0 0 1]

B=[2 3 4;5 6 7;8 9 10]

C=[A B]

D=[A;B]

E=reshape(C,2,9)

F=reshape(D,2,9)

11.计算第5题矩阵A的转秩。

A=[1 0 0;1 1 0;0 0 1]

B=transpose(A)

12.分别计算第5题矩阵A和B的A+B、A.\B和A\B。

A=[1 0 0;1 1 0;0 0 1]

B=[2 3 4;5 6 7;8 9 10]

C=A+B

D=A.*B

E=A\B

13.判断第5题矩阵A和B中哪些元素值不小于4。

A=[1 0 0;1 1 0;0 0 1]

B=[2 3 4;5 6 7;8 9 10]

A>=4

B>=4

14.分别用函数strcat()和矩阵合并符合并如下字符串:’The picture is’和’very good’。a=' The picture is '

b=' very good '

c=strcat(a,b)

d=[a b]

15.创建字符串数组,其中元素分别为’Picture’和’Pitch’。

a=char('Picture','Pitch')

16.在第14题结果中查找字符串’e’。

a=' The picture is '

b=' very good '

c=strcat(a,b)

d=[a b]

e=strfind(c,'e')

f=strfind(d,'e')

17.在第15题结果中匹配字符串’Pi’。

a=char('Picture','Pitch')

x=strmatch('Pi',a)

18.将字符串’very good’转换为等值的整数。

a=double('very good')

19.将十进制的50转换为二进制的字符串。

a=dec2bin(50)

20将十六进制的字符串’50’转换为三进制的整数。

a=hex2dec('50')

第三章

1.计算矩阵A的二范数、行列式、秩、化零空间和正交空间。

A=[17 24 1 8 50;23 5 7 14 49;4 6 13 20 43;10 12 19 21 62;11 18 25 2 56]

N=norm(A)

A_det=det(A)

Z=null(A)

Q=orth(A)

b=rank(A)

A=[17 24 1 8 50;23 5 7 14 49;4 6 13 20 43;10 12 19 21 62;11 18 25 2 56]

2.求解线性方程组AX=B,其中A如第1题所示,B=[1 1 1 1 1]的转秩。

A=[17 24 1 8 50;23 5 7 14 49;4 6 13 20 43;10 12 19 21 62;11 18 25 2 56]

B=transpose([1 1 1 1 1])

X=A\B

3.对矩阵A进行LU分解和Schur分解,其中A如第1题。

A=[17 24 1 8 50;23 5 7 14 49;4 6 13 20 43;10 12 19 21 62;11 18 25 2 56]

[L1,U1]=lu(A)

[U2,L2]=schur(A)

4对矩阵A的前4行进行QR分解和奇异值分解,其中A如第1题。

A=[17 24 1 8 50;23 5 7 14 49;4 6 13 20 43;10 12 19 21 62;11 18 25 2 56]

B=A(1:4,:)

[Q,R]=qr(B)

[U S V]=svd(B)

5计算矩阵A的特征值及对应的特征向量,判断矩阵A是否可对角化,其中A如第1题。A=[17 24 1 8 50;23 5 7 14 49;4 6 13 20 43;10 12 19 21 62;11 18 25 2 56]

[V,D]=eig(A)

a=inv(V)*A*V-D

6.计算矩阵A的指数、开平方和余弦值,其中A如第1题。

A=[17 24 1 8 50;23 5 7 14 49;4 6 13 20 43;10 12 19 21 62;11 18 25 2 56]

Y1=expm(A)

Y2=sqrtm(A)

Y3=funm(A,@cos)

7.计算矩阵A每个元素的指数、开平方和余弦值(元素单位为度),其中A如第1题。

A=[17 24 1 8 50;23 5 7 14 49;4 6 13 20 43;10 12 19 21 62;11 18 25 2 56]

Y1=exp(A)

Y2=sqrt(A)

Y3=cosd(A)

8.计算复数矩阵C每个元素的模、相角和共轭。

C=[3+4i 2 –i -i;2 -2 0]。

C=[3+4i 2-i -i;2 -2 0]

Y1=abs(C)

Y2=angle(C)

Y3=conj(C)

9.分别使用函数fix()、floor()、ceil()和round(),计算第8题中的相角结果。

C=[3+4i 2-i -i;2 -2 0]

Y1=fix(C)

Y2=floor(C)

Y3=ceil(C)

Y4=round(C)

10.将2-i的模结果近似为有理数,并以数值形式显示。

a=2-i

Y1=abs(a)

Y2=rats(Y1)

11.计算,其中m=4!和n是42与35的最大公因式。

n=gcd(42,35)

m=factorial(4)

c=nchoosek(m,n)

12.将球坐标系中的点(1,1,1)分别转换到笛卡尔坐标系和极坐标系。

[a,b,c]=sph2cart(1,1,1)

[d,e,f]=cart2pol(a,b,c)

第四章

1.创建脚本实现随机数序列的各元素由大到小排列,其中随机数服从U(-5,9)的均匀分布,并且序列长度为10。

clear

clc

A=unifrnd(-5,9,1,10)

n=10;

for i=1:n-1

for j=i+1:n

if A(i)

tmpx=A(j);

A(j)=A(i);

A(i)=tmpx;

end

end

end

A

2.创建函数实现指定长度的随机数序列的各元素由大到小排列,其中随机数服从N (3,9)的高斯分布。

clear

clc

n=input('data length')

A=normrnd(3,9,1,n);

B=sort(A,'descend')

for i=1:n-1

for j=i+1:n

if A(i)

tmpx=A(j);

A(j)=A(i);

A(i)=tmpx;

end

end

end

A

3.提示用户输入1或2,如输入1时,执行第一题的脚本;如输入2时,提示用户输入随机数序列长度,然后执行第二题的函数。

clear

clc

r=input('1 or 2')

switch r

case 1

disp('????????d1')

edit d1.m

case 2

n=input('??????????????ò??????¤????????') disp('????????d2')

edit d2.m

end

4.分别选用if 或switch 结构实现下述函数表示。f(x,y)=??

???==e ╰otherwis x cos x sin 2y Cos(x) 1y Sin(x))()(

f(x)=?????????><=<--<=<<=<--<=d x d x c d x d c c

x b b x a a x a b a x --------------------0---------)(/1--------------------1----------)(/1---------------------0

5.分别用for 和while 结构实现如下函数计算。

Sin (x )-cos (x )+sin (2x )+cos (2x )+……+sin(nx)+(-1)^xCos(nx)

expAt+AexpAt+…..+A^nxexpA^nt,其中A=[1 2 3;0 1 2;0 0 1]

6.在第3题的代码中添加continue 、break 、return 、echo 等命令,熟悉他们的用法。

7.计算n 个随机数的自然对数,并对运算结果求其算术平方根和四舍五入的和,其中,随机数服从U (-2,2)的均匀分布。运行下述函数并进行调试。

第五章

1.绘制函数y=sin (x )cos (x )在[-2,2]上的曲线,其中曲线为红实线。

x=-2:0.01:2;

y=sin(x).*cos(x);

plot(x,y,'-r')

2.绘制函数x^2/9+y^2/16=1的边界。

ezplot('16*x^2+9*y^2-144',[-3,3,-4,4])

3.绘制函数????

??2y 1y =???

? ??)1x (cos 2x )2x (sin 1x 在x1,x2∈[-2,2]上的曲线,其中数据点为菱形。 x1=-2:2;

x2=-2:2;

x=[x1 x2];

y1=x1'*sin(x2);

y2=x2'*cos(x1);

y=[y1 y2];

plot(x,y,'d')

4.在第三题结果的上基础上绘制对应的等高线。

x1=-2:2;

x2=-2:2;

y1=x1'*sin(x2);

y2=x2'*cos(x1);

meshc(y1)

hold on

meshc(y2)

5.在第二题结果的基础上对坐标轴进行标注,标注内容为对应变量的范围并添加标题“解曲

线”。

ezplot('16*x^2+9*y^2-144',[-3,3,-4,4])

xlabel('x[-3,3]')

ylabel('y[-4,4]')

title('解曲线')

6.在第三题结果基础上对曲线进行标注。

x1=-2:0.01:2;

x2=-2:0.01:2;

x=[x1;x2]

y=[x1.*sin(x2);x2.*cos(x1)]

plot(x,y,'d')

xlabel('x[-2,2]')

7.在第一题结果基础上将x轴的范围限定在[-3,3],y轴范围限定在[-1.5,1,5]。

x=-2:0.01:2

y=sin(x).*cos(x)

plot(x,y,'-r')

axis([-3 3 -1.5 1.5])

8.在第七题结果的基础上绘制网格。

x=-2:0.01:2

y=sin(x).*cos(x)

plot(x,y,'-r')

axis([-3 3 -1.5 1.5])

grid on

9.在第七题结果的基础上取10个点,并进行排序。

x=-2:0.01:2

y=sin(x).*cos(x)

plot(x,y,'-r')

axis([-3 3 -1.5 1.5])

[x,y]=ginput(10)

[b c]=sort([x,y])

10.在一个图形窗口依次绘制函数sin(x)、cos(x)、tg(x)、ctg(x)、sec(x)、cec(x)的曲线,并进行标注。

x=-pi:pi/20:pi

plot(x,sin(x),'r')

hold on

plot(x,cos(x),'y')

plot(x,tan(x),'b')

plot(x,atan(x),'g')

plot(x,sec(x),'m')

plot(x,asec(x),'c')

xlabel('x[-pi pi]')

ylabel('oˉêyè??μ')

title('?ú??')

11.在一个图形窗口中按3*2绘制第十题所列函数的子图。x=-pi:pi/20:pi;

subplot(2,3,1)

plot(x,sin(x))

title('sin')

subplot(2,3,2)

plot(x,cos(x))

title('cos')

subplot(2,3,3)

plot(x,tan(x))

title('tan')

subplot(2,3,4)

plot(x,atan(x))

title('atan')

subplot(2,3,5)

plot(x,sec(x))

title('sec')

subplot(2,3,6)

plot(x,asec(x))

title('asec')

13.在不同窗口绘制第十题所列函数图形。

x=-pi:pi/20:pi;

figure(1);

plot(x,sin(x));

title('sin');

figure(2);

plot(x,cos(x));

title('cos');

figure(3);

plot(x,tan(x));

title('tan');

figure(4);

plot(x,atan(x));

title('atan');

figure(5);

plot(x,sec(x));

title('sec');

figure(6);

plot(x,asec(x));

title('asec');

%14

i=10;

j=10;

A=unifrnd(-2,6,i,j)

A;

a=1:i;

b=1:j;

num=0;

for b=1:j

for a=1:i

if A(a,b)>1

num=num+1;

end

end

end

14.首先生成100个服从U(-2,6)的均匀分布随机数,其次按行排成10*10的矩阵,再次将数据保存在mydata.mat文件中,然后清除内存和屏幕,最后计算数据中大于1的个数。

15.首先将第四题的10*10的矩阵写入二进制文件,其次清除内存和关闭所有窗口,再次读入该矩阵,计算矩阵的逆。

x1=-2:1:2;

x2=-2:0.5:2;

y1=x1'*sin(x2);

x1=-2:0.5:2;

x2=-2:1:2;

y2=x2'*cos(x1);

A=y1;

B=y2;

C=[A;B]

fid=fopen('e15_1.m','w');

a=fwrite(fid,C,'float')

clear

clc

fclose('all');

fid=fopen('e15_1.m','r');

b=fread(fid,[10 10])

D=inv(b)

fclose(fid)

16.首先将第四题的10*10的矩阵写入文本文件,其次清除内存和关闭所有窗口,再次读入该矩阵,计算矩阵的指数。

x1=-2:1:2;

x2=-2:0.5:2;

y1=x1'*sin(x2);

x1=-2:0.5:2;

x2=-2:1:2;

y2=x2'*cos(x1);

A=y1;

B=y2;

C=[A;B]

fid=fopen('e16_1.txt','w');

a=fprintf(fid,'%g',C)

fclose('all');

fid=fopen('e16_1.txt','r');

b=fscanf(fid,'%d',[10 10])

D=expm(b)

fclose(fid);

17.通过文本指针控制,首先读取第十五题二进制文件中的第一行第二个数据,其次移动指针读取第一行第四个数据,再次读取倒数的1~5个数据,最后判断是否到文件末尾。

clear

clc

fid=fopen('e15_1.m','r');

p1=ftell(fid)

status1=fseek(fid,2,'bof')

a1=fread(fid,[1 1])

status2=fseek(fid,2,'cof')

a2=fread(fid,[1 1])

status3=fseek(fid,5,'eof')

a3=fread(fid,[1 5])

status4=feof(fid)

fclose(fid);

第六章

1.将多项式A的系数向量形式[1 2 4 2 1]转换为完整形式,并将多项式B的完整形式

2x^5+x^2+3x+5表示为系数向量形式。

syms x;

A=[1 2 4 2 1]

[s,len]=poly2str(A,'x')

B=2*x^5+x^2+3*x+5;

b=[2 0 0 1 3]

2.针对第一题A,计算自变量为1~10

A=[1 2 4 2 1];

p=[1 2 3 4 5 ;6 7 8 9 10];

r_A=polyval(A,p)

3.针对第一题A 和B,计算A和B的乘法和除法。

p1=[1 2 4 2 1];

p2=[2 0 0 1 3 5];

w=conv(p1,p2)

[q,r] = deconv(p2,p1);

sq=poly2str(q, 'x')

sr=poly2str(r, 'x')

4.针对第一题A 和B,计算A/B的微分。

A=[1 2 4 2 1];

B=[2 0 0 1 3 5];

[q,d]=polyder(A,B)

5.针对第一题A,计算其积分。

A=[1 2 4 2 1];

s1=polyint(A)

6.针对如下矩阵,计算其对应特征多项式。[1 1 1;2 3 4;4 9 16]

A=[1 1 1;2 3 4;4 9 16;];

p=poly(A);

sp= poly2str(p, 'x')

r=roots(p)

eA=eig(A)

7.针对第一题A,B,将A/B展成部分分式。

p1=[1 2 4 2 1];

p2=[2 0 0 1 3 5];

[r,p,k] = residue(A,B)

8.针对函数f(x)=expx在x∈{0,0.1,0.2,……,5}上的取值,采用多项式进行拟合,并对x∈{0.15,0.45,0.75}分别采用最邻近、双线性和三次样条插值方法进行插值。

x=0:0.1:5;

y=exp(x);

p=polyfit(x,y,5)

y=polyval(p,x)

plot(x,y,'ro')

xlabel('x');

ylabel('y');

x=0:0.1:5;

y=exp(x);

xi = [0.15,0.45,1.75]

yi_nearest = interp1(x,y,xi,'nearset');

yi_linear = interp1(x,y,xi);

yi_spline = interp1(x,y,xi,'spline ');

figure;

hold on;

subplot(1,3,1);

plot(x,y,'ro',xi,yi_nearest,'r-');

title('最邻近法');

subplot(1,3,2);

plot(x,y,'ro',xi,yi_linear,'b-');

title('双线性法');

subplot(1,3,3);

plot(x,y,'ro',xi,yi_spline,'g--');

title('三次样条插值法');

9.针对二维函数f(x)=expxy在x∈∈{0,0.1,0.2,......,5};y∈{0,0.1,0.2, (5)

上的取值,对(x,y)∈{(0.15,0.15),(0.45,0.45),(0.75,0.75)}分别采用最邻近、双线性和三次样条插值方法进行插值。

10.产生40个服从正态分布N(-1,4)的随机数,计算它们的最大值、最小值、平均值、中间值、元素和、标准差和方差,斌按照绝对值大小进行排序,同时标出原来的序列号。

y=normrnd(-1,4,1,40);

y_max=max(y)

y_min=min(y)

y_mean=mean(y)

y_sum=sum(y)

y_s=std(y)

y_var=var(y)

x=abs(y)

[z,iz]=sort(x)

11.产生五个样本,每个样本包含20个服从均匀分布U(3,4)的随机数,计算它们的协方差和相关系数矩阵。

y1=unifrnd(3,4,1,20)

y2=unifrnd(3,4,1,20)

y3=unifrnd(3,4,1,20)

y4=unifrnd(3,4,1,20)

a1 = cov(y1)

a2 = cov(y1,1)

a3 = corrcoef(y1)

b1 = cov(y2)

b2 = cov(y2,1)

b3 = corrcoef(y2)

c1 = cov(y3)

c2 = cov(y3,1)

c3 = corrcoef(y3)

d1 = cov(y4)

d2 = cov(y4,1)

d3 = corrcoef(y4)

12.实现对信号3*sin (t )+0.1(rand (1)-0.5)的一维二阶平均值数字滤波。 t=0:0.01:10;

s=3*sin(t);

x=3*sin(t)+0.1*(rand(1)-0.5);

a = 1;

b = [1/2 1/2];

y=filter(b,a,x);

plot(t,s,'g-');

hold on

plot(t,x,'b--');

plot(t,y,'r:');

axis([0 10 -30 30]);

xlabel('时间');

13.计算脉冲信号和单位正弦信号的卷积。

t=0:0.2:10;

u(1)=1;

v=sin(t);

w=conv(u,v);

figure

subplot(3,1,1);

stem(u);

title('u');

subplot(3,1,2);

stem(v);

title('v');

subplot(3,1,3);

stem(w);

title('w');

14.对比第十二题中滤波前后的频谱。

15.针对函数y=sin (1

2^x 1x ++)x ∈[0,10],绘制其图像,并计算最大值、最小值和零点。 f = @(x)sin((x+1)./(x.^2+1));

fplot(f,[0 10],1e-4,'r-');

title('y=sin((x+1)/(x^2+1))');

xlabel('x');

ylabel('y');

grid;

x_min=fminbnd(f,0,10)

x_zero = fzero(f,[-5,10])

16.针对第十五题的函数,计算在[0,10]上的积分。

f = @(x)sin((x+1)./(x.^2+1));

q = quad(f,0,10)

17.计算expxydxdy 0y -101??。

f=@(x,y) exp(x*y).*(x+y<=1)

dblquad(f,0,1,0,1,1e-6,@quadl)

18.通过在功能函数中使用含参函数,实现计算函数f (x )=x^2+ax+b 的零点。

19.计算微分方程y ’’’+2y ’’+y=expt(t ∈[0,2])且初始值为0的解。

20.计算微分方程(y^2+1)y ’=y(t ∈[0,2])且初始值为0的解。

第七章

1.计算一元三次方程ax^3+bx^2+cx+d=0(a ≠0)根的通式。

solve('a*x^3+b*x^2+c*x+d=0')

2.计算定积分xpxdx sinxe a

b ?。 syms x a b;

int (sin(x)*exp(x),a,b)

3.计算导数(sinxexpx )’.

x=sym('x');

diff(sin(x)*exp(x))

4.计算矩阵A=(aij )的2*2矩阵,和B=(bij)的2*2矩阵的加减乘。 syms a11 a12 a21 a22 b11 b12 b21 b22;

A=[a11,a12;a21,a22]

B=[b11,b12;b21,b22]

add=A+B

dec=A-B

mul=A*B

5.针对第四题中的A 和B ,计算A 2,sinB 和B A 1-.

syms a11 a12 a21 a22 b11 b12 b21 b22;

A=[a11,a12;a21,a22]

B=[b11,b12;b21,b22]

index=2^A

RES=sin(B)

res=inv(A)*B

6.因式分解符号多项式n x -1(n=1,2,3,……10),并化简结果。

syms x;

n=1:10;

x = x(ones(size(n)));

p=x.^n-1;

[p,factor(p)]'

7.针对第六题的符号多项式,计算x=pi 时具有3位有效数字的值。 x=pi;

n=1:10;

x = x(ones(size(n)));

p=x.^n-1;

vpa(p,3)

8.针对第四题中的A ,计算其逆、行列式、特征值和约当标准型。 syms a11 a12 a21 a22 ;

A=[a11,a12;a21,a22]

A_inv=inv(A)

A_det=det(A)

A_eig=eig(A)

A_jordan=jordan(A)

9.计算sinxexpx 在x →-∞时的极限。

syms x;

f=sin(x)*exp(x);

x_limit=limit(f,x,inf)

10.计算expx 在x=0处的泰勒级数,并计算级数和。

syms x;

f=exp(x);

r = taylor(f,50,x,0)

13.计算微分方程组???????==-x dt

dy y dy dx 的解。 ans=dsolve('Dx=y','Dy=-x','x','y','t')

disp(ans.x)

disp(ans.y)

matlab课后习题解答第二章

第2章符号运算 习题2及解答 1 说出以下四条指令产生的结果各属于哪种数据类型,是“双精度” 对象,还是“符号”符号对象 3/7+; sym(3/7+; sym('3/7+'); vpa(sym(3/7+) 〖目的〗 不能从显示形式判断数据类型,而必须依靠class指令。 〖解答〗 c1=3/7+ c2=sym(3/7+ c3=sym('3/7+') c4=vpa(sym(3/7+) Cs1=class(c1) Cs2=class(c2) Cs3=class(c3) Cs4=class(c4) c1 = c2 = 37/70 c3 = c4 = Cs1 = double Cs2 = sym Cs3 = sym Cs4 = sym 2 在不加专门指定的情况下,以下符号表达式中的哪一个变量被认 为是自由符号变量. sym('sin(w*t)'),sym('a*exp(-X)'),sym('z*exp(j*th)') 〖目的〗 理解自由符号变量的确认规则。 〖解答〗 symvar(sym('sin(w*t)'),1) ans = w symvar(sym('a*exp(-X)'),1)

ans = a symvar(sym('z*exp(j*th)'),1) ans = z 5求符号矩阵???? ??????=3332 31 232221 131211 a a a a a a a a a A 的行列式值和逆,所得结果应采用“子表达式置换”简洁化。 〖目的〗 理解subexpr 指令。 〖解答〗 A=sym('[a11 a12 a13;a21 a22 a23;a31 a32 a33]') DA=det(A) IA=inv(A); [IAs,d]=subexpr(IA,d) A = [ a11, a12, a13] [ a21, a22, a23] [ a31, a32, a33] DA = a11*a22*a33 - a11*a23*a32 - a12*a21*a33 + a12*a23*a31 + a13*a21*a32 - a13*a22*a31 IAs = [ d*(a22*a33 - a23*a32), -d*(a12*a33 - a13*a32), d*(a12*a23 - a13*a22)] [ -d*(a21*a33 - a23*a31), d*(a11*a33 - a13*a31), -d*(a11*a23 - a13*a21)] [ d*(a21*a32 - a22*a31), -d*(a11*a32 - a12*a31), d*(a11*a22 - a12*a21)] d = 1/(a11*a22*a33 - a11*a23*a32 - a12*a21*a33 + a12*a23*a31 + a13*a21*a32 - a13*a22*a31) 8(1)通过符号计算求t t y sin )(=的导数 dt dy 。(2)然后根据此结果,求- =0t dt dy 和2 π = t dt dy 。 〖目的〗 diff, limit 指令的应用。 如何理解运行结果。 〖解答〗 syms t

Matlab课后习题解答

P16 Q2: 计算表达式()2 tan arccos x x -在0.25x =和0.78x π =时的函数值。 function y=jie(x) y=tan(-x.^2)*acos(x); >> jie(0.25) ans = -0.0825 >> jie(0.78*pi) ans = 0 + 0.4418i Q3:编写M 命令文件,求5010 2 1 1 1k k k k ==+ ∑∑ 的值。 a=0;b=0; for i=1:50 a=a+i*i; end for j=1:10 b=b+1/j; end c=a+b; >> c c = 4.2928e+004 P27 Q2:矩阵1234567 8 9A ????=??????,4 685563 2 2B ?? ?? =? ????? ,计算A B *,.A B *,并比较两者的区别。 >> A=[1 2 3;4 5 6;7 8 9];

>> B=[4 6 8;5 5 6;3 2 2]; >> A*B ans = 23 22 26 59 61 74 95 100 122 >> A.*B ans = 4 12 24 20 25 36 21 16 18 A*B表示A与B两矩阵相乘。 A.*B表示A与B对应元素相乘。 P34 Q2:编写一个转换成绩等级的程序,其中成绩等级转换标准为:考试分数在[] 90,100显示为优秀;分数在[) 0,60的 60,80的显示为及格;分数在[) 80,90的显示为良好;分数在[) 显示为不及格。 if x>=90 disp('优秀'); elseif x>=80 disp('良好'); elseif x>=60 disp('及格'); else disp('不及格'); end >> x=85 x = 85 良好

matlab课后习题及答案详解

第1章 MATLAB概论 1.1与其他计算机语言相比较,MATLAB语言突出的特点是什么? MATLAB具有功能强大、使用方便、输入简捷、库函数丰富、开放性强等特点。 1.2 MATLAB系统由那些部分组成? MATLAB系统主要由开发环境、MATLAB数学函数库、MATLAB语言、图形功能和应用程序接口五个部分组成。 1.3 安装MATLAB时,在选择组件窗口中哪些部分必须勾选,没有勾选的部分以后如何补安装? 在安装MATLAB时,安装内容由选择组件窗口中个复选框是否被勾选来决定,可以根据自己的需要选择安装内容,但基本平台(即MATLAB选项)必须安装。第一次安装没有选择的内容在补安装时只需按照安装的过程进行,只是在选择组件时只勾选要补装的组件或工具箱即可。 1.4 MATLAB操作桌面有几个窗口?如何使某个窗口脱离桌面成为独立窗口?又如何将脱离出去的窗口重新放置到桌面上? 在MATLAB操作桌面上有五个窗口,在每个窗口的右上角有两个小按钮,一个是关闭窗口的Close按钮,一个是可以使窗口成为独立窗口的Undock按钮,点击Undock按钮就可以使该窗口脱离桌面成为独立窗口,在独立窗口的view菜单中选择Dock ……菜单项就可以将独立的窗口重新防止的桌面上。 1.5 如何启动M文件编辑/调试器? 在操作桌面上选择“建立新文件”或“打开文件”操作时,M文件编辑/调试器将被启动。在命令窗口中键入edit命令时也可以启动M文件编辑/调试器。 1.6 存储在工作空间中的数组能编辑吗?如何操作? 存储在工作空间的数组可以通过数组编辑器进行编辑:在工作空间浏览器中双击要编辑的数组名打开数组编辑器,再选中要修改的数据单元,输入修改内容即可。 1.7 命令历史窗口除了可以观察前面键入的命令外,还有什么用途? 命令历史窗口除了用于查询以前键入的命令外,还可以直接执行命令历史窗口中选定的内容、将选定的内容拷贝到剪贴板中、将选定内容直接拷贝到M文件中。 1.8 如何设置当前目录和搜索路径,在当前目录上的文件和在搜索路径上的文件有什么区别? 当前目录可以在当前目录浏览器窗口左上方的输入栏中设置,搜索路径可以通过选择操作桌面的file 菜单中的Set Path菜单项来完成。在没有特别说明的情况下,只有当前目录和搜索路径上的函数和文件能够被MATLAB运行和调用,如果在当前目录上有与搜索路径上相同文件名的文件时则优先执行当前目录上的文件,如果没有特别说明,数据文件将存储在当前目录上。 1.9 在MATLAB中有几种获得帮助的途径?

matlab程序设计第三章课后习题答案

1. p138 第6题在同一坐标轴中绘制下列两条曲线并标注两曲线交叉点。 >> t=0:0.01:pi; >> x1=t; >> y1=2*x1-0.5; >> x2=sin(3*t).*cos(t); >> y2=sin(3*t).*sin(t); >> plot(x1,y1,'r-',x2,y2,'g-') >> axis([-1,2,-1.5,1]) >> hold on >> s=solve('y=2*x-0.5','x=sin(3*t)*cos(t)','y=sin(3*t)*sin(t)'); >> plot(double(s.x),double(s.y),'*'); 截图:

p366 第4题绘制极坐标曲线,并分析对曲线形状的影响。 function [ output_args ] = Untitled2( input_args ) %UNTITLED2 Summary of this function goes here % Detailed explanation goes here theta=0:0.01:2*pi; a=input('请输入a的值:'); b=input('请输入b的值:'); n=input('请输入n的值:'); rho=a*sin(b+n*theta); polar(theta,rho,'k'); end 下面以a=1,b=1,n=1的极坐标图形为基础来分析a、b、n的影响。

对a的值进行改变:对比发现a只影响半径值的整倍变化 对b的值进行改变:对比发现b的值使这个圆转换了一定的角度

对n的值进行改变:对比发现当n>=2时有如下规律 1、当n为整数时,图形变为2n个花瓣状的图形 2、当n为奇数时,图形变为n个花瓣状的图形 分别让n为2、3、4、5

(完整版)matlab习题及答案(2)

第1章MATLAB概论 1.1与其他计算机语言相比较,MA TLAB语言突出的特点是什么? MATLAB具有功能强大、使用方便、输入简捷、库函数丰富、开放性强等特点。 1.2 MA TLAB系统由那些部分组成? MATLAB系统主要由开发环境、MA TLAB数学函数库、MATLAB语言、图形功能和应用程序接口五个部分组成。 1.3 安装MATLAB时,在选择组件窗口中哪些部分必须勾选,没有勾选的部分以后如何补安装? 在安装MA TLAB时,安装内容由选择组件窗口中个复选框是否被勾选来决定,可以根据自己的需要选择安装内容,但基本平台(即MATLAB选项)必须安装。第一次安装没有选择的内容在补安装时只需按照安装的过程进行,只是在选择组件时只勾选要补装的组件或工具箱即可。 1.4 MA TLAB操作桌面有几个窗口?如何使某个窗口脱离桌面成为独立窗口?又如何将脱离出去的窗口重新放置到桌面上? 在MA TLAB操作桌面上有五个窗口,在每个窗口的右上角有两个小按钮,一个是关闭窗口的Close按钮,一个是可以使窗口成为独立窗口的Undock按钮,点击Undock按钮就可以使该窗口脱离桌面成为独立窗口,在独立窗口的view菜单中选择Dock ……菜单项就可以将独立的窗口重新防止的桌面上。 1.5 如何启动M文件编辑/调试器? 在操作桌面上选择“建立新文件”或“打开文件”操作时,M文件编辑/调试器将被启动。在命令窗口中键入edit命令时也可以启动M文件编辑/调试器。 1.6 存储在工作空间中的数组能编辑吗?如何操作? 存储在工作空间的数组可以通过数组编辑器进行编辑:在工作空间浏览器中双击要编辑的数组名打开数组编辑器,再选中要修改的数据单元,输入修改内容即可。 1.7 命令历史窗口除了可以观察前面键入的命令外,还有什么用途? 命令历史窗口除了用于查询以前键入的命令外,还可以直接执行命令历史窗口中选定的内容、将选定的内容拷贝到剪贴板中、将选定内容直接拷贝到M文件中。

matlab基础练习题(带答案)

Matlab 基础练习题 常量、变量、表达式 1、 MATLAB 中,下面哪些变量名是合法的?( ) (A )_num (B )num_ (C )num- (D )-num 2、 在MA TLAB 中,要给出一个复数z 的模,应该使用( )函数。 (A )mod(z) (B )abs(z) (C )double(z) (D )angle(z) 3、 下面属于MATLAB 的预定义特殊变量的是?( ) (A )eps (B )none (C )zero (D )exp 4、 判断:在MA TLAB 的内存工作区中,存放一个英文字符 'a' 需要占用1个字节,存放 一个中文字符‘啊’需要占用2个字节。( 错,都是2个字节 ) 5、 判断:MA TLAB 中,i 和j ( 对 ) 6、 判断:MA TLAB 中,pi 代表圆周率,它等于3.14。( 错,后面还有很多位小数 ) 7、 在MA TLAB 中,若想计算的5 1)3.0sin(21+= πy 值,那么应该在MA TLAB 的指令窗中 输入的MA TLAB 指令是__y1=2*sin(0.3*pi)/(1+sqrt(5))_。 8、 在MA TLAB 中,a = 1,b = i ,则a 占_8__个字节,b 占_16_个字节,c 占________字 节。 9、 在MA TLAB 中,inf 的含义是__无穷大__,nan 的含义是__非数(结果不定)___。 数组 1、 在MA TLAB 中,X 是一个一维数值数组,现在要把数组X 中的所有元素按原来次序 的逆序排列输出,应该使用下面的( )指令。 (A )X[end:1] (B )X[end:-1:1] (C )X (end:-1:1) (D )X(end:1) 2、 在MA TLAB 中,A 是一个字二维数组,要获取A 的行数和列数,应该使用的MATLAB 的命令是( )。 (A )class(A) (B )sizeof(A) (C )size(A) (D )isa(A) 3、 在MATLAB 中,用指令x=1:9生成数组x 。现在要把x 数组的第二和第七个元素都 赋值为0,应该在指令窗中输入( ) (A )x([2 7])=(0 0) (B )x([2,7])=[0,0] (C )x[(2,7)]=[0 0] (D )x[(2 7)]=(0 0) 4、 在MA TLAB 中,依次执行以下指令:clear;A=ones(3,4); A(:)=[-6:5];这时, 若在指令窗中输入指令b=A(:,2)',那么,MATLAB 输出的结果应该是( ) (A )b = -3 -2 -1 (B )b = -2 -1 0 1 (C )b = -5 -1 3 (D )b = -5 -2 1 4 5、 在MA TLAB 中,A = 1:9,现在执行如下指令L1 = ~(A>5),则MATLAB 的执行结果应 该是L1 =___ 1 1 1 1 1 0 0 0 0___。

matlab课后习题答案

第4章数值运算 习题 4 及解答 1 根据题给的模拟实际测量数据的一组t和)(t y试用数值差分diff 或数值梯度gradient指令计算)(t y'曲线绘制 y',然后把)(t y和)(t 在同一张图上,观察数值求导的后果。(模拟数据从prob_data401.mat获得) 〖目的〗 ●强调:要非常慎用数值导数计算。 ●练习mat数据文件中数据的获取。 ●实验数据求导的后果 ●把两条曲线绘制在同一图上的一种方法。 〖解答〗 (1)从数据文件获得数据的指令 假如prob_data401.mat文件在当前目录或搜索路径上 clear load prob_data401.mat (2)用diff求导的指令 dt=t(2)-t(1); yc=diff(y)/dt; %注意yc的长度将比y短1 plot(t,y,'b',t(2:end),yc,'r') (3)用gradent求导的指令(图形与上相似) dt=t(2)-t(1); yc=gradient(y)/dt;

plot(t,y,'b',t,yc,'r') grid on 〖说明〗 ● 不到万不得已,不要进行数值求导。 ● 假若一定要计算数值导数,自变量增量dt 要取得比原有数据相对误差高1、2个量级 以上。 ● 求导会使数据中原有的噪声放大。 2 采用数值计算方法,画出dt t t x y x ? =0 sin )(在]10 ,0[区间曲线,并计算)5.4(y 。 〖提示〗 ● 指定区间内的积分函数可用cumtrapz 指令给出。 ● )5.4(y 在计算要求不太高的地方可用find 指令算得。 〖目的〗 ● 指定区间内的积分函数的数值计算法和cumtrapz 指令。 ● find 指令的应用。 〖解答〗 dt=1e-4; t=0:dt:10; t=t+(t==0)*eps; f=sin(t)./t; s=cumtrapz(f)*dt; plot(t,s,'LineWidth',3) ii=find(t==4.5); s45=s(ii) s45 =

最新MATLAB基础教程-薛山第二版-课后习题答案

《MATLAB及应用》实验指导书《MATLAB及应用》实验指导书 班级:T1243-7 姓名:柏元强 学号:20120430724 总评成绩: 汽车工程学院 电测与汽车数字应用中心

目录 实验04051001 MATLAB语言基础 (1) 实验04051002 MATLAB科学计算及绘图 (18) 实验04051003 MATLAB综合实例编程 (31)

实验04051001 MATLAB语言基础 1实验目的 1)熟悉MATLAB的运行环境 2)掌握MATLAB的矩阵和数组的运算 3)掌握MATLAB符号表达式的创建 4)熟悉符号方程的求解 2实验内容 第二章 1.创建double的变量,并进行计算。 (1)a=87,b=190,计算 a+b、a-b、a*b。 clear,clc a=double(87); b=double(190); a+b,a-b,a*b (2)创建 uint8 类型的变量,数值与(1)中相同,进行相同的计算。 clear,clc a=uint8(87); b=uint8(190); a+b,a-b,a*b 2.计算: (1) () sin 60

(2) e3 (3) 3cos 4??π ??? clear,clc a=sind(60) b=exp(3) c=cos(3*pi/4) 3.设2u =,3v =,计算: (1) 4 log uv v (2) () 2 2 e u v v u +- (3) clear,clc u=2;v=3; a=(4*u*v)/log(v) b=((exp(u)+v)^2)/(v^2-u) c=(sqrt(u-3*v))/(u*v) 4.计算如下表达式: (1) ()() 3542i i -+ (2) () sin 28i - clear,clc (3-5*i)*(4+2*i) sin(2-8*i) 5.判断下面语句的运算结果。 (1) 4 < 20 (2) 4 <= 20

matlab课后习题与答案

习题二 1.如何理解“矩阵是MATLAB最基本的数据对象”? 答:因为向量可以看成是仅有一行或一列的矩阵,单个数据(标量)可以看成是仅含一个元素的矩阵,故向量和单个数据都可以作为矩阵的特例来处理。 因此,矩阵是MATLAB最基本、最重要的数据对象。 2.设A和B是两个同维同大小的矩阵,问: (1)A*B和A.*B的值是否相等? 答:不相等。 (2)A./B和B.\A的值是否相等? 答:相等。 (3)A/B和B\A的值是否相等? 答:不相等。 (4)A/B和B\A所代表的数学含义是什么? 答:A/B等效于B的逆右乘A矩阵,即A*inv(B),而B\A等效于B矩阵的逆左乘A矩阵,即inv(B)*A。 3.写出完成下列操作的命令。 (1)将矩阵A第2~5行中第1, 3, 5列元素赋给矩阵B。 答:B=A(2:5,1:2:5); 或B=A(2:5,[1 3 5]) (2)删除矩阵A的第7号元素。 答:A(7)=[] (3)将矩阵A的每个元素值加30。 答:A=A+30; (4)求矩阵A的大小和维数。 答:size(A); ndims(A); (5)将向量t的0元素用机器零来代替。 答:t(find(t==0))=eps; (6)将含有12个元素的向量x转换成34 矩阵。 答:reshape(x,3,4); (7)求一个字符串的ASCII码。 答:abs(‘123’); 或double(‘123’); (8)求一个ASCII码所对应的字符。 答:char(49);

4. 下列命令执行后,L1、L2、L3、L4的值分别是多少? A=1:9;B=10-A;... L1=A==B; L2=A<=5; L3=A>3&A<7; L4=find(A>3&A<7); 答:L1的值为[0, 0, 0, 0, 1, 0, 0, 0, 0] L2的值为[1, 1, 1, 1, 1, 0, 0, 0, 0] L3的值为[0, 0, 0, 1, 1, 1, 0, 0, 0] L4的值为[4, 5, 6] 5. 已知 23100.7780414565532503269.5454 3.14A -????-??=????-?? 完成下列操作: (1) 取出A 的前3行构成矩阵B ,前两列构成矩阵C ,右下角32?子矩阵构 成矩阵D ,B 与C 的乘积构成矩阵E 。 答:B=A(1:3,:); C=A(:,1:2); D=A(2:4,3:4); E=B*C; (2) 分别求E=10&A<25)。 答:E=10&A<25)=[1; 5]。 6. 当A=[34, NaN, Inf, -Inf, -pi, eps, 0]时,分析下列函数的执行结果:all(A), any(A),isnan(A),isinf(A),isfinite(A)。 答:all(A)的值为0 any(A) 的值为1 isnan(A) 的值为[0, 1, 0, 0, 0, 0, 0] isinf(A) 的值为[0, 0, 1, 1, 0, 0, 0] isfinite(A) 的值为[1, 0, 0,0, 1, 1, 1]

汽车理论课后作业答案MATLAB

汽车理论作业MA TLAB过程 汽车驱动力与阻力平衡图 加速度倒数-速度曲线图 0 10 20 30 40 50 60 70 80 90 100 u

汽车功率平衡图 u/(km/h)最高档等速百公里油耗曲线 Ua/(km/h)

燃油积极性-加速时间曲线 源程序: 《第一章》 m=3880; g=9.8; r=0.367; x=0.85; f=0.013; io=5.83; CdA=2.77; lf=0.218; Iw1=1.798; Iw2=3.598; Iw=lw1+lw2; ig=[6.09 3.09 1.71 1.00]; %变速器传动比 L=3.2; a=1.947; hg=0.9; n=600:1:4000;

T=-19.313+295.27* n/1000-165.44*(门/1000)人2+40.874*(门/1000)人3-3.8445*( n/IOOO).%; Ft1=T*ig(1)*io*x/r; %计算各档对应转速下的驱动力 Ft2=T*ig(2)*io*x/r; Ft3=T*ig(3)*io*x/r; Ft4=T*ig(4)*io*x/r; u1=0.377*r*n/(io*ig(1)); u2=0.377*r*n/(io*ig(2)); u3=0.377*r*n/(io*ig(3)); u4=0.377*r*n/(io*ig(4)); u=0:130/3400:130; F仁m*g*f+CdA*u”2/21.15;%计算各档对应转速下的驱动阻力 F2=m*g*f+CdA*u2.A2/21.15; F3=m*g*f+CdA*u3.A2/21.15; F4=m*g*f+CdA*u4.A2/21.15; figure(1); plot(u1,Ft1, '-r' ,u2,Ft2, '-m' ,u3,Ft3, '-k' ,u4,Ft4, '-b' ,u1,F1, '-r' ,u2,F2, '-m' ,u3,F3, ' k' ,u4,F4, '-b' , 'LineWidth' ,2) title( ' 汽车驱动力与阻力平衡图' ); xlabel( 'u_{a}/km.hA{-1}' ) ylabel( 'F/N' ) gtext( 'F_{t1}' ) gtext( 'F_{t2}' ) gtext( 'F_{t3}' ) gtext( 'F_{t4}' ) gtext( 'F_{f}+F_{w}' ) %由汽车驱动力与阻力平衡图知,他们无交点,u4在最大转速时达到最大 umax=u4(3401) Ft1max=max(Ft1); imax=(Ft1max-m*g*f)/(m*g) disp( ' 假设是后轮驱动' ); C=imax/(a/L+hg*imax/L) % 附着率 delta1=1+(Iw1+Iw2)/(m*rA2)+If*ig(1)*rA2*ioA2*x/(m*rA2); delta2=1+(Iw1+Iw2)/(m*rA2)+If*ig(2)*rA2*ioA2*x/(m*rA2); delta3=1+(Iw1+Iw2)/(m*rA2)+If*ig(3)*rA2*ioA2*x/(m*rA2); delta4=1+(Iw1+Iw2)/(m*rA2)+If*ig(4)*rA2*ioA2*x/(m*rA2); a1=(Ft1-F1)/(delta1*m); %加速度 a2=(Ft2-F2)/(delta2*m); a3=(Ft3-F3)/(delta3*m); a4=(Ft4-F4)/(delta4*m); h1=1./a1; %加速度倒数 h2=1./a2; h3=1./a3; h4=1./a4; figure(2);

matlab练习题和答案

matlab练习题和答案 控制系统仿真实验 Matlab部分实验结果 目录 实验一 MATLAB基本操 作 ............................................................................................ 1 实验二 Matlab编程 .................................................................................................... 5 实验三Matlab底层图形控制 (6) 实验四控制系统古典分析.............................................................................................12 实验五控制系统现代分析 . (15) 实验六 PID控制器的设 计 ...........................................................................................19 实验七系统状态空间设计.............................................................................................23 实验九直流双闭环调速系统仿真 . (25) 实验一 MATLAB基本操作 1 用MATLAB可以识别的格式输入下面两个矩阵 1233,,1443678,i,,,,2357,,,,2335542,i,,,, A,1357B,,,2675342, i,,3239,,,,189543,,,,1894,, 再求出它们的乘积矩阵C,并将C矩阵的右下角2×3子矩阵赋给D矩阵。赋值完成后,调 用相应的命令查看MATLAB工作空间的占用情况。 A=[1,2,3,3;2,3,5,7;1,3,5,7;3,2,3,9;1,8,9,4];

matlab课后习题答案第一章

第1章基础准备及入门 习题1及解答 1数字1.5e2,1.5e3中的哪个与1500相同吗? 〖解答〗 1.5e3 2请指出如下5个变量名中,哪些是合法的? abcd-2xyz_33chan a变量ABCDefgh 〖解答〗 2、5是合法的。 3在MATLAB环境中,比1大的最小数是多少? 〖解答〗 1+eps 4设a=-8,运行以下三条指令,问运行结果相同吗?为什么? w1=a^(2/3) w2=(a^2)^(1/3) w3=(a^(1/3))^2 〖解答〗 (1)不同。具体如下 w1=a^(2/3)%仅求出主根 w2=(a^2)^(1/3)%求出(-8)^2的主根 w3=(a^(1/3))^2%求出(-8)主根后再平方 w1= -2.0000+3.4641i w2= 4.0000 w3= -2.0000+3.4641i (2)复数的多方根的,下面是求取全部方根的两种方法: (A)根据复数方根定义 a=-8;n=2;m=3; ma=abs(a);aa=angle(a); for k=1:m%m决定循环次数 sa(k)=(aa+2*pi*(k-1))*n/m;%计算各根的相角 end result=(ma^(2/3)).*exp(j*sa)%计算各根 result= -2.0000+3.4641i 4.0000-0.0000i-2.0000-3.4641i

(B )利用多项式02 3=-a r 求根p=[1,0,0,-a^2];r=roots(p)r =-2.0000+3.4641i -2.0000-3.4641i 4.00005指令clear,clf,clc 各有什么用处? 〖解答〗clear 清除工作空间中所有的变量。clf 清除当前图形。clc 清除命令窗口中所有显示。6以下两种说法对吗?(1)“MATLAB 进行数值的表达精度与其 指令窗中的数据显示精度相同。”(2) MATLAB 指令窗中显示的数值有效位数不超过7位。” 〖解答〗 (1)否;(2)否。 7想要在MATLAB 中产生二维数组???? ??????=987654321S ,下面哪些指令能实现目的? (A )S=[1,2,3;4,5,6;7,8;9] (B )S=[123;456;789] (C )S=[1,2,3;4,5,6;7,8,9] %整个指令在中文状态下输入 〖解答〗 前两种输入方法可以,后一种方法不行。8试为例1.3-5编写一个解题用的M 脚本文件? 〖解答〗 直接点击新文件图标,出现M 文件编辑器窗口;在该M 文件编辑器中,输入例1.3-5中的全部指令;并另存为p109.m ,便得到所需的脚本文件。

MATLAB课后习题集附标准答案

第2章MATLAB概论 1、与其他计算机语言相比较,MA TLAB语言突出的特点是什么? 答:起点高、人机界面适合科技人员、强大而简易的作图功能、智能化程度高、功能丰富,可扩展性强. 2、MA TLAB系统由那些部分组成? 答:开发环境、MATLAB数学函数库、MATLAB语言、图形功能、应用程序接口 3、安装MATLAB时,在选择组件窗口中哪些部分必须勾选,没有勾选的部分以后如何补安装? 答:在安装MATLAB时,安装内容由选择组件窗口中各复选框是否被勾选来决定,可以根据自己的需要选择安装内容,但基本平台(即MATLAB选项)必须安装.第一次安装没有选择的内容在补安装时只需按照安装的过程进行,只是在选择组件时只勾选要补装的组件或工具箱即可.矚慫润厲钐瘗睞枥庑赖。 4、MATLAB操作桌面有几个窗口?如何使某个窗口脱离桌面成为独立窗口?又如何将脱离出去的窗口重新放置到桌面上? 答:在MATLAB操作桌面上有五个窗口,在每个窗口的右下角有两个小按钮,一个是关闭窗口的Close 按钮,一个是可以使窗口称为独立的Undock按钮,点击Undock按钮就可以使该窗口脱离桌面称为独立窗口,在独立窗口的view菜单中选择Dock,菜单项就可以将独立的窗口重新防止的桌面上. 5、如何启动M文件编辑/调试器? 答:在操作桌面上选择“建立新文件”或“打开文件”操作时,M文件编辑/调试器将被启动.在命令窗口中键入edit命令时也可以启动M文件编辑/调试器. 6、存储在工作空间中的数组能编辑吗?如何操作? 答:存储在工作空间的数组可以通过数组编辑器进行编辑:在工作空间浏览器中双击要编辑的数组名打开数组编辑器,再选中要修改的数据单元,输入修改内容即可.彈贸摄尔霁毙攬砖卤庑。 7、命令历史窗口除了可以观察前面键入的命令外,还有什么用途? 答:命令历史窗口除了用于查询以前键入的命令外,还可以直接执行命令历史窗口中选定的内容、将选定的内容拷贝到剪贴板中、将选定内容直接拷贝到M文件中.謀荞抟箧飆鐸怼类蒋薔。 8、如何设置当前目录和搜索路径,在当前目录上的文件和在搜索路径上的文件有什么区别? 答:当前目录可以在当前目录浏览器窗口左上方的输入栏中设置,搜索路径可以通过选择操作桌面的file菜单中的Set Path菜单项来完成.在没有特别说明的情况下,只有当前目录和搜索路径上的函数和文件能够被MATLAB运行和调用,如果在当前目录上有与搜索路径上相同文件名的文件时则优先执行当前目录上的文件,如果没有特别说明,数据文件将存储在当前目录上.厦礴恳蹒骈時盡继價骚。 9、在MA TLAB中有几种获得帮助的途径? 答:(1)帮助浏览器:选择view菜单中的Help菜单项或选择Help菜单中的MATLAB Help菜单项可以打开帮助浏览器.茕桢广鳓鯡选块网羈泪。 (2)help命令:在命令窗口键入“help”命令可以列出帮助主题,键入“help 函数名”可以得到鹅娅尽損鹌惨歷茏鴛賴。 指定函数的在线帮助信息. (3)lookfor命令:在命令窗口键入“lookfor 关键词”可以搜索出一系列与给定关键词相关的命令和函数.籟丛妈羥为贍偾蛏练淨。 (4)模糊查询:输入命令的前几个字母,然后按Tab键,就可以列出所有以这几个字母开始的命令和函数. 注意:lookfor和模糊查询查到的不是详细信息,通常还需要在确定了具体函数名称后用help命令显示详细信息.預頌圣鉉儐歲龈讶骅籴。

MATLAB 实用教程 课后习题答案

第二章 1.计算复数3+4i与5-6i的乘积。 a=3+4i b=5-6i c=a*b 2.构建结构体Students,属性包含Name、age和Email,数据包括{’Zhang’,18,*‘Zhang@16 https://www.360docs.net/doc/009925412.html,’,’Zhang@https://www.360docs.net/doc/009925412.html,’+}、{’Wang’,21,[]}和{’Li’,[],[]},构建后读取所有Name属性值,并且修改’Zhang’的Age属性值为19。 Students(1).Age=18 Students(1).Email='zhang@https://www.360docs.net/doc/009925412.html,','zhang@https://www.360docs.net/doc/009925412.html,' Students(2).Name='Wang' Students(2).Age=21 Students(2).Email=[] Students(3).Name='Li' Students(3).Age=[] Students(3).Email=[] https://www.360docs.net/doc/009925412.html, Student(1).Age(1)=19 Student.Age 3.用满矩阵和稀疏矩阵存储方式分别构造下属矩阵: A=[0 1 0 0 0;1 0 0 0 0;0 0 0 0 0;0 0 0 1 0] A=[0 1 0 0 0;1 0 0 0 0;0 0 0 0 0;0 0 0 1 0] S=sparse(A) S=sparse([2,1,4],[1,2,4],[1,1,1],4,5) 4.采用向量构造符得到向量[1,5,9....,41]. A=1:4:41 5.按水平和竖直方向分别合并下述两个矩阵:A=[1 0 0;1 1 0;0 0 1],B=[2 3 4;5 6 7;8 9 10] A=[1 0 0;1 1 0;0 0 1] B=[2 3 4;5 6 7;8 9 10] C=[A B] D=[A;B] 6.分别删除第五题两个结果的第2行。 A=[1 0 0;1 1 0;0 0 1] B=[2 3 4;5 6 7;8 9 10] C=[A B] D=[A;B] C(2,:)=[] D(2,:)=[] 7.分别将第5题两个结果的第2行最后3列的数值改为[11 12 13]。 A=[1 0 0;1 1 0;0 0 1] B=[2 3 4;5 6 7;8 9 10] C=[A B] D=[A;B]

Matlab习题与答案2

实验二二维/三维数据的可视化 一、实验目的 熟悉掌握简单的图形绘制函数;掌握MATLAB常用的二维、三维图形及其他图形绘制函数的使用方法;熟悉图形句柄的使用。 二、实验环境 硬件环境:计算机一台 软件环境:Matlab 6.0 三、实验内容 作为一个功能强大的工具软件,Matlab具有很强的图形处理功能,提供了大量的二维、三维图形函数。由于系统采用面向对象的技术和丰富的矩阵运算,所以在图形处理方面即常方便又高效。 1、二维绘图 (1)plot函数 函数格式:plot(x,y) 其中x和y为坐标向量 函数功能:以向量x、y为轴,绘制曲线。 例1 在区间0≤X≤2 内,绘制正弦曲线Y=SIN(X),其程序为: x=0:pi/100:2*pi; y=sin(x); plot(x,y) 例2同时绘制正、余弦两条曲线Y1=SIN(X)和Y2=COS(X),其程序为:x=0:pi/100:2*pi; y1=sin(x); y2=cos(x); plot(x,y1,x,y2) plot函数还可以为plot(x,y1,x,y2,x,y3,…)形式,其功能是以公共向量x 为X轴,分别以y1,y2,y3,…为Y轴,在同一幅图内绘制出多条曲线。 例3 用不同线型和颜色重新绘制Y1=SIN(X)和Y2=COS(X),其程序为:x=0:pi/100:2*pi; y1=sin(x); y2=cos(x); plot(x,y1,'go',x,y2,'b-.') 其中参数'go'和'b-.'表示图形的颜色和线型。g表示绿色,o表示图形线型为

圆圈;b表示蓝色,-.表示图形线型为点划线。 在绘制图形的同时,可以对图形加上一些说明,如图形名称、图形某一部分的含义、坐标说明等,将这些操作称为添加图形标记。 title(‘加图形标题'); xlabel('加X轴标记'); ylabel('加Y轴标记'); text(X,Y,'添加文本'); 例4 在坐标范围0≤X≤2π,-2≤Y≤2内重新绘制正弦曲线,其程序为: x=linspace(0,2*pi,60);生成含有60个数据元素的向量X y=sin(x); plot(x,y); axis ([0 2*pi -2 2]);设定坐标轴范围 2、subplot函数 (1)subplot(m,n,p) 该命令将当前图形窗口分成m×n个绘图区,即每行n个,共m行,区号按行优先编号,且选定第p个区为当前活动区。 例5 在一个图形窗口中同时绘制正弦、余弦、正切、余切曲线,程序为:x=linspace(0,2*pi,60); y=sin(x); z=cos(x); t=sin(x)./(cos(x)+eps); eps为系统内部常数 ct=cos(x)./(sin(x)+eps); subplot(2,2,1); 分成2×2区域且指定1号为活动区 plot(x,y); title('sin(x)'); axis ([0 2*pi -1 1]); subplot(2,2,2); plot(x,z); title('cos(x)'); axis ([0 2*pi -1 1]); subplot(2,2,3); plot(x,t); title('tangent(x)'); axis ([0 2*pi -40 40]); subplot(2,2,4); plot(x,ct); title('cotangent(x)');

matlab课后习题及答案详解

第2章 MATLAB 矩阵运算基础 2.1 在MA TLAB 中如何建立矩阵?? ? ???194375,并将其赋予变量a ? >> a=[5 7 3;4 9 1] 2.2 有几种建立矩阵的方法?各有什么优点? 可以用四种方法建立矩阵: ①直接输入法,如a=[2 5 7 3],优点是输入方法方便简捷; ②通过M 文件建立矩阵,该方法适用于建立尺寸较大的矩阵,并且易于修改; ③由函数建立,如y=sin(x),可以由MATLAB 的内部函数建立一些特殊矩阵; ④通过数据文件建立,该方法可以调用由其他软件产生数据。 2.3 在进行算术运算时,数组运算和矩阵运算各有什么要求? 进行数组运算的两个数组必须有相同的尺寸。进行矩阵运算的两个矩阵必须满足矩阵运算规则,如矩阵a 与b 相乘(a*b )时必须满足a 的列数等于b 的行数。 2.4 数组运算和矩阵运算的运算符有什么区别? 在加、减运算时数组运算与矩阵运算的运算符相同,乘、除和乘方运算时,在矩阵运算的运算符前加一个点即为数组运算,如a*b 为矩阵乘,a.*b 为数组乘。 2.5 计算矩阵??????????897473535与??? ? ? ?????638976242之和。 >> a=[5 3 5;3 7 4;7 9 8]; >> b=[2 4 2;6 7 9;8 3 6]; >> a+b ans = 7 7 7 9 14 13 15 12 14 2.6 求?? ? ? ??+-+-+-+-++=i 44i 93i 49i 67i 23i 57i 41i 72i 53i 84x 的共轭转置。 >> x=[4+8i 3+5i 2-7i 1+4i 7-5i;3+2i 7-6i 9+4i 3-9i 4+4i]; >> x’ ans = 4.0000 - 8.0000i 3.0000 - 2.0000i

MATLAB习题及参考答案

习题: 1, 计算?? ????=572396a 与??? ???=864142b 的数组乘积。 2, 对于B AX =,如果?? ?? ? ?????=753467294A ,??????????=282637B ,求解X 。 3, 已知:?? ?? ? ?????=987654321a ,分别计算a 的数组平方和矩阵平方,并观察其结果。 4, 角度[]604530=x ,求x 的正弦、余弦、正切和余切。(应用sin,cos, 5, 将矩阵?? ?? ??=7524a 、??????=3817b 和??? ???=2695c 组合成两个新矩阵: (1)组合成一个43的矩阵,第一列为按列顺序排列的a 矩阵元素,第二列为按列顺序排列的b 矩阵 元素,第三列为按列顺序排列的c 矩阵元素,即 ?? ??? ???? ???237 912685 574 (2)按照a 、b 、c 的列顺序组合成一个行矢量,即 []296531877254 6, 将(x -6)(x -3)(x -8)展开为系数多项式的形式。(应用poly,polyvalm) 7, 求解多项式x 3-7x 2+2x +40的根。(应用roots) 8, 求解在x =8时多项式(x -1)(x -2) (x -3)(x -4)的值。(应用poly,polyvalm) 9, 计算多项式9514124234++--x x x x 的微分和积分。(应用polyder,polyint ,poly2sym) 10, 解方程组??? ? ? ?????=??????????66136221143092x 。(应用x=a\b) 11, 求欠定方程组?? ? ???=???? ??5865394742x 的最小范数解。(应用pinv)

相关文档
最新文档