Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 02.04.2011, 22:37
studentftf studentftf вне форума
Прохожий
 
Регистрация: 02.04.2011
Сообщения: 1
Репутация: 10
Счастье ошибки в программе

не понятно, в чем ошибка
мною написана прога, компилирую, ошибок нет, а вот при нажатии на кнопку, происходит ошибка и отладка идет бесконечно(((
PHP код:
unit Unit1

{
$mode objfpc}{$H+}

interface

uses
  Classes
SysUtilsFileUtilLResourcesFormsControlsGraphicsDialogs,
  
StdCtrlsGridsTAGraphTASeriesMath;
  const 
MaxDimension 9;
type

  
TForm1 }
  
Vector = array[0..MaxDimensionof Double;
  
Matrix = array[0..MaxDimension,0..MaxDimensionof Double;
  
FunctionType = function(xdouble ): double;
  
TForm1 = class(TForm)
    
Button1TButton;
    
Button2TButton;
    
Button3TButton;
    
Chart1TChart;
    
Chart1LineSeries1TLineSeries;
    
Chart1LineSeries2TLineSeries;
    
Chart1LineSeries3TLineSeries;
    
ListBox1TListBox;
    
ListBox2TListBox;
    
procedure Button1Click(SenderTObject);
    
procedure Button2Click(SenderTObject);
    
procedure Button3Click(SenderTObject);
  private
    { private 
declarations }
  public
    { public 
declarations }
  
end
   function 
gxdouble): double;
var
  
Form1TForm1

implementation
{$F+}

function 
gxdouble): double;
begin
 g 
:= exp(2*x) ;
end;
TForm1 }

procedure TForm1.Button1Click(SenderTObject);
var 
bettazFs,s1xy,h,double;
    
a,masMatrix;
    
b,mas2,FB,x1,resh,resh1,Fb1Vector;
    
i,j,k,l,c,d,n:integer;
    
x3x2epsilon,alphadouble;
begin
// подсчет интеграла
betta:=0;
:= 0;
 While (
<=9) do
   
begin
       betta 
:= betta 0.01;
       
z:=0;
       
j:=0;
        While (
<= 9) do
         
begin
                z
:= 0.01;
                
:= (-2*betta*z+sinH(2*betta*(z-1))+sinH(2*betta))/(4*betta);
               
mas[ij] := F;
               
:= 1;
          
end;
       
:= 1;
   
end;
// определение готового решения
:= 0;
:= 0;
  While (
<= 9)and (x<=1) do begin
      x 
:= 0.1;
      
:= exp(2*x);
      
mas2[i]:= y;
      
:= 1;
      
end;
// получение свободного члена
 
for i:=0 to MaxDimension do
     
begin
     s
:=0;
   for 
j:=0 to MaxDimension do := mas[i,j]*mas2[i];
  
Fb[i] := s;
     
end;

//Метод Гаусса для решения системы линейных уравнений
  
if (MaxDimension+1then n := MaxDimension+1;
  for 
:= 0 to n do
  
begin
      
for j:= i+1 to n+do
  
begin
   mas 
[j,i]:=-mas[j,i]/mas[i,i];
   for 
:= i+1 to n do
     
mas[j,k]:=mas [j,k]+mas[j,i]*mas[i,k];
     
Fb[j]:=Fb[j]+mas[j,i]*Fb[i]
    
end;
    
resh[n]:=Fb[n]/mas[n,n];
    
end;
   
//Обратный ход - нахождение корней
    
for i:=n-1 downto 0 do
    
begin
      h
:=Fb[i];
      for 
j:=i+1 to n do h:=h-resh[j]*mas[i,j];
      
resh[i]:=h/mas[i,i]
    
end;

 
// применение регуляризации
 
a[i,j]:=mas[i,j];
  for 
i:=0 to MaxDimension do
     
begin
     alpha
:= Power(10,-3);
     
a[i,i]:= a[i,i]-alpha;
     
s1:=0;
     for 
j:=0 to MaxDimension do s1 := s1 a[i,j]*mas2[i];
  
Fb1[i] := s1;
     
end;
     
//Метод Гаусса для решения системы линейных уравнений для регуляризации
  
if (MaxDimensionthen n := MaxDimension;
  for 
:= 0 to n-do
  
begin
      
for j:= i+1 to n do
  
begin
   a 
[j,i]:=-a[j,i]/a[i,i];
   for 
:= i+1 to n do
     
a[j,k]:=a[j,k]+a[j,i]*a[i,k];
     
Fb1[j]:=Fb1[j]+a[j,i]*Fb1[i]
    
end;
    
resh1[n]:=Fb1[n]/a[n,n];
    
end;
   
//Обратный ход - нахождение корней
    
for i:=n-1 downto 0 do
    
begin
      h
:=Fb1[i];
      for 
j:=i+1 to n do h:=h-resh1[j]*a[i,j];
      
resh1[i]:=h/a[i,i]
    
end;
 
// вывод результата

 
for i:=0 to MaxDimension do
      
ListBox1.Items.AppendFloatToStr(Fb[i]));
 for 
i:=0 to MaxDimension do
      
ListBox2.Items.AppendFloatToStr(resh1[i]));
 
x3 := 0;
  
x2 := 1;
  
epsilon :=  0.001;
  
Chart1LineSeries1.Clear;
  
Chart1LineSeries2.Clear;
  
Chart1LineSeries3.Clear;
  while 
x3 <= x2 do
   
begin
   Chart1LineSeries2
.Add(resh[i],'',clRed);
   
Chart1LineSeries1.AddXY(x3g(x3));
   
Chart1LineSeries3.Add(resh1[i],'',clGreen);
    
x3 := x3 epsilon;
   
end;

end;

procedure TForm1.Button2Click(SenderTObject);
begin
  Close
end
;

procedure TForm1.Button3Click(SenderTObject);
begin

end
;

initialization
  
{$I unit1.lrs}

end

Последний раз редактировалось studentftf, 02.04.2011 в 22:41.
Ответить с цитированием
  #2  
Старый 02.04.2011, 23:20
Аватар для Konrad
Konrad Konrad вне форума
Эксперт
 
Регистрация: 19.03.2009
Сообщения: 1,261
Репутация: 45834
По умолчанию

Вот мне нравятся такие задачи.

Прога на 3 страницы. Комментов минимум. Куча элементов: кнопки, стринггриды,эдиты и т.д. - что в них должно вводится тоже загадка.
Какие данные прога использует - тоже тайна.
Где ошибкам - тоже непонятно.

И вот тут кто-то должен во всем этом рабираться?

Поэтому вывод:
скинь файлом весь проект -
при чем во всех эдитах должны быть уже введены данные.

Тогда можно будет о чем-то говорить.

Тоесть, другими словами:
ты скидываешь проект.
Я жму на кнопку - он виснет.
Я нахожу где он виснет - и выясняю почему.
НО зачем мне парить мозг - что там ты думал вводить в эдиты, где брать файлы, и что вообще должен делать тот твой проджект????
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 08:56.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025