l := sqrt(sqr(v[0]) + sqr(v[1]) + sqr(v[2]));
if l < 1E-7 then begin
v1[0] := 0;
v1[1] := 0;
v1[2] := 0;
v2[0] := 0;
v2[1] := 0;
v2[2] := 0;
end else begin
if (v[0] >= v[1]) and (v[0] >= v[2]) then begin //ищем первый перпендикуляр
v1[0] := -v[1];
v1[1] := v[0];
v1[2] := 0;
end else begin
v1[0] := 0;
v1[1] := -v[2];
v1[2] := v[1];
end;
v2[0] := v[1]*v1[2]-v[2]*v1[1]; // векторный произведением ищем второй
v2[1] := v[2]*v1[0]-v[0]*v1[2];
v2[2] := v[0]*v1[1]-v[1]*v1[0];
l1 := sqrt(sqr(v1[0]) + sqr(v1[1]) + sqr(v1[2])); // нормируем
l2 := sqrt(sqr(v2[0]) + sqr(v2[1]) + sqr(v2[2]));
v1[0] := v1[0]/l1*l;
v1[1] := v1[1]/l1*l;
v1[2] := v1[2]/l1*l;
v2[0] := v2[0]/l2*l;
v2[1] := v2[1]/l2*l;
v2[2] := v2[2]/l2*l;
end;
Дан вектор в R3. Найти 2 перпендикулярных ему, тоже длины. |