我想解决一个线性系统AX =B,其中A是n×n常数矩阵,矩阵B的类型是nx1。然而,矩阵B的每个元素是类型的nx1向量(这是因为每个元素bij是时变的)。
%%% Example
t = 0:0.002:0.5; %% Time
A = [1 0 -1 0 0 0; ...
0 -1 0 0 1 0; ...
r12y, r32y-r12x r32x 0 0; ...
0 0 -1 0 1 0; ...
0 -1 0 0 1 0; ...
0 r23y-7-r43y r23x r43x];
%% Where rij is constant
% Construction 6x1 matrix C
C = [m2.*A2x ; ...
m2.*FG2-a2y; ...
ICM2.*Alpha2; ...
m3.*A3X ; ...
m3.*a3y-FG3; ...
Icm3.*Alph8a3];
%% Where A2x, a2y, A3X, a3y, alpha2, Alpha3 are elements of the matrix C that are time-varying.我试着解决了segunte形式:
C = rand (6,1,251);
A = rand (6,6);%
X = zeros (6, size (C, 3));
for i = 1: size (C, 3)
X (:, i) = A \ C (:,:, i);
end但我不知道这是不是最好的方法。
发布于 2013-01-01 01:54:35
您可以只执行以下操作。
C = reshape(rand(6,1,251), 6, 251); % Or just create rand(6, 251);
A = rand(6,6);
X = A \ C;这将得到相同的结果,并且比for循环更快。
https://stackoverflow.com/questions/14104366
复制相似问题