Форум программистов, компьютерный форум, киберфорум
Delphi для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 19.03.2017
Сообщений: 14
1

Floating point division by zero

17.11.2017, 18:02. Показов 848. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Вечер добрый, обращался с этой проблемой, но так и не разобрался. На пункте "Определение потерь давления между ступенями" идет ошибка. Оперировал точкой, запятой, эффекта никого.
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
unit Unit1;
 
interface
 
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Math;
 
type
  TForm1 = class(TForm)
    Button1: TButton;
    Edit1: TEdit;
    Edit2: TEdit;
    Edit3: TEdit;
    Edit4: TEdit;
    Edit5: TEdit;
    Label1: TLabel;
    Label2: TLabel;
    Label3: TLabel;
    Label4: TLabel;
    Label5: TLabel;
    Button2: TButton;
    Label6: TLabel;
    procedure calculate(Sender: TObject);
    procedure Button2Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
 
var
  Form1: TForm1;
 
implementation
 
{$R *.dfm}
 
procedure TForm1.calculate(Sender: TObject);
var
A,B,C,D,E: real;
X1,X2: real;
S1,S2,S3,S4: real;
Q1,Q2,Q3,Q4: real;
W1,W2,W3,W4,W5: real;
E1,E2,E3,E4,E5: real;
R1,R2,R3,R4,T1,T2,T3,T4: real;
Y1,Y2,Y3,Y4: real;
U1,U2,U3,U4: real;
I1,I2,I3,I4: real;
O1,O2,O3,O4: real;
P1,P2,P3,P4: real;
G1,G2,G3,G4,F1,F2,F3,F4: real;
begin
DecimalSeparator:= '.';
// Ввод исходных данных.
A:= StrToFloat(Edit1.Text);
B:= StrToFloat(Edit2.Text);
C:= StrToFloat(Edit3.Text);
D:= StrToFloat(Edit4.Text);
E:= StrToFloat(Edit5.Text);
// Вычисление числа ступеней и степени сжатия.
X1:=B/A;
X2:=(ln(X1))/(ln(4));
S1:=exp(3*ln(X1/1));
S2:=exp(3*ln(X1/0.95));
S3:=exp(3*ln(X1/0.9025));
S4:=exp(3*ln(X1/0.857375));
// Определение давления газа по ступеням.
Q1:=A*S1;
Q2:=Q1*S2;
Q3:=Q2*S3;
Q4:=Q3*S4;
// Определение потерь давления между ступенями.    дальше идет большой ошибкен
W1:=0.3*(2.6/power(0.26,A*1000000));
W2:=0.3*(2.6/power(0.26,Q1*1000000));
W3:=0.3*(2.6/power(0.26,Q2*1000000));
W4:=0.3*(2.6/power(0.26,Q3*1000000));
W5:=0.3*(2.6/power(0.26,Q4*1000000));
E1:=0.7*(2.6/power(0.26,Q1*1000000));
E2:=0.7*(2.6/power(0.26,Q2*1000000));
E3:=0.7*(2.6/power(0.26,Q3*1000000));
E4:=0.7*(2.6/power(0.26,Q4*1000000));
// Определение давлений по ступеням с учетом потерь.
R1:=(1-W1)*A;
R2:=(1-W2)*Q1;
R3:=(1-W3)*Q2;
R4:=(1-W4)*Q3;
T1:=(1-E1)*Q1;
T2:=(1-E2)*Q2;
T3:=(1-E3)*Q3;
T4:=(1-E4)*Q4;
// Определение коэффициента подачи.
// Определение объемного коэффициента.
Y1:=1-0.08*(power((1/1.2),(T1/R1))-1);
Y2:=1-0.08*(power((1/1.3),(T2/R2))-1);
Y3:=1-0.08*(power((1/1.35),(T3/R3))-1);
Y4:=1-0.08*(power((1/1.35),(T4/R4))-1);
// Определение коэффициента дросселирования.
U1:=1-(((1-0.08)/(23*Y1))*((A-R1)/A));
U2:=1-(((1-0.08)/(23*Y2))*((Q1-R2)/Q1));
U3:=1-(((1-0.08)/(23*Y3))*((Q2-R3)/Q2));
U4:=1-(((1-0.08)/(23*Y4))*((Q3-R4)/Q3));
// Определение коэффициента подогрева.
I1:=1-0.01*((T1/R1)-1);
I2:=1-0.01*((T2/R2)-1);
I3:=1-0.01*((T3/R3)-1);
I4:=1-0.01*((T4/R4)-1);
// Определение коэффициентов плотности для компрессоров в хорошем состоянии.
O1:=0.98;
O2:=0.975;
O3:=0.965;
O4:=0.965;
// Определение коэффициента подачи.
P1:=Y1*U1*I1*O1*1;
P2:=Y2*U2*I2*O2*1;
P3:=Y3*U3*I3*O3*1;
P4:=Y4*U4*I4*O4*1;
// Определение температура сжимаемого газа;
G1:=C;
G2:=C+5;
G3:=G2+5;
G4:=G3+5;
F1:=G1*power((0.32/1.32),(T1/R1));
F2:=G2*power((0.34/1.34),(T2/R2));
F3:=G3*power((0.36/1.36),(T3/R3));
F4:=G4*power((0.38/1.38),(T4/R4));
showmessage('F4');
end;
 
procedure TForm1.Button2Click(Sender: TObject);
begin
Close;
end;
 
end.
Миниатюры
Floating point division by zero  
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.11.2017, 18:02
Ответы с готовыми решениями:

floating point division by zero
floating point division by zero при интегрировании методом прямоугольников. procedure...

Floating point division by zero
возникает такая ошибка: Floating point division by zero помогите, пожалуйста, ее исправить ...

Ошибка: floating point division by zero
y:=9.1*x-(cos(x)*cos(x))*(abs(0.2*x))/((x+3)*(x+3)); Выдаёт ошибку floating point division by zero...

Ошибка ''floating point division by zero''
Табуляция функции у и суммы ряда ее разложения. При выполнение выдает ошибку "floating point...

3
138 / 136 / 100
Регистрация: 10.03.2015
Сообщений: 553
17.11.2017, 18:07 2
Значит в этой строке у тебя происходит деление на ноль.
0
Почетный модератор
64300 / 47595 / 32743
Регистрация: 18.05.2008
Сообщений: 115,181
17.11.2017, 18:21 3
Попробуйте сменить тип real на extended.
power(0.26,A*1000000) очень маленькое число и real может воспринимать его как 0.
0
0 / 0 / 0
Регистрация: 19.03.2017
Сообщений: 14
17.03.2018, 18:08  [ТС] 4
решил проблему разбив большую формулу на две малых
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
// Вычисление числа ступеней и степени сжатия.
X1:=B/A;
X2:=(ln(X1))/(ln(4));
W1:=X1/1;
W2:=X1/0.95;
W3:=X1/0.9025;
W4:=X1/0.857375;
S1:=power(W1,1/4);
S2:=power(W2,1/4);
S3:=power(W3,1/4);
S4:=power(W4,1/4);
// Определение давления газа по ступеням.
Q1:=A*S1;
Q2:=Q1*S2;
Q3:=Q2*S3;
Q4:=Q3*S4;
// Определение потерь между ступенями.
E1:=power(A*1000000,0.26);
E2:=power(Q1*1000000,0.26);
E3:=power(Q2*1000000,0.26);
E4:=power(Q3*1000000,0.26);
E5:=power(Q4*1000000,0.26);
R1:=0.3*(2.6/E1);
R2:=0.3*(2.6/E2);
R3:=0.3*(2.6/E3);
R4:=0.3*(2.6/E4);
T1:=0.7*(2.6/E2);
T2:=0.7*(2.6/E3);
T3:=0.7*(2.6/E4);
T4:=0.7*(2.6/E5);
// Определение давлений по ступеням с учетом потерь
0
17.03.2018, 18:08
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.03.2018, 18:08
Помогаю со студенческими работами здесь

Ошибка: floating point division by zero
Выдает ошибку: floating point division by zero unit Unit1; interface uses Windows,...

Ошибка: Floating point division by zero
Доброй ночи! У меня одна проблема. Делфи мне пишет floating point division by zero при...

Ошибка в коде: 'Floating point division by zero'"
Выскакивает ошибка "raised exception class EZeroDivide with massage 'Floating point division by...

Первая игра на delphi 7=) Floating point division by zero
Всем привет, написал игру на delphi с языком знаком 2 недели и вроде бы всё хорошо , игра...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru