You've already forked lazarus-ccr
git-svn-id: https://svn.code.sf.net/p/lazarus-ccr/svn@7628 8e941d3f-bd1b-0410-a28a-d453659cc2b4
120 lines
2.2 KiB
ObjectPascal
120 lines
2.2 KiB
ObjectPascal
unit Utils;
|
|
|
|
{$mode objfpc}{$H+}
|
|
|
|
interface
|
|
|
|
uses
|
|
Classes, SysUtils, StdCtrls, Dialogs,
|
|
Globals;
|
|
|
|
function AnySelected(AListbox: TListBox): Boolean;
|
|
|
|
procedure ErrorMsg(const AMsg: String);
|
|
procedure ErrorMsg(const AMsg: String; const AParams: array of const);
|
|
|
|
procedure Exchange(var a, b: Double); overload;
|
|
procedure Exchange(var a, b: Integer); overload;
|
|
procedure Exchange(var a, b: String); overload;
|
|
|
|
procedure SortOnX(X, Y: DblDyneVec);
|
|
procedure SortOnX(X: DblDyneVec; Y: DblDyneMat);
|
|
|
|
implementation
|
|
|
|
function AnySelected(AListBox: TListBox): Boolean;
|
|
var
|
|
i: Integer;
|
|
begin
|
|
Result := false;
|
|
for i := 0 to AListbox.Items.Count-1 do
|
|
if AListbox.Selected[i] then
|
|
begin
|
|
Result := true;
|
|
exit;
|
|
end;
|
|
end;
|
|
|
|
procedure ErrorMsg(const AMsg: String);
|
|
begin
|
|
MessageDlg(AMsg, mtError, [mbOK], 0);
|
|
end;
|
|
|
|
procedure ErrorMsg(const AMsg: String; const AParams: array of const);
|
|
begin
|
|
ErrorMsg(Format(AMsg, AParams));
|
|
end;
|
|
|
|
procedure Exchange(var a, b: Double);
|
|
var
|
|
tmp: Double;
|
|
begin
|
|
tmp := a;
|
|
a := b;
|
|
b := tmp;
|
|
end;
|
|
|
|
procedure Exchange(var a, b: Integer);
|
|
var
|
|
tmp: Integer;
|
|
begin
|
|
tmp := a;
|
|
a := b;
|
|
b := tmp;
|
|
end;
|
|
|
|
procedure Exchange(var a, b: String);
|
|
var
|
|
tmp: String;
|
|
begin
|
|
tmp := a;
|
|
a := b;
|
|
b := tmp;
|
|
end;
|
|
|
|
procedure SortOnX(X, Y: DblDyneVec);
|
|
var
|
|
i, j, N: Integer;
|
|
begin
|
|
N := Length(X);
|
|
if N <> Length(Y) then
|
|
raise Exception.Create('[SortOnX] Both arrays must have the same length');
|
|
|
|
for i := 0 to N - 2 do
|
|
begin
|
|
for j := i + 1 to N - 1 do
|
|
begin
|
|
if X[i] > X[j] then //swap
|
|
begin
|
|
Exchange(X[i], X[j]);
|
|
Exchange(Y[i], Y[j]);
|
|
end;
|
|
end;
|
|
end;
|
|
end;
|
|
|
|
// NOTE: The matrix Y is transposed relative to the typical usage in LazStats
|
|
procedure SortOnX(X: DblDyneVec; Y: DblDyneMat);
|
|
var
|
|
i, j, k, N, Ny: Integer;
|
|
begin
|
|
N := Length(X);
|
|
if N <> Length(Y[0]) then
|
|
raise Exception.Create('[SortOnX] Arrays X and Y (2nd index) must have the same length');
|
|
Ny := Length(Y);
|
|
|
|
for i := 0 to N-2 do
|
|
begin
|
|
for j := i+1 to N-1 do
|
|
if X[i] > X[j] then
|
|
begin
|
|
Exchange(X[i], X[j]);
|
|
for k := 0 to Ny-1 do
|
|
Exchange(Y[k, i], Y[k, j]);
|
|
end;
|
|
end;
|
|
end;
|
|
|
|
end.
|
|
|