Statistiques
| Révision:

root / Ludo / numgrad.inc

Historique | Voir | Annoter | Télécharger (916 octets)

1
{ ******************************************************************
2
  Numerical gradient
3
  ****************************************************************** }
4

    
5
procedure Gradient(X, G : TVector);
6

    
7
const
8
  Eta = 1.0E-4;     { Relative increment }
9

    
10
var
11
  I     : Integer;  { Loop variable }
12
  Temp  : Float;    { Temporary variable }
13
  Delta : Float;    { Increment }
14
  Xm    : Float;    { X - Delta }
15
  Xp    : Float;    { X + Delta }
16
  Fm    : Float;    { F(X - Delta) }
17
  Fp    : Float;    { F(X + Delta) }
18

    
19
begin
20
  for I := 1 to Nvar do
21
    begin
22
      if X[I] <> 0.0 then
23
        Delta := Eta * Abs(X[I])
24
      else
25
        Delta := Eta;
26

    
27
      Xp := X[I] + Delta;
28
       Xm := X[I] - Delta;
29

    
30
      Temp := X[I];
31

    
32
      X[I] := Xm;
33
      Fm := Func(X);
34

    
35
      X[I] := Xp;
36
      Fp := Func(X);
37

    
38
      G[I] := (Fp - Fm) / (2.0 * Delta);
39

    
40
      X[I] := Temp
41
    end;
42
end;