matlab 多个向量的余弦角_matlab 一个向量和矩阵中各行向量的夹角余弦值 比如A=(1,2,3,4,5)B={1,2,3,4,5;6,7,8,9,10;11,12,13,14,15;16,1...

该博客提供了一个Matlab函数`ucos`,用于计算一个向量与矩阵中各向量的夹角余弦值,并找出最大和最小夹角余弦值及其对应的行号。通过示例数据展示了如何使用这个函数。
摘要由CSDN通过智能技术生成

优质解答

楼主试试下述代码:

%{

matlab 一个向量和矩阵中各行向量的夹角余弦值

比如A=(1,2,3,4,5)

B={1,2,3,4,5;

6,7,8,9,10;

11,12,13,14,15;

16,17,18,19,20}

分别求向量A与矩阵B中各行向量的夹角余弦值

并输出最大的夹角余弦值,及所对应的具体是哪一行向量

%}

function [CosXY MaxCos MaxCosAngle RCMaxCos MinCos MinCosAngle RCMinCos] = ucos(X,Y)

% ucos功能:

% (1) 计算矩阵 X 的各行向量与矩阵 Y 的各行向量之间的夹角余弦,存储在输出项 CosXY 中;

% (2) 计算最大夹角余弦值及其所对应的角度,分别存储在输出项 MaxCos 和 MaxCosAngle 中;

% (3) 输出最大余弦值所对应的 X 和 Y 所在的行,存储在 RCMaxCos 中;

% (4) 计算最小夹角余弦值及其所对应的角度,分别存储在输出项 MinCos 和 MinCosAngle 中;

% (5) 输出最小余弦值所对应的 X 和 Y 所在的行,存储在 RCMinCos 中;

[rx cx] = size(X);

[ry cy] = size(Y);

if cx~=cy

error('输入的矩阵类型不匹配,输入的矩阵X和Y必须列数相同')

end

CosXY = zeros(rx,ry);

for k = 1:rx

for l = 1:ry

CosXY(k,l) = sum(X(k,:).*Y(l,:))/norm(X(k,:))/norm(Y(l,:));

end

end

MaxCos = max(max(CosXY));

MaxCosAngle = acos(MaxCos);

[r c] = find(CosXY==MaxCos); % 找出最大余弦值所在的行r和列c;

RCMaxCos = [r c];

disp(['最大余弦值出现在X的第 ' num2str(r) ' 行与Y的第 ' num2str(c) ' 行.'])

MinCos = min(min(CosXY));

MinCosAngle = acos(MinCos);

[r c] = find(CosXY==MinCos); % 找出最小余弦值所在的行r和列c;

RCMinCos = [r c];

disp(['最小余弦值出现在X的第 ' num2str(r) ' 行与Y的第 ' num2str(c) ' 行.'])

执行你的数据:

>> A = [1,2,3,4,5];

>> B = [1,2,3,4,5;

6,7,8,9,10;

11,12,13,14,15;

16,17,18,19,20];

>> [CosXY MaxCos MaxCosAngle RCMaxCos MinCos MinCosAngle RCMinCos] = ucos(A,B);

最大余弦值出现在X的第 1 行与Y的第 1 行.

最小余弦值出现在X的第 1 行与Y的第 4 行.

CosXY = [ 1 0.964950504732767 0.945343100616969 0.935153458570522]

MaxCos = 1

MaxCosAngle = 0

RCMaxCos = [1 1]

MinCos = 0.935153458570522

MinCosAngle = 0.362104308112746

RCMinCos = [1 4]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值