1、说明: 本书中所有的常用数值算法子过程按书中的章数分别放在以C开头的子目录中。 所有这些为验证上述子过程而编的验证过程按书中的章数分别放在以D开头的子目录中。 所有为验

源代码在线查看: unit1.pas

软件大小: 1953 K
上传用户: andyandnancy
关键词: 子过程 目录 数值算法
下载地址: 免注册下载 普通下载 VIP

相关代码

				unit Unit1;
				
				interface
				
				uses
				  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
				  StdCtrls;
				Function FUNC2(X:array of real; N:integer):real;
				procedure DFUNC(X:array of real;var DF:array of real);
				Function FUNC(X:real):real;
				type
				  TForm1 = class(TForm)
				    Button1: TButton;
				    Memo1: TMemo;
				    procedure Button1Click(Sender: TObject);
				  private
				    { Private declarations }
				  public
				    { Public declarations }
				  end;
				
				var
				  Form1: TForm1;
				  NCOM:integer; PCOM,XICOM:array[0..50] of REAL;
				implementation
				//PROGRAM D9R9
				//Driver for routine DFPMIN
				uses
				  unit2;
				  {$R *.DFM}
				Function FUNC2(X:array of real; N:integer):real;
				begin
				    FUNC2:=1 - BESSJ0(X[1]-0.5) * BESSJ0(X[2]-0.5) * BESSJ0(X[3]-0.5);
				end;
				
				procedure DFUNC(X:array of real;var DF:array of real);
				begin
				    DF[1]:= BESSJ1(X[1]-0.5) * BESSJ0(X[2]-0.5) * BESSJ0(X[3]-0.5);
				    DF[2]:= BESSJ0(X[1]-0.5) * BESSJ1(X[2]-0.5) * BESSJ0(X[3]-0.5);
				    DF[3]:= BESSJ0(X[1]-0.5) * BESSJ0(X[2]-0.5) * BESSJ1(X[3]-0.5);
				end;
				
				Function FUNC(X:real):real;
				begin
				  FUNC:=F1DIM(X);
				end;
				
				procedure TForm1.Button1Click(Sender: TObject);
				const
				  s1='%8.4f'; s2 = '#0'; s3 = '.#####0e+00';
				  PIO2 = 1.5707963;  NDIM = 3; FTOL = 0.000001;
				var
				  F:TextFile;
				  P:array[0..3] of real;
				  K,ITER:integer;   ANGL,FRET:real;
				begin
				  //输出计算结果到文件
				  AssignFile(F, 'd:\delphi_shu\p9\d9r9.dat');
				  Rewrite(F);
				  Writeln(F);
				  Writeln(F, '   Program finds the minimum of a function');
				  Writeln(F, '   with different trial starting vectors.');
				  Writeln(F, '   True minimum is (0.5, 0.5, 0.5)');
				  Writeln(F);
				  For K:= 0 To 4 do
				  begin
				    ANGL:= PIO2 * K / 4;
				    P[1]:= 2 * Cos(ANGL);
				    P[2]:= 2 * Sin(ANGL);
				    P[3]:= 0;
				    Writeln(F, '   Starting vector: (', Format(s1,[P[1]]),
				                   Format(s1,[P[2]]),Format(s1,[P[3]]),')');
				    DFPMIN(P, NDIM, FTOL, ITER, FRET);
				    Writeln(F, '   Iterations: ', FormatFloat(s2,ITER));
				    Writeln(F, '   Solution vector: (', Format(s1,[P[1]]),
				                   Format(s1,[P[2]]),Format(s1,[P[3]]),')');
				    Writeln(F, '   Func. value at solution  ', FormatFloat(s3,FRET));
				    Writeln(F);
				  end;
				  CloseFile(F);
				  //屏幕显示计算结果
				  memo1.Lines.LoadFromFile('d:\delphi_shu\p9\d9r9.dat');
				end;
				
				end.
							

相关资源