Текст подпрограммы и версий
ask9c_p.zip
Тексты тестовых примеров
task9c_p.zip

Подпрограмма:  ASK9C (модуль ASK9C_p)

Назначение

Решение системы линейных алгебраических уравнений с клеточно - циркулянтной матрицей, все клетки которой суть клеточно - теплицевы матрицы с клетками общего вида.

Математическое описание

Решается система А*x = b с клеточно - циркулянтной матрицей А (см. [1]) клеточного размера К на К, с клетками размера (М*L) на (М*L); клетки матрицы А являются клеточно - теплицевыми матрицами клеточного размера L на L, с клетками общего вида размера М на М.

В основе алгорифма лежит подобное преобразование матрицы А к клеточно - диагональной матрице клеточного размера К на К, с клетками размера (М*L) на (М*L). Тем самым решение исходной системы порядка М на L на К сводится к решению К систем порядка М на L, матрицы которых - клеточно - теплицевы с клетками общего вида (см. [2]).

1.  В.В.Воеводин. Вычислительные основы линейной алгебры. М., Наука, 1977.
2.  Е.Е.Тыртышников. О решении систем с матрицами типа теплицевых. В сб. "Численный анализ на ФОРТРАНе. Вычисл. Методы и инструментальные системы". Изд-во МГУ, 1978.

Использование

procedure ASK9C(var A :Array of Complex; var X :Array of Complex;
                var R :Array of Complex; M :Integer; L :Integer;
                K :Integer);

Параметры

A - комплексный одномерный массив длины М2 на (2*L - 1) на К, в котором задается матрица системы следующим образом. Массив А делится на К кусков длины М2 на (2*L - 1). В I - ом куске, I = 1, ..., К, задается I - ая клетка первой клеточной строки исходной матрицы. Задание I - ой клетки в своем куске осуществляется следующим образом: соответствующий кусок делится на I - 1 сегментов длины М2. В J - ом сегменте, J = 1, ..., L, записывается J - ая клетка первой клеточной строки I - ой клетки. В L + J - ом сегменте, J = 1, ..., L - 1, записывается J + 1 - ая клетка первого клеточного столбца J - ой клетки. Все внутренние клетки в своих сегментах записываются по столбцам;
X - комплексный одномерный массив длины М на L на К, в котором задается правая часть. На выходе из подпрограммы в Х получается решение;
R - комплексный одномерный рабочий массив длины max (2*М2*L + 4*М2 + М, К);
M - порядок внутренней клетки (тип: целый);
L - клеточный порядок клеток исходной матрицы (тип: целый);
K - клеточный порядок исходной матрицы (тип: целый).

Версии: нет

Вызываемые подпрограммы

ASKAC - решение системы линейных алгебраических уравнений с клеточно - теплицевой матрицей с клетками общего вида.
ASG1C - обращение комплексной матрицы методом Жордана с выбором по столбцу.

Замечания по использованию

  В подпрограмме АSК9С используются служебные подпрограммы АR01С, АR02С, АSКВС.

Пример использования

Unit TASK9C_p;
interface
uses
SysUtils, Math, { Delphi }
Lstruct, Lfunc, UtRes_p, ASK9C_p;

function TASK9C: String;

implementation

function TASK9C: String;
var
M,L,K,_i :Integer;
R :Array [0..33] of Complex;
const
A :Array [0..23] of Complex = ( ( re:1.0; im:1.0 ),( re:2.0; im:2.0 ),( re:2.0; 
im:2.0 ),( re:1.0; im:1.0 ),( re:2.0; im:2.0 ),( 
re:4.0; im:4.0 ),( re:4.0; im:4.0 ),( re:2.0; 
im:2.0 ),( re:2.0; im:2.0 ),( re:4.0; im:4.0 ),( 
re:4.0; im:4.0 ),( re:2.0; im:2.0 ),( re:2.0; 
im:2.0 ),( re:4.0; im:4.0 ),( re:4.0; im:4.0 ),( 
re:2.0; im:2.0 ),( re:4.0; im:4.0 ),( re:8.0; 
im:8.0 ),( re:8.0; im:8.0 ),( re:4.0; im:4.0 ),( 
re:4.0; im:4.0 ),( re:8.0; im:8.0 ),( re:8.0; 
im:8.0 ),( re:4.0; im: 4.0 ) );
X :Array [0..7] of Complex = ( ( re:27.0; im:27.0 ),( re:27.0; im:27.0 ),( 
re:27.0; im:27.0 ),( re:27.0; im:27.0 ),( 
re:27.0; im:27.0 ),( re:27.0; im:27.0 ),( 
re:27.0; im:27.0 ),( re:27.0; im: 27.0 ) );
begin
Result := '';  { результат функции }
M := 2;
L := 2;
K := 2;
ASK9C(A,X,R,M,L,K);
Result := Result + Format('%s',[' X=' + #$0D#$0A]);
Result := Result + #$0D#$0A;
for _i:=0 to 7 do
 begin
  Result := Result + Format('%20.16f %20.16f ',[X[_i].re,X[_i].im]);
  if ( ((_i+1) mod 2)=0 )
   then Result := Result + #$0D#$0A;
 end;
Result := Result + #$0D#$0A;
UtRes('TASK9C',Result);  { вывод результатов в файл TASK9C.res }
exit;
end;

end.

Результат:

      X  =  ( (1., 0.),  (1., 0.),  (1., 0.),  (1., 0.),  (1., 0.),  (1., 0.), 
                (1., 0.),  (1., 0.) )