Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Автоматика, матрицы и векторы.doc
Скачиваний:
0
Добавлен:
01.05.2025
Размер:
2.12 Mб
Скачать

14.2.3. Класс комплексных векторов

//T_CVECTOR.PAS

unit T_CVector;

interface

uses T_Complex,// Модуль комплексных чисел

dialogs; // Стандартный модуль диалоговых окон

type

CVector=array of TComplex; /* Тип : динамический вектор комплексных чисел */

TCVector = class // Класс комплексного вектора

len:integer; // Длина вектора

Vector:CVector; // Сам вектор

procedure SetLen(l:integer);virtual; //Установка длины вектора

constructor CVCreate(l:integer); /* Создание вектора длины l*/

private

protected

public

// Внутренние ф-ции

function CVMultOnDig(d:TComplex): TCVector;virtual; { <-- ф-ция - Умножение вектора на комплексное число (действительное число - это комлексное число с нулевой мнимой частью : complex(dig,0) ) }

function CVNormir:TCVector;virtual; { Нормирование вектора}

function CVModul:TComplex;virtual; {Модуль вектора}

Procedure Revers;virtual; // Реверсирование

published

end;

{Внешние ф-ции (директивой far избавимся от написания методов в указаном порядке) }

function CVOptimize(c:CVector):CVector;far; { Отбрасывание ведущих нулей и приведение к 0 с точностью 1е-8}

function CVSumma(v1,v2:CVector):CVector;far;

// Сумма векторов

function CVRazn(v1,v2:CVector):CVector;far;

// Разность векторов

function CVMult(v1,v2:CVector):CVector;far;

// Умножение векторов

function CVScalarMult(v1,v2:CVector): TComplex;far; // Скалярное произведение

function CVEquiv(v1,v2:cvector):boolean;far;

// Сравнение векторов

procedure MessageBox(s:string);far; {Просто сообщение}

implementation

procedure TCVector.Revers;//Реверсирование вектора

var res:Cvector;

i,j:integer;

begin

setlength(res,len);

for j:=0 to len-1 do res[j]:=vector[j];

for i:=0 to len-1 do vector[i]:=res[abs(len-i-1)];

end;

function CVOptimize(c:CVector):CVector; {Отбрасывание ведущих нулей и приведение к 0 с точностью 1е-8}

var i:integer;res:CVector;

begin

res:=c;

for i:=0 to high(c) do begin

if abs(res[i].re)<=1e-8 then res[i].re:=0;

if abs(res[i].im)<=1e-8 then res[i].im:=0;

end;

result:=res;

end;

procedure MessageBox(s:string);

begin

MessageDlg(s,mtInformation,[mbOk],1); // Без слов

end;

function CVEquiv(v1,v2:cvector):boolean; {Сравнение векторов}

var i:integer;

begin

result:=true;

if high(v1)<>high(v2) then begin result:=false;exit end;

for i:=0 to high(v1) do

if not CEquiv(v1[i],v2[i]) then result:=false;

end;

procedure TCVector.SetLen(l:integer);

begin

setlength(vector,l); {Устанавливаем вектору vector длину l}

len:=l;

end;

function TCVector.CVMultOnDig(d:TComplex):TCVector;

var t:TCVector;i:integer;

begin

t:=TCVector.CVCreate(len);

for i:=0 to len-1 do t.Vector[i]:=CMult(Vector[i],d);{ Вызов процедуры произведения комплексных чисел (из модуля T_Copmlex) }

result:=t;

end;

constructor TCVector.CVCreate(l:integer);

// Создаём вектор длины l

var i:integer;

begin

inherited Create; // Конструктор предка

setlen(l); // Наша ф-ция установки длинны

for i:=0 to len-1 do vector[i]:=Complex(0,0);

// Сразу заполняем нулями

end;

function TCVector.CVModul:TComplex;//Модуль вектора

var tt:TComplex;i:integer;

begin

tt:=Complex(0,0);

{Возведение каждого элемента вектора в квадрат}

for i:=0 to len-1 do tt:=CSumma(tt,CPow(vector[i],2));

{Сумма элементов вектора}

result:=CPow(tt,0.5); // SQRT(tt)

end;

function CVSumma(v1,v2:CVector):CVector;

//Сумма векторов

var i:integer;d:CVector;

begin

if high(v1)>high(v2) then begin

setlength(d,high(v1)+1); { Устанавливаем размер по наибольшей длине }

for i:=0 to high(v2) do

d[i]:=CSumma(v1[i],v2[i]); { Заносим в вектор-результат значения суммы }

for i:=high(v2)+1 to high(v1) do d[i]:=v1[i];

// Переписываем что осталось

end else

begin

setlength(d,high(v2)+1); { Устанавливаем размер по наибольшей длине}

for i:=0 to high(v1) do d[i]:=CSumma(v1[i],v2[i]); // Заносим в вектор-результат значения суммы

for i:=high(v1)+1 to high(v2) do d[i]:=v2[i];

// Переписываем что осталось

end;

result:=d;

end;

function CVRazn(v1,v2:CVector):CVector;

// Разность векторов

var i:integer;d:CVector;

begin

// Аналогичные действия

if high(v1)>high(v2) then begin

setlength(d,high(v1)+1);

for i:=0 to high(v2) do d[i]:=CRazn(v1[i],v2[i]);

for i:=high(v2)+1 to high(v1) do d[i]:=v1[i];

end else

begin

setlength(d,high(v2)+1);

for i:=0 to high(v1) do d[i]:=CRazn(v1[i],v2[i]);

for i:=high(v1)+1 to high(v2) do d[i]:=CMultOnDig(v2[i],-1);

end;

result:=d;

end;

function CVMult(v1,v2:CVector):CVector;

// Произведение векторов

var i:integer;d:CVector;

begin

setlength(d,high(v1)+1);

for i:=0 to high(v1) do d[i]:=CMult(v1[i],v2[i]);

result:=d;

end;

function CVScalarMult(v1,v2:CVector):TComplex;

var d:cvector;tt,n1,n2:tcomplex;i:integer;

tc:TCVector;

begin

if high(v1)=high(v2) then begin

tc:=TCVector.CVCreate(high(v1)+1);

tt:=Complex(0,0);

d:=CVMult(v1,v2);

for i:=0 to high(d) do tt:=CSumma(tt,d[i]);

tc.vector:=v1;n1:=tc.CVModul;

tc.vector:=v2;n2:=tc.CVModul;

if (((n1.re=0) and (n1.im=0)) or((n2.re=0) and (n2.im=0))) then begin

MessageBox('Один из векторов нулевой;(Модуль T_CVector)');

result:=complex(0,0);

exit;

end;

result:=CDiv(tt,CMult(n1,n2));

tc.Free;

end else result:=complex(0,0);

exit;

end;

function TCVector.CVNormir:TCvector;

// Нормирование вектора

var t:TCVector;tt:TComplex;i:integer;

begin

t:=TCVector.CVCreate(len);

t.vector:=vector;

tt:=t.CVModul;

for i:=0 to len-1 do

t.Vector[i]:=CDiv(t.Vector[i],tt);{ Деление каждого элемента вектора на модуль вектора}

result:=t;

end;

//End file.

end.