В этом примере показано, как реализовать аппаратное эффективное решение матричного уравнения A'AX=B с комплексным знаком с помощью Комплексной Пакетной Матрицы, Решают Используя блок Q-less QR Decomposition.
Задайте количество строк в матрице А, количество столбцов в матрице А и строк в B, и количество столбцов в матрице B.
m = 100; % Number of rows in A n = 10; % Number of columns in A and rows in B p = 1; % Number of columns in B
В данном примере используйте функцию помощника complexRandomQlessQRMatrices
сгенерировать случайные матрицы A и B для проблемы A'AX=B. Матрицы сгенерированы таким образом, что действительные и мнимые части элементов массива и B между-1 и +1, и A является полным рангом.
rng('default')
[A,B] = fixed.example.complexRandomQlessQRMatrices(m,n,p);
Используйте функцию помощника complexQlessQRMatrixSolveFixedpointTypes
выбрать типы данных с фиксированной точкой для входных матриц A и B и вывести X таким образом, что существует низкая вероятность переполнения во время расчета.
Действительные и мнимые части элементов массива и B между-1 и 1, таким образом, максимальное возможное абсолютное значение любого элемента является sqrt (2).
max_abs_A = sqrt(2); % Upper bound on max(abs(A(:)) max_abs_B = sqrt(2); % Upper bound on max(abs(B(:)) precisionBits = 24; % Number of bits of precision T = fixed.complexQlessQRMatrixSolveFixedpointTypes(m,n,max_abs_A,max_abs_B,precisionBits); A = cast(A,'like',T.A); B = cast(B,'like',T.B); OutputType = fixed.extractNumericType(T.X);
model = 'ComplexBurstQlessQRMatrixSolveModel';
open_system(model);
Подсистема Обработчика Данных в этой модели берет комплексные матрицы A и B как входные параметры. ready
порт инициировал Обработчик Данных. После отправки истинного validIn
сигнал, перед ready
может быть некоторая задержка установлен в ложь. Когда Обработчик Данных обнаруживает передний край
ready
сигнал, блок устанавливает validIn
к истине и отправляет следующую строку A и B. Этот протокол позволяет данным быть отправленными каждый раз, когда передний край ready
сигнал обнаруживается, гарантируя, что все данные обрабатываются.
Используйте функцию помощника setModelWorkspace
добавить переменные, заданные выше к рабочему пространству модели. Эти переменные соответствуют параметрам блоков для Комплексной Пакетной Матрицы, Решают Используя блок Q-less QR Decomposition.
numSamples = 1; % Number of samples fixed.example.setModelWorkspace(model,'A',A,'B',B,'m',m,'n',n,'p',p,... 'numSamples',numSamples,'OutputType',OutputType);
out = sim(model);
Комплексная Пакетная Матрица Решает Используя блок Q-less QR Decomposition выходные данные одна строка за один раз. Когда строка результата выводится, блок устанавливает validOut
к истине. Строки X выводятся в порядке, они вычисляются, последняя строка сначала, таким образом, необходимо восстановить данные, чтобы интерпретировать результаты. Чтобы восстановить матрицу X от выходных данных, используйте функцию помощника matrixSolveModelOutputToArray
.
X = fixed.example.matrixSolveModelOutputToArray(out.X,n,p);
Чтобы оценить точность Комплексной Пакетной Матрицы Решают Используя блок Q-less QR Decomposition, вычисляют относительную погрешность.
relative_error = norm(double(A'*A*X - B))/norm(double(B)) %#ok<NOPTS>
relative_error = 2.5932e-04