
31.12.2013, 10:51
|
Новичок
|
|
Регистрация: 05.04.2010
Сообщения: 85
Репутация: 10
|
|
почему тогда у меня не работает. в чем ошибка? модуль math я подключил.
Код:
procedure TForm1.ATTRFm(const name: string);
var
Svalexetrhead:string;
valexetrhead:Word;
extblock:array[0..31] of Byte;
tpProc:Cardinal;
nameFileSeism:string;
dPP,NcentrPV,NprS,Nsp:real;
mic_b, mic_e, sig_b,sig_e,tras1_b,tras1_e,tras_b,tras_e:Cardinal;
step,NaT,NserT,NseisT,ND,NprP,Npp:cardinal;
ration:Real;
countS,CountM:Integer;
koef:single;
i,j,z:Cardinal;
Asig,Amic:array of Single;
head:Thead;
headtras:TheadTras;
dats:array of single;
f:TFileStream;
v:TStringList;
begin
f:=TFileStream.Create(name,fmOpenRead);
f.Read(head,SizeOf(head));
step:=SwapDword(head.step);
NaT:=SwapDWorD(head.NallT);
NserT:=SwapDWorD(head.NserT);
NseisT:=SwapDWorD(head.NseisT);
ND:=SwapDWorD(head.Ndiskret);
NprS:=head.lv[0]*256*256+head.lV[1]*256+head.lV[2];
NprS:=NprS+head.lV[3]/256+head.lV[4]/256/256;
Nsp:=head.PV[0]*256*256+head.PV[1]*256+head.PV[2];
Nsp:=Nsp+head.PV[3]/256+head.PV[4]/256/256;
Nsp:=StrToFloat(FloatToStr(NprS)+FloatToStr(Nsp));
setlength(dats,nd);
tras_b:=strtoint(form2.edit5.Text);
tras_e:=strtoint(form2.edit6.Text);
mic_b:=trunc(strtofloat(form2.edit1.Text)/step*1000+1);
mic_e:=trunc(strtofloat(form2.edit2.Text)/step*1000+1);
sig_b:=trunc(strtofloat(form2.edit3.Text)/step*1000+1);
sig_e:=trunc(strtofloat(form2.edit4.Text)/step*1000+1);
for I := 1 to NserT do begin
f.Read(headtras,SizeOf(headtras));
f.Read(dats[0],nd*4);
end;
countS:=0;
countM:=0;
for i:=0 to NseisT-1 do begin //начиная с этой трассы ведем перебор и запись данных в массив мик
f.Read(headtras,SizeOf(headtras));
f.Read(dats[0],nd*4);
NprP:=headtras.LP[0]*256*256+headtras.LP[1]*256+headtras.LP[2];
Npp:=headtras.PP[0]*256*256+headtras.PP[1]*256+headtras.PP[2];
Npp:=StrToInt(IntToStr(NprP)+inttostr(Npp));
if (offset(Nsp,Npp)<=tras_e) and (offset(Nsp,Npp)>=tras_b) then
begin
SetLength(Amic,(mic_e-mic_b+1)+i*(mic_e-mic_b+1));
SetLength(Asig,(sig_e-sig_b+1)+i*(sig_e-sig_b+1));
koef:=swapflt(headtras.koef);
for j:=mic_b-1 to mic_e-1 do begin
Amic[CountM]:=Abs(koef*swapflt(dats[j]));
//mt.Add(FloatToStr(Amic[CountM]));
Inc(CountM);
end;
for z:=sig_b-1 to sig_e-1 do begin
Asig[CountS]:=Abs(koef*swapflt(dats[z]));
Inc(CountS);
end;
end;
end;
f.Free;
if form2.radiobutton1.Checked then
ration:=mean(Asig)/mean(Amic)
else
ration:=norm(Asig)/norm(Amic);
end;
при этом в rad xe5 этот код работает. а в delphi7 говорит о несовместимости типов - incompatible types 'array' and 'dynamic array'
|