亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? unitfp.pas

?? 很不錯的非線性回歸分析程序
?? PAS
?? 第 1 頁 / 共 4 頁
字號:
unit UnitFP;

interface

  uses
     Forms, SysUtils, windows, Compile_Hss, DBClient, RunExe_Hss, math,
     DB, Variants;

  type TabcList=record         //注意 比 TParameterList 多了幾個域
    CName     :String;     //參數名稱
    CAddress  :PExtended;  //參數地址
    IfConst   :boolean;    //是否為常數  false:常數 true:變量  (沒有用,這里全部為false)
    PType     :integer;    //參數類型   整數、浮點、常數
    MinV      :extended;   //最小值
    MaxV      :extended;   //最大值
    Default   :extended;   //默認值
    Precision :integer;    //網格精度
  end;

  type TPDList=record
    CName     :String;     //變元名稱
    CAddress  :PExtended;  //變元地址
    Index     :integer;    //變元序號
  end;

  const  DataLength:integer=100;
  const  DataMaxIndex:integer=20;
  var
    Compile   :TCompile;     //編譯執行函數
    abcList   :array of TabcList;       //擬合函數中的 參數
    PDList    :array of TPDList; //擬合函數中的 變元
    dData     :array of array of Extended;  //變元數據矩陣

    NowTime   :Extended;          //當前時間 
    runPause  :boolean;

    ApWay     :integer;        //當前擬合方法
    FBWay     :integer;        //當前 擬合 優劣 檢驗 標準

    ExpressionType :integer;   // -1..DataLength-1 //表達式方式  意義 -1: 0=f() ; N(0-DataLength-1): dN=f() ;
    ExpressionTypeLR :integer; //意義 -1: 0=f(); 0: dN=f() ; 1: f()=dN ;


    dMax        :extended;           //當前最好優化值
    abcMax      :array of extended;  //當前最好參數

    ClientDataSetDataOld: TClientDataSet;   //當前數據源
    ClientDataSetDataOldTemp :TClientDataSet; //臨時保存數據用
    ClientDataSetData: array  of TClientDataSet;

  procedure FieldDefsAssign(var cdX : TClientDataSet);  //生成字段名
  
  function  GetEQ(const str:string;var FirstEQIndex:integer):integer;  // 返回表達式中有幾個等號
  function  IFIn(const F:string;const Af:array of string):boolean;   // F 是否在 字符串數組中 (不區分大小寫)
  function  IFInDCount(const F:string):boolean;    // F 是否在 'd0'...... 中 (不區分大小寫)
  function  strFind(const StrT1,StrT2:string;var index:integer):boolean; //在StrT1中是否有 標識符 StrT2

  function  GetdData(DdataSet:TClientDataSet;var iCount:integer):boolean;    //獲取實驗數據
  function  GetabcData(abcDataSet:TClientDataSet):boolean;//獲取設置好的參數性質

  function  GetFBValue(const cList :array of TabcList;const HowFBWay:integer=-1):Extended;//根據傳來的參數具體值,計算返回 優劣 值

  procedure GetSubValue(const cList :array of TabcList;const pArray :array of extended;var dSubArray:array of extended);overload; //
  function  GetSubValue(const cList :array of TabcList;const pArray :array of extended;const x:extended;const index0,index1:integer):extended;overload;
  
  procedure RunOptimize();
  procedure RunOptimize0();
  procedure RunOptimize1();
  procedure RunOptimize2();
  procedure RunOptimize3();
  procedure RunOptimize4();

  
  function MaxInArray(const Data: array of Extended): Extended;
  function MinInArray(const Data: array of Extended): Extended;

  function Sgn(const x:extended):integer;
  
  function  GetKeyValue(const sKey:string):extended;

  function  GetDataAsStr(const sDataSet: TClientDataSet):string;
  function  GetStrFeildValue(var s:string):variant;
  procedure SetDataAsStr(var sDataSet: TClientDataSet;const sData: string;const CellX:integer=0);

implementation

uses  UnitAuto;

function Sgn(const x:extended):integer;
begin
  if x>0 then
    result:=1
  else if x<0 then
    result:=-1
  else
    result:=0;
end;

function  GetEQ(const str:string;var FirstEQIndex:integer):integer;  // 返回表達式中有幾個等號
var
  i     :integer;
  strT1 :string;
  strT2 :string;

  function  DelNil(const str0:string):string;
  var
    i     :integer;
  begin
    result:='';
    for i:=1 to length(str0) do
    begin
      case str0[i] of
        ' ',#13,#10,#9: result:=result;
        else result:=result+str0[i];
      end;
    end;
  end;

begin
  result:=0;
  FirstEQIndex:=0;
  for i:=length(str) downto 1 do
  begin
    if str[i]='=' then
    begin
      inc(result);
      FirstEQIndex:=i;   //返回第一個'='的位置
    end;
  end;
  if result=0 then
  begin
    ExpressionType:=-1;
    ExpressionTypeLR:=-1;
  end
  else if result=1 then
  begin
    strT1:=uppercase(copy(str,1,FirstEQIndex-1));
    strT1:=DelNil(strT1);
    strT2:=uppercase(copy(str,FirstEQIndex+1,length(str)-FirstEQIndex));
    strT2:=DelNil(strT2);
    if (strT1='0') or (strT2='0') then
    begin
      ExpressionType:=-1;
      ExpressionTypeLR:=-1;
    end
    else if (IFInDCount(strT1)) and (not(strFind(StrT2,StrT1,i)))then
    begin
      ExpressionType:=strtoint(copy(strT1,2,length(strT1)-1));
      ExpressionTypeLR:=0;
    end
    else if (IFInDCount(strT2)) and(not( strFind(StrT1,StrT2,i))) then
    begin
      ExpressionType:=strtoint(copy(strT2,2,length(strT2)-1));
      ExpressionTypeLR:=1;
    end
    else
    begin
      ExpressionType:=-1;
      ExpressionTypeLR:=-1;
    end;
  end;

end;

function MaxInArray(const Data: array of Extended): Extended;
var
  I: Integer;
begin
  Result := Data[Low(Data)];
  for I := Low(Data) + 1 to High(Data) do
    if Result < Data[I] then  Result := Data[I];
end;

function MinInArray(const Data: array of Extended): Extended;
var
  I: Integer;
begin
  Result := Data[Low(Data)];
  for I := Low(Data) + 1 to High(Data) do
    if Result > Data[I] then  Result := Data[I];
end;

procedure FieldDefsAssign(var cdX : TClientDataSet);  //生成字段名
var
  i:integer;
begin
  cdX:=TClientDataSet.Create(nil);
  cdX.AfterScroll:=frmMain.ClientDataSetDataAfterScroll;
  cdX.AfterPost:=frmMain.ClientDataSetDataAfterPost;
  cdX.AfterDelete:=frmMain.ClientDataSetDataAfterDelete;
  cdX.AfterClose:=frmMain.ClientDataSetDataAfterClose;
  for i:=0 to DataLength-1 do
  begin
    cdX.FieldDefs.Add('d'+inttostr(i),ftFloat);
  end;
  cdX.CreateDataSet;
end;

function IFIn(const F:string;const Af:array of string):boolean;
var
  i   :integer;
begin
  result:=false;
  for i:=Low(Af) to High(Af) do
  begin
    if uppercase(F)=uppercase(Af[i]) then
    begin
      result:=true;
      exit;
    end;
  end;
end;

function IFInDCount(const F:string):boolean;
var
  s   :string;
  i   :integer;
  Af  :array of string;
begin
  try
    s:=uppercase(f) ;
    case length(s) of
      0:  result:=false;
      1:  result:=false;
      2,3..10:
        begin
          setlength(af,DataLength);
          for i:=0 to DataLength-1 do
          begin
            af[i]:=inttostr(i);
          end;
          if (s[1]='D') and (ifin(copy(s,2,length(s)-1),af)) then
            result:=true
          else
            result:=false;
        end;
      else
        result:=false;
    end;
  except
    result:=false;
  end;
end;

function GetdData(DdataSet:TClientDataSet;var iCount:integer):boolean;
var
  i,nloop  :integer;
begin
  try
    DdataSet.Last;
    DdataSet.First;
    iCount:=DdataSet.RecordCount;
    if not (iCount<0) then
    begin
      setlength(dData,iCount);
      for i:=0 to iCount-1 do
        setlength(dData[i],DataLength);
      i:=0;
      while not (DdataSet.Eof) do
      begin
        for nloop:=0 to DataLength-1 do
        begin
          dData[i,nloop]:=DdataSet.FieldByName('d'+inttostr(nloop)).asfloat;
        end;
        DdataSet.Next;
        i:=i+1;
      end;
      DdataSet.First;
      result:=true;
    end
    else
      result:=false;
  except
    result:=false;
  end;
end;

function GetabcData(abcDataSet:TClientDataSet):boolean;
var
  i   :integer;
  dTemp :extended;
begin
  try
    for i:=low(abcList) to high(abcList) do
    begin
        abcDataSet.First;
        while not(abcDataSet.Eof) do
        begin
          if (abcDataSet.FieldByName('F_TP_NAME').AsString=abcList[i].CName) then
            break
          else
           abcDataSet.Next;
        end;

        abcList[i].PType:=abcDataSet.FieldByName('F_TP_ZF_ID').AsInteger;
        abcList[i].MinV:=abcDataSet.FieldByName('F_TP_MIN').AsFloat;
        abcList[i].MaxV:=abcDataSet.FieldByName('F_TP_MAX').AsFloat;;
        abcList[i].Default:=abcDataSet.FieldByName('F_TP_DEFAULT').AsFloat;;
        abcList[i].Precision:=abcDataSet.FieldByName('F_TP_Precision').AsInteger;;
     end;
     abcDataSet.First;


     for i:=low(abcList) to high(abcList) do
     begin

       if (abcList[i].PType=2) then
       begin
         abcList[i].MinV:=trunc(abcList[i].MinV);
         abcList[i].MaxV:=trunc(abcList[i].MaxV);
       end
       else if (abcList[i].PType=3) then
       begin
         abcList[i].MinV:=abcList[i].Default;
         abcList[i].MaxV:=abcList[i].Default;
         abcList[i].Precision:=1;
       end;

       if (abcList[i].MaxV=abcList[i].MinV) then
       begin
         abcList[i].Default:=abcList[i].MaxV;
       end;

       
       abcList[i].Precision:=abs(abcList[i].Precision);
       if abcList[i].Precision<1 then abcList[i].Precision:=2;
       
       if abcList[i].MaxV<abcList[i].MinV then
       begin
         dTemp:= abcList[i].MaxV;
         abcList[i].MaxV:=abcList[i].MinV;
         abcList[i].MinV:=dTemp;
       end;
     end;

     result:=true;
  except
    result:=false;
  end;
end;

function GetFBValue(const cList :array of TabcList;const HowFBWay:integer=-1):Extended;//越小越好//根據傳來的參數具體值,計算返回 優劣 值
var
  i,j     :integer;
  sum     :extended;
  dVMax   :extended;
  dVMin   :extended;
  dV      :extended;
  dVvar   :array of Extended;
  L       :integer;
  dVP     :Extended;
  MyFBWay :integer;
  Temp    :double;
begin
  sum:=0;
  for i:=low(cList) to high(cList) do    //參數賦值
  begin
    cList[i].CAddress^:=cList[i].Default;
  end;
  if HowFBWay=-1 then
    myFBWay:=FBWay
  else
    myFBWay:=HowFBWay;
  try
    case myFBWay of
      0:   //方差最小  , 返回 方差
      begin       
        sum:=0;
        for i:=low(dData) to high(dData) do
        begin
          for j:=low(PDList) to high(PDList) do
            PDList[j].CAddress^:=dData[i,PDList[j].Index];

          Compile.GetValue(dV);
          Sum:=Sum+dV*dV;
        end;
      end;
      1:   // 差的絕對值和最小 ,返回 差的絕對值的和
      begin
        sum:=0;
        for i:=low(dData) to high(dData) do
        begin
          for j:=low(PDList) to high(PDList) do
            PDList[j].CAddress^:=dData[i,PDList[j].Index];

          Compile.GetValue(dV);
          Sum:=Sum+abs(dV);
        end;
      end;
      2:   // 差的絕對值最大者最小 ,返回 差的絕對值最大者
      begin
        sum:=0;
        for i:=low(dData) to high(dData) do
        begin
          for j:=low(PDList) to high(PDList) do
            PDList[j].CAddress^:=dData[i,PDList[j].Index];

          Compile.GetValue(dV);
          dV:=abs(dV);
          if dV>sum then sum:=dV;
        end;
      end;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品菠萝久久久久久久| 成人性生交大片免费看视频在线| 五月婷婷色综合| 一区二区三区日韩欧美| 亚洲精品国产精品乱码不99| 亚洲男人的天堂av| 综合久久久久久| 一区二区三区不卡在线观看 | 欧美精品一区二区三区在线| 日韩一二三区视频| 久久久噜噜噜久噜久久综合| 久久久久高清精品| 中文字幕亚洲一区二区va在线| 亚洲欧美国产77777| 亚洲国产一区视频| 日韩国产成人精品| 国产伦精品一区二区三区在线观看| 国产一区福利在线| 成人av动漫网站| 色哟哟国产精品| 在线播放视频一区| 日韩电影一二三区| 日韩不卡一二三区| k8久久久一区二区三区| 国产98色在线|日韩| 色综合久久中文综合久久牛| 欧美视频一区二区| 欧美电影免费观看高清完整版在线 | 色婷婷亚洲精品| 欧美视频中文字幕| 日韩精品一区二区在线观看| 欧美激情综合五月色丁香小说| 亚洲天堂2016| 五月天婷婷综合| 国产激情视频一区二区三区欧美| 一本久久a久久免费精品不卡| 欧美日韩另类一区| 国产人成一区二区三区影院| 国产欧美日韩视频在线观看| 亚洲精品国产一区二区三区四区在线| 天天综合网 天天综合色| 韩国三级电影一区二区| 色拍拍在线精品视频8848| 91精品国产一区二区三区香蕉| 久久久久国产精品麻豆| 亚洲一区二区三区四区五区黄| 免费在线成人网| 成人不卡免费av| 51精品国自产在线| 中文字幕欧美一| 麻豆国产一区二区| 91在线播放网址| 精品国产乱码久久久久久1区2区| 亚洲卡通欧美制服中文| 国产尤物一区二区在线| 精品视频1区2区| 国产精品的网站| 久久99精品网久久| 欧美视频日韩视频在线观看| 国产三级精品视频| 婷婷亚洲久悠悠色悠在线播放| 国产精品99久久久| 欧美一区二区三区四区五区 | 久久精品av麻豆的观看方式| 色综合激情五月| 久久精品夜色噜噜亚洲aⅴ| 视频在线观看一区| 91社区在线播放| 国产亚洲成av人在线观看导航| 首页亚洲欧美制服丝腿| 91免费国产视频网站| 国产亚洲综合性久久久影院| 日韩精品免费专区| 在线观看欧美日本| 欧美一区二区三区人| 欧美中文字幕一区二区三区亚洲| 欧美α欧美αv大片| 亚洲成av人影院在线观看网| 97精品国产露脸对白| 国产欧美日韩另类一区| 麻豆国产精品官网| 777精品伊人久久久久大香线蕉| 亚洲人成人一区二区在线观看| 国产成人综合在线播放| 精品国产乱码91久久久久久网站| 日韩专区一卡二卡| 在线观看免费视频综合| 亚洲免费观看在线观看| 成人av资源站| 国产精品久久国产精麻豆99网站 | 日韩一级片网站| 五月天婷婷综合| 538在线一区二区精品国产| 亚洲午夜电影网| 欧美怡红院视频| 亚洲自拍与偷拍| 欧美日本一区二区在线观看| 亚洲国产综合视频在线观看| 欧美伊人久久久久久午夜久久久久| 亚洲精品菠萝久久久久久久| 一本大道综合伊人精品热热| 一区二区三区电影在线播| 91国偷自产一区二区开放时间 | 最新成人av在线| 91在线看国产| 一区二区三区蜜桃| 欧美三级三级三级| 天天射综合影视| 日韩三级视频在线看| 狂野欧美性猛交blacked| 日韩欧美在线网站| 激情综合色播激情啊| 国产午夜亚洲精品理论片色戒| 国产成人免费视频网站高清观看视频 | 欧美一激情一区二区三区| 青青草97国产精品免费观看无弹窗版| 日韩午夜在线播放| 国产一区二区三区香蕉| 国产欧美综合在线| 91女神在线视频| 爽好多水快深点欧美视频| 精品免费视频.| 成人动漫在线一区| 亚洲线精品一区二区三区八戒| 91精品国产综合久久婷婷香蕉| 麻豆久久久久久| 国产精品沙发午睡系列990531| 色88888久久久久久影院野外| 五月天精品一区二区三区| 久久综合久久综合久久| av不卡在线播放| 亚洲高清免费视频| 精品国产乱码久久久久久久| 北岛玲一区二区三区四区| 亚洲国产人成综合网站| 日韩一区二区三区视频| 国产激情视频一区二区三区欧美| 最近中文字幕一区二区三区| 在线播放视频一区| 国产成人精品一区二区三区网站观看| 亚洲影院理伦片| 免费日韩伦理电影| 国产亚洲一区二区三区| 99精品热视频| 伦理电影国产精品| 国产精品美女视频| 欧美一区二区三区在线视频| 国产成人午夜99999| 亚洲超碰97人人做人人爱| 久久精品亚洲一区二区三区浴池 | 欧美日韩国产一二三| 精品一区二区三区的国产在线播放| 国产精品久99| 日韩视频在线你懂得| 色综合网站在线| 狠狠色丁香婷婷综合久久片| 亚洲乱码中文字幕| 久久久久国产精品厨房| 欧美精品少妇一区二区三区| 99久久综合国产精品| 麻豆国产精品777777在线| 亚洲美女在线一区| 久久色.com| 91精品在线一区二区| 91欧美一区二区| 国产1区2区3区精品美女| 免费成人美女在线观看.| 亚洲精品中文字幕在线观看| 久久久久久久久一| 欧美一区二区视频免费观看| 国产乱妇无码大片在线观看| 亚洲欧洲色图综合| 精品sm捆绑视频| 制服丝袜亚洲色图| 色婷婷精品久久二区二区蜜臀av | 久久―日本道色综合久久| 欧美日韩黄色影视| 色悠悠久久综合| 成人性生交大片免费看视频在线 | 欧美一区二区在线免费播放| 色拍拍在线精品视频8848| 成人免费视频app| 国产麻豆一精品一av一免费 | 91视频.com| 波多野结衣视频一区| 国产成人一区在线| 国产一区二区三区黄视频| 青青青伊人色综合久久| 偷拍日韩校园综合在线| 亚洲国产精品天堂| 亚洲综合男人的天堂| 亚洲精品久久7777| 亚洲欧美一区二区三区孕妇| 国产精品全国免费观看高清 | 奇米四色…亚洲| 丝袜美腿一区二区三区| 婷婷综合在线观看| 天堂va蜜桃一区二区三区漫画版 | 欧美日韩一区中文字幕| 欧美专区亚洲专区|