数学实验矩阵的运算

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

数学实验报告

学院:

班级:

学号:

姓名:

完成日期:

实验四矩阵的运算

(一)投入产出分析

一.实验目的

1.理解投入产出分析中的基本概念和模型;

2.从数学和投入产出理论的角度,理解矩阵乘法、逆矩

阵等的含义。

二.问题描述

设国民经济由农业、制造业和服务业三个部门构成,已知某年它们之间的投入产出关系、部需求、初始投入等如表1-1所示

表1-1国民经济三产部门之间的投入产出表

根据表回答下列问题:

(1)如果农业、制造业、服务业外部需求为50,150,100,问三个部门总产出分别为多少?

(2)如果三个部门的外部需求分别增加一个单位,问

他们的总产出分别为多少?

三.实验过程

1.问题(1)的求解

(1)求直接消耗矩阵A

根据直接消耗的计算公式

a ij=x ij/x j

和各部门中间需求;

x n a n

运行如下代码可得直接消耗系数表。

X=[15 20 30;30 10 45;20 60 0];

X_colsum=[100 200 150];

X_rep=repmat(X_colsum,3,1)

A=X./ X_rep

运行结果为:

A =

0.1500 0.1000 0.2000

0.3000 0.0500 0.3000

0.2000 0.3000 0 (2)求解

根据公式

X=(I-A)-1y

在运行如下代码

y=[50;150;100];

n=size(y,1);

W=eye(n)-A;

X=W\y

运行结果为

X =

139.2801

267.6056

208.1377

即三个部门的总产出分别为139.2801,267.6056, 208.1377亿元。

2.问题2求解

设外部需求由y增加至y+Δy,则产出x的增量为

Δx=(I-A)-1(y+Δy)- (I-A)-1y=(I-A)-1Δy

利用问题(1)求得的I-A矩阵,再运行如下的MATLAB 代码可得问题的结果:

dx=inv(W)

运行结果:

dx =

1.3459 0.2504 0.3443

0.5634 1.2676 0.4930

0.4382 0.4304 1.2167

根据上述结果可知,当农业的外部需求增加1个单位时,农业、制造业、服务业的总产出分别增加 1.3459,0.5634,0.4382个单位;当制造业的外部需求增加1个单位时,农业、制造业、服务业的总产出分别增加0.2504,1.2676,0.4304个单位;当服务业的外部需求增加1个单位时,农业、制造业、服务业的总产出分别增加0.3443,0.4930,1.2167个单位。四.实验总结

投入产出的理论依据,主要是矩阵运算和逆矩阵,投入和产出分析在编制和修订宏观计划、开展紧急预测和项目效果预测、研究价格水平及其变动影响,研究产业结构及其关联程度,投资对消费的带动分析等方面对会有很重要的应用。

(二)Hill密码的加密、解密与破译

一、实验目的

1. 复习线性代数, 矩阵, 线性空间与线性变换等概念和

运算.

2. 熟悉Hill密码体制的加密, 解密和破译过程.

3. Hill密码体制的加密, 解密和破译过程的MATLAB编

程实践.

二、问题描述

对明文为“Mr Hill made this code”,利运用不同的密匙矩

阵加密矩阵,实现Hill加密与解密过程。

三.实验过程

(1)模型建立于问题分析

简单起见,为了使明文参与矩阵运算,建立如下表格2-1:

表2-1 26个英文字母、空格、句号与数字之间的对应关系设明文为M=(m1, m2,…,m i)T,密匙矩阵为可逆的l x l 的方阵,则经过线性变换得到密文C=E K(M)=(c1c2…cI)T,其中

C1=(k11m1+ k12m2+…+ k1l m l)mod28,

C2=(k21m1+ k22m2+…+ k2l m l)mod28,

………….

C l=(k l1m1+ k l2m2+…+ k ll m l)mod28,

或写成矩阵形式

C=(KM)mod28,

其中

C=(C1,C2,…,C l)T ,M=(m1,m2,…,m l)T,K=(k ij)lxl 解密得明文

M=(K-1C)mod28

注意,明文、密文都是非负实数,故密匙矩阵K及其逆矩阵K-1的元素都应该是非负实数,不能是负整数、分数、

或小数。当密匙矩阵K的行列式的值等于+1或-1,则逆矩阵

K-1的元素是整数。若K-1的元素有负整数,再对矩阵K-1的所有元素加28的若干倍,再取模28,可保证矩阵K-1的所有元素为正整数。密文解密后可得非负整数明文M,与原明文相同。

(2)加密

对明文为“Mr Hill made this code。”,按表2-1的规则映射为数集{13,18,0,8,9,12,12,0,13,1,4,5,0,20,8,9,19,0,3,15,4,5,27,0},假设将消息从左到右,每4个字符分为一组,并将对应的四个整数排列成4维的列向量,加密后仍为4维的列向量,其分量仍为整数,要发出的消息可写为一个矩阵:

. 13 9 13 0 19 4

M= 18 12 1 20 0 5

0 12 4 8 3 27

8 0 5 9 15 0

为求出合适的密匙矩阵K1,在一个4x4阶矩阵中,任设二元函数的值为x,y,其余元素给出具体的非负整数值,并令其行列式的值的绝对值为1,可得一个二元一次或二元二次不定方程,可求其正整数解,如取:

4 x 8 y

K1= 12 1 6 9 , I K1I=1,

3 6

4 6

2 11

3 8

利用如下的MATLAB代码可求得密匙矩阵K1的行列式:

相关文档
最新文档