root / UnitPredictionDetail.pas @ 12
Historique | Voir | Annoter | Télécharger (49,165 ko)
1 | 1 | avalancogn | unit UnitPredictionDetail;
|
---|---|---|---|
2 | |||
3 | {$WARN SYMBOL_PLATFORM OFF}
|
||
4 | |||
5 | interface
|
||
6 | |||
7 | uses
|
||
8 | Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, |
||
9 | Dialogs, StdCtrls, ExtCtrls, DB, DBCtrls, Mask, JvEdit, JvExStdCtrls, |
||
10 | JvValidateEdit, JvCsvData, RpSystem, RpRender, RpRenderPDF, RpDefine, RpRave, |
||
11 | RvClass, RvCsStd, RpBase, gnugettext, ActnList, ImgList, JvButton, JvCtrls, |
||
12 | XMLIntf, XMLDoc, RpDevice; |
||
13 | |||
14 | type
|
||
15 | TFormPredictionDetail = class(TForm)
|
||
16 | RvProjectReport: TRvProject; |
||
17 | RvSystemReport: TRvSystem; |
||
18 | SaveDialogExport: TSaveDialog; |
||
19 | PanelMain: TPanel; |
||
20 | PanelButtons: TPanel; |
||
21 | LabelName: TLabel; |
||
22 | LabelMS: TLabel; |
||
23 | EditName: TEdit; |
||
24 | EditMS: TMemo; |
||
25 | GroupBoxAzote: TGroupBox; |
||
26 | LabelCrois3: TLabel; |
||
27 | LabelTruie3: TLabel; |
||
28 | LabeldN: TLabel; |
||
29 | EditdNc: TMemo; |
||
30 | EditdNt: TMemo; |
||
31 | GroupBoxEnergy: TGroupBox; |
||
32 | LabelEB: TLabel; |
||
33 | LabelED: TLabel; |
||
34 | LabelEM: TLabel; |
||
35 | LabelEN: TLabel; |
||
36 | LabelCrois1: TLabel; |
||
37 | LabelTruie1: TLabel; |
||
38 | LabelRatio: TLabel; |
||
39 | EditEBc: TMemo; |
||
40 | EditEBt: TMemo; |
||
41 | EditEDc: TMemo; |
||
42 | EditEDt: TMemo; |
||
43 | EditEMc: TMemo; |
||
44 | EditEMt: TMemo; |
||
45 | EditENc: TMemo; |
||
46 | EditENt: TMemo; |
||
47 | EditEMt_EMc: TMemo; |
||
48 | EditENt_ENc: TMemo; |
||
49 | EditEBt_EBc: TMemo; |
||
50 | EditEDt_EDc: TMemo; |
||
51 | GroupBoxEnergyUtilization: TGroupBox; |
||
52 | LabeldE: TLabel; |
||
53 | LabelEM_ED: TLabel; |
||
54 | LabelEN_EM: TLabel; |
||
55 | LabelCrois2: TLabel; |
||
56 | LabelTruie2: TLabel; |
||
57 | LabelBonus: TLabel; |
||
58 | EditdEc: TMemo; |
||
59 | EditdEt: TMemo; |
||
60 | EditEMc_EDc: TMemo; |
||
61 | EditEMt_EDt: TMemo; |
||
62 | EditENc_EMc: TMemo; |
||
63 | EditENt_EMt: TMemo; |
||
64 | EditBonusC: TMemo; |
||
65 | EditBonusT: TMemo; |
||
66 | GroupBoxProximal: TGroupBox; |
||
67 | LabelMAT: TLabel; |
||
68 | LabelCB: TLabel; |
||
69 | LabelMG: TLabel; |
||
70 | LabelMM: TLabel; |
||
71 | LabelNDF: TLabel; |
||
72 | LabelADF: TLabel; |
||
73 | LabelAmidon: TLabel; |
||
74 | LabelSucres: TLabel; |
||
75 | LabelMOdv: TLabel; |
||
76 | EditMAT: TMemo; |
||
77 | EditCB: TMemo; |
||
78 | EditMG: TMemo; |
||
79 | EditMM: TMemo; |
||
80 | EditNDF: TMemo; |
||
81 | EditADF: TMemo; |
||
82 | EditAmidon: TMemo; |
||
83 | EditSucres: TMemo; |
||
84 | EditMOdv: TMemo; |
||
85 | ImageListIcons: TImageList; |
||
86 | ActionListButtons: TActionList; |
||
87 | ActionPrint: TAction; |
||
88 | ActionXML: TAction; |
||
89 | ActionHelp: TAction; |
||
90 | ActionClose: TAction; |
||
91 | JvImgBtnClose: TJvImgBtn; |
||
92 | JvImgBtnHelp: TJvImgBtn; |
||
93 | JvImgBtnXML: TJvImgBtn; |
||
94 | JvImgBtnPrint: TJvImgBtn; |
||
95 | procedure FormCreate(Sender: TObject);
|
||
96 | procedure FormShow(Sender: TObject);
|
||
97 | procedure ActionPrintExecute(Sender: TObject);
|
||
98 | procedure ActionXMLExecute(Sender: TObject);
|
||
99 | procedure ActionHelpExecute(Sender: TObject);
|
||
100 | procedure ActionCloseExecute(Sender: TObject);
|
||
101 | private
|
||
102 | { D?clarations priv?es }
|
||
103 | MS, MM, MAT, MG, CB, NDF, ADF, Amidon, Sucres, dMOv: Double; |
||
104 | EB, dEc, BonusC, EDc, EMc, ENc, dEt, BonusT, EDt, EMt, ENt, dNc, dNt: Double; |
||
105 | procedure BuildReport;
|
||
106 | public
|
||
107 | { D?clarations publiques }
|
||
108 | end;
|
||
109 | |||
110 | var
|
||
111 | FormPredictionDetail: TFormPredictionDetail; |
||
112 | |||
113 | implementation
|
||
114 | |||
115 | uses
|
||
116 | UnitDeclaration, UnitOptions, UnitPredictionCreate; |
||
117 | |||
118 | {$R *.dfm}
|
||
119 | |||
120 | procedure TFormPredictionDetail.ActionCloseExecute(Sender: TObject);
|
||
121 | begin
|
||
122 | ModalResult := mrClose; |
||
123 | end;
|
||
124 | |||
125 | procedure TFormPredictionDetail.ActionXMLExecute(Sender: TObject);
|
||
126 | var
|
||
127 | USFormatSettings: TFormatSettings; |
||
128 | XMLDoc: IXMLDocument; |
||
129 | Workbook, Worksheet, Table, Row: IXMLNode; |
||
130 | |||
131 | procedure CellData(Row: IXMLNode; Value, Format: string); |
||
132 | var
|
||
133 | Cell, Data: IXMLNode; |
||
134 | begin
|
||
135 | Cell := Row.AddChild('Cell');
|
||
136 | Data := Cell.AddChild('Data');
|
||
137 | Data.Attributes['ss:Type'] := Format;
|
||
138 | Data.Text := Value; |
||
139 | end;
|
||
140 | |||
141 | begin
|
||
142 | if SaveDialogExport.Execute
|
||
143 | then
|
||
144 | begin
|
||
145 | GetLocaleFormatSettings(1033, USFormatSettings);
|
||
146 | XMLDoc := TXMLDocument.Create(nil);
|
||
147 | try
|
||
148 | XMLDoc.XML.Clear; |
||
149 | XMLDoc.XML.Add('<?xml version="1.0" encoding="UTF-8" ?>');
|
||
150 | XMLDoc.XML.Add('<?mso-application progid="Excel.Sheet"?>');
|
||
151 | XMLDoc.XML.Add('<Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet">');
|
||
152 | XMLDoc.XML.Add('</Workbook>');
|
||
153 | XMLDoc.Active := True; |
||
154 | Workbook := XMLDoc.DocumentElement; |
||
155 | Workbook.DeclareNamespace('o', 'urn:schemas-microsoft-com:office:office'); |
||
156 | Workbook.DeclareNamespace('x', 'urn:schemas-microsoft-com:office:excel'); |
||
157 | Workbook.DeclareNamespace('ss', 'urn:schemas-microsoft-com:office:spreadsheet'); |
||
158 | Workbook.DeclareNamespace('html', 'http://www.w3.org/TR/REC-html40'); |
||
159 | Worksheet := Workbook.AddChild('Worksheet');
|
||
160 | Worksheet.SetAttributeNS('ss:Name', Workbook.FindNamespaceURI('ss'), Caption); |
||
161 | Table := Worksheet.AddChild('Table');
|
||
162 | // Titre
|
||
163 | Row := Table.AddChild('Row');
|
||
164 | CellData(Row, _('Label'), 'String'); |
||
165 | CellData(Row, _('Value'), 'String'); |
||
166 | CellData(Row, _('Unit'), 'String'); |
||
167 | // Donn?es
|
||
168 | Row := Table.AddChild('Row');
|
||
169 | CellData(Row, LabelName.Caption, 'String');
|
||
170 | CellData(Row, EditName.Text, 'String');
|
||
171 | // Analyse proximale
|
||
172 | Row := Table.AddChild('Row');
|
||
173 | CellData(Row, LabelMS.Caption, 'String');
|
||
174 | CellData(Row, FloatToStrF(MS, ffFixed, 15, FormOptions.ProximalDecimals, USFormatSettings), 'Number'); |
||
175 | if FormOptions.Expression = 0 |
||
176 | then // sur frais |
||
177 | CellData(Row, FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], 'String')
|
||
178 | else // sur mati?re s?che |
||
179 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], _('DM')]), 'String'); |
||
180 | Row := Table.AddChild('Row');
|
||
181 | CellData(Row, LabelMM.Caption, 'String');
|
||
182 | if EditMM.Text <> '' |
||
183 | then
|
||
184 | with DataModuleDeclaration do |
||
185 | CellData(Row, FloatToStrF(OutputProximal(MM, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, USFormatSettings), 'Number') |
||
186 | else
|
||
187 | CellData(Row, '', 'String'); |
||
188 | if FormOptions.Expression = 0 |
||
189 | then // sur frais |
||
190 | CellData(Row, FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], 'String')
|
||
191 | else // sur mati?re s?che |
||
192 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], _('DM')]), 'String'); |
||
193 | Row := Table.AddChild('Row');
|
||
194 | CellData(Row, LabelMAT.Caption, 'String');
|
||
195 | if EditMAT.Text <> '' |
||
196 | then
|
||
197 | with DataModuleDeclaration do |
||
198 | CellData(Row, FloatToStrF(OutputProximal(MAT, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, USFormatSettings), 'Number') |
||
199 | else
|
||
200 | CellData(Row, '', 'String'); |
||
201 | if FormOptions.Expression = 0 |
||
202 | then // sur frais |
||
203 | CellData(Row, FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], 'String')
|
||
204 | else // sur mati?re s?che |
||
205 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], _('DM')]), 'String'); |
||
206 | Row := Table.AddChild('Row');
|
||
207 | CellData(Row, LabelMG.Caption, 'String');
|
||
208 | if EditMG.Text <> '' |
||
209 | then
|
||
210 | with DataModuleDeclaration do |
||
211 | CellData(Row, FloatToStrF(OutputProximal(MG, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, USFormatSettings), 'Number') |
||
212 | else
|
||
213 | CellData(Row, '', 'String'); |
||
214 | if FormOptions.Expression = 0 |
||
215 | then // sur frais |
||
216 | CellData(Row, FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], 'String')
|
||
217 | else // sur mati?re s?che |
||
218 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], _('DM')]), 'String'); |
||
219 | Row := Table.AddChild('Row');
|
||
220 | CellData(Row, LabelCB.Caption, 'String');
|
||
221 | if EditCB.Text <> '' |
||
222 | then
|
||
223 | with DataModuleDeclaration do |
||
224 | CellData(Row, FloatToStrF(OutputProximal(CB, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, USFormatSettings), 'Number') |
||
225 | else
|
||
226 | CellData(Row, '', 'String'); |
||
227 | if FormOptions.Expression = 0 |
||
228 | then // sur frais |
||
229 | CellData(Row, FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], 'String')
|
||
230 | else // sur mati?re s?che |
||
231 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], _('DM')]), 'String'); |
||
232 | Row := Table.AddChild('Row');
|
||
233 | CellData(Row, LabelNDF.Caption, 'String');
|
||
234 | if EditNDF.Text <> '' |
||
235 | then
|
||
236 | with DataModuleDeclaration do |
||
237 | CellData(Row, FloatToStrF(OutputProximal(NDF, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, USFormatSettings), 'Number') |
||
238 | else
|
||
239 | CellData(Row, '', 'String'); |
||
240 | if FormOptions.Expression = 0 |
||
241 | then // sur frais |
||
242 | CellData(Row, FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], 'String')
|
||
243 | else // sur mati?re s?che |
||
244 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], _('DM')]), 'String'); |
||
245 | Row := Table.AddChild('Row');
|
||
246 | CellData(Row, LabelADF.Caption, 'String');
|
||
247 | if EditADF.Text <> '' |
||
248 | then
|
||
249 | with DataModuleDeclaration do |
||
250 | CellData(Row, FloatToStrF(OutputProximal(ADF, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, USFormatSettings), 'Number') |
||
251 | else
|
||
252 | CellData(Row, '', 'String'); |
||
253 | if FormOptions.Expression = 0 |
||
254 | then // sur frais |
||
255 | CellData(Row, FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], 'String')
|
||
256 | else // sur mati?re s?che |
||
257 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], _('DM')]), 'String'); |
||
258 | Row := Table.AddChild('Row');
|
||
259 | CellData(Row, LabelAmidon.Caption, 'String');
|
||
260 | if EditAmidon.Text <> '' |
||
261 | then
|
||
262 | with DataModuleDeclaration do |
||
263 | CellData(Row, FloatToStrF(OutputProximal(Amidon, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, USFormatSettings), 'Number') |
||
264 | else
|
||
265 | CellData(Row, '', 'String'); |
||
266 | if FormOptions.Expression = 0 |
||
267 | then // sur frais |
||
268 | CellData(Row, FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], 'String')
|
||
269 | else // sur mati?re s?che |
||
270 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], _('DM')]), 'String'); |
||
271 | Row := Table.AddChild('Row');
|
||
272 | CellData(Row, LabelSucres.Caption, 'String');
|
||
273 | if EditSucres.Text <> '' |
||
274 | then
|
||
275 | with DataModuleDeclaration do |
||
276 | CellData(Row, FloatToStrF(OutputProximal(Sucres, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, USFormatSettings), 'Number') |
||
277 | else
|
||
278 | CellData(Row, '', 'String'); |
||
279 | if FormOptions.Expression = 0 |
||
280 | then // sur frais |
||
281 | CellData(Row, FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], 'String')
|
||
282 | else // sur mati?re s?che |
||
283 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], _('DM')]), 'String'); |
||
284 | Row := Table.AddChild('Row');
|
||
285 | CellData(Row, LabelMOdv.Hint, 'String');
|
||
286 | if EditMOdv.Text <> '' |
||
287 | then
|
||
288 | with DataModuleDeclaration do |
||
289 | CellData(Row, FloatToStrF(OutputProximal(dMOv * (1 - MM), RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, USFormatSettings), 'Number') |
||
290 | else
|
||
291 | CellData(Row, '', 'String'); |
||
292 | if FormOptions.Expression = 0 |
||
293 | then // sur frais |
||
294 | CellData(Row, FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], 'String')
|
||
295 | else // sur mati?re s?che |
||
296 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxProximal.Items[FormOptions.Proximal], _('DM')]), 'String'); |
||
297 | // Energie
|
||
298 | Row := Table.AddChild('Row');
|
||
299 | CellData(Row, LabelEB.Caption, 'String');
|
||
300 | if EditEBc.Text <> '' |
||
301 | then
|
||
302 | with DataModuleDeclaration do |
||
303 | CellData(Row, FloatToStrF(OutputEnergy(EB, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, USFormatSettings), 'Number') |
||
304 | else
|
||
305 | CellData(Row, '', 'String'); |
||
306 | if FormOptions.Expression = 0 |
||
307 | then // sur frais |
||
308 | CellData(Row, FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], 'String')
|
||
309 | else // sur mati?re s?che |
||
310 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], _('DM')]), 'String'); |
||
311 | Row := Table.AddChild('Row');
|
||
312 | CellData(Row, Format('%s, %s', [LabelED.Caption, _('growing pig')]), 'String'); |
||
313 | if EditEDc.Text <> '' |
||
314 | then
|
||
315 | with DataModuleDeclaration do |
||
316 | CellData(Row, FloatToStrF(OutputEnergy(EDc, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, USFormatSettings), 'Number') |
||
317 | else
|
||
318 | CellData(Row, '', 'String'); |
||
319 | if FormOptions.Expression = 0 |
||
320 | then // sur frais |
||
321 | CellData(Row, FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], 'String')
|
||
322 | else // sur mati?re s?che |
||
323 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], _('DM')]), 'String'); |
||
324 | Row := Table.AddChild('Row');
|
||
325 | CellData(Row, Format('%s, %s', [LabelED.Caption, _('adult pig')]), 'String'); |
||
326 | if EditEDt.Text <> '' |
||
327 | then
|
||
328 | with DataModuleDeclaration do |
||
329 | CellData(Row, FloatToStrF(OutputEnergy(EDt, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, USFormatSettings), 'Number') |
||
330 | else
|
||
331 | CellData(Row, '', 'String'); |
||
332 | if FormOptions.Expression = 0 |
||
333 | then // sur frais |
||
334 | CellData(Row, FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], 'String')
|
||
335 | else // sur mati?re s?che |
||
336 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], _('DM')]), 'String'); |
||
337 | Row := Table.AddChild('Row');
|
||
338 | CellData(Row, Format('%s, %s', [LabelED.Caption, _('ratio')]), 'String'); |
||
339 | if EditEDt_EDc.Text <> '' |
||
340 | then
|
||
341 | with DataModuleDeclaration do |
||
342 | CellData(Row, FloatToStrF(EDt / EDc * 100, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
343 | else
|
||
344 | CellData(Row, '', 'String'); |
||
345 | CellData(Row, '%', 'String'); |
||
346 | Row := Table.AddChild('Row');
|
||
347 | CellData(Row, Format('%s, %s', [LabelEM.Caption, _('growing pig')]), 'String'); |
||
348 | if EditEMc.Text <> '' |
||
349 | then
|
||
350 | with DataModuleDeclaration do |
||
351 | CellData(Row, FloatToStrF(OutputEnergy(EMc, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, USFormatSettings), 'Number') |
||
352 | else
|
||
353 | CellData(Row, '', 'String'); |
||
354 | if FormOptions.Expression = 0 |
||
355 | then // sur frais |
||
356 | CellData(Row, FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], 'String')
|
||
357 | else // sur mati?re s?che |
||
358 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], _('DM')]), 'String'); |
||
359 | Row := Table.AddChild('Row');
|
||
360 | CellData(Row, Format('%s, %s', [LabelEM.Caption, _('adult pig')]), 'String'); |
||
361 | if EditEMt.Text <> '' |
||
362 | then
|
||
363 | with DataModuleDeclaration do |
||
364 | CellData(Row, FloatToStrF(OutputEnergy(EMt, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, USFormatSettings), 'Number') |
||
365 | else
|
||
366 | CellData(Row, '', 'String'); |
||
367 | if FormOptions.Expression = 0 |
||
368 | then // sur frais |
||
369 | CellData(Row, FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], 'String')
|
||
370 | else // sur mati?re s?che |
||
371 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], _('DM')]), 'String'); |
||
372 | Row := Table.AddChild('Row');
|
||
373 | CellData(Row, Format('%s, %s', [LabelEM.Caption, _('ratio')]), 'String'); |
||
374 | if EditEMt_EMc.Text <> '' |
||
375 | then
|
||
376 | with DataModuleDeclaration do |
||
377 | CellData(Row, FloatToStrF(EMt / EMc * 100, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
378 | else
|
||
379 | CellData(Row, '', 'String'); |
||
380 | CellData(Row, '%', 'String'); |
||
381 | Row := Table.AddChild('Row');
|
||
382 | CellData(Row, Format('%s, %s', [LabelEN.Caption, _('growing pig')]), 'String'); |
||
383 | if EditENc.Text <> '' |
||
384 | then
|
||
385 | with DataModuleDeclaration do |
||
386 | CellData(Row, FloatToStrF(OutputEnergy(ENc, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, USFormatSettings), 'Number') |
||
387 | else
|
||
388 | CellData(Row, '', 'String'); |
||
389 | if FormOptions.Expression = 0 |
||
390 | then // sur frais |
||
391 | CellData(Row, FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], 'String')
|
||
392 | else // sur mati?re s?che |
||
393 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], _('DM')]), 'String'); |
||
394 | Row := Table.AddChild('Row');
|
||
395 | CellData(Row, Format('%s, %s', [LabelEN.Caption, _('adult pig')]), 'String'); |
||
396 | if EditENt.Text <> '' |
||
397 | then
|
||
398 | with DataModuleDeclaration do |
||
399 | CellData(Row, FloatToStrF(OutputEnergy(ENt, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, USFormatSettings), 'Number') |
||
400 | else
|
||
401 | CellData(Row, '', 'String'); |
||
402 | if FormOptions.Expression = 0 |
||
403 | then // sur frais |
||
404 | CellData(Row, FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], 'String')
|
||
405 | else // sur mati?re s?che |
||
406 | CellData(Row, Format('%s %s', [FormOptions.ComboBoxEnergy.Items[FormOptions.Energy], _('DM')]), 'String'); |
||
407 | Row := Table.AddChild('Row');
|
||
408 | CellData(Row, Format('%s, %s', [LabelEN.Caption, _('ratio')]), 'String'); |
||
409 | if EditENt_ENc.Text <> '' |
||
410 | then
|
||
411 | with DataModuleDeclaration do |
||
412 | CellData(Row, FloatToStrF(ENt / ENc * 100, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
413 | else
|
||
414 | CellData(Row, '', 'String'); |
||
415 | CellData(Row, '%', 'String'); |
||
416 | Row := Table.AddChild('Row');
|
||
417 | CellData(Row, Format('%s, %s', [LabelBonus.Caption, _('growing pig')]), 'String'); |
||
418 | CellData(Row, FloatToStrF(BonusC, ffFixed, 15, 1, USFormatSettings), 'Number'); |
||
419 | CellData(Row, '%', 'String'); |
||
420 | Row := Table.AddChild('Row');
|
||
421 | CellData(Row, Format('%s, %s', [LabelBonus.Caption, _('adult pig')]), 'String'); |
||
422 | CellData(Row, FloatToStrF(BonusT, ffFixed, 15, 1, USFormatSettings), 'Number'); |
||
423 | CellData(Row, '%', 'String'); |
||
424 | Row := Table.AddChild('Row');
|
||
425 | CellData(Row, Format('%s, %s', [LabeldE.Caption, _('growing pig')]), 'String'); |
||
426 | if EditdEc.Text <> '' |
||
427 | then
|
||
428 | with DataModuleDeclaration do |
||
429 | CellData(Row, FloatToStrF(dEc + BonusC, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
430 | else
|
||
431 | CellData(Row, '', 'String'); |
||
432 | CellData(Row, '%', 'String'); |
||
433 | Row := Table.AddChild('Row');
|
||
434 | CellData(Row, Format('%s, %s', [LabeldE.Caption, _('adult pig')]), 'String'); |
||
435 | if EditdEt.Text <> '' |
||
436 | then
|
||
437 | with DataModuleDeclaration do |
||
438 | CellData(Row, FloatToStrF(dEt + BonusT, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
439 | else
|
||
440 | CellData(Row, '', 'String'); |
||
441 | CellData(Row, '%', 'String'); |
||
442 | Row := Table.AddChild('Row');
|
||
443 | CellData(Row, Format('%s, %s', [LabelEM_ED.Caption, _('growing pig')]), 'String'); |
||
444 | if EditEMc_EDc.Text <> '' |
||
445 | then
|
||
446 | with DataModuleDeclaration do |
||
447 | CellData(Row, FloatToStrF(EMc / EDc * 100, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
448 | else
|
||
449 | CellData(Row, '', 'String'); |
||
450 | CellData(Row, '%', 'String'); |
||
451 | Row := Table.AddChild('Row');
|
||
452 | CellData(Row, Format('%s, %s', [LabelEM_ED.Caption, _('adult pig')]), 'String'); |
||
453 | if EditEMt_EDt.Text <> '' |
||
454 | then
|
||
455 | with DataModuleDeclaration do |
||
456 | CellData(Row, FloatToStrF(EMt / EDt * 100, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
457 | else
|
||
458 | CellData(Row, '', 'String'); |
||
459 | CellData(Row, '%', 'String'); |
||
460 | Row := Table.AddChild('Row');
|
||
461 | CellData(Row, Format('%s, %s', [LabelEN_EM.Caption, _('growing pig')]), 'String'); |
||
462 | if EditENc_EMc.Text <> '' |
||
463 | then
|
||
464 | with DataModuleDeclaration do |
||
465 | CellData(Row, FloatToStrF(ENc / EMc * 100, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
466 | else
|
||
467 | CellData(Row, '', 'String'); |
||
468 | CellData(Row, '%', 'String'); |
||
469 | Row := Table.AddChild('Row');
|
||
470 | CellData(Row, Format('%s, %s', [LabelEN_EM.Caption, _('adult pig')]), 'String'); |
||
471 | if EditENt_EMt.Text <> '' |
||
472 | then
|
||
473 | with DataModuleDeclaration do |
||
474 | CellData(Row, FloatToStrF(ENt / EMt * 100, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
475 | else
|
||
476 | CellData(Row, '', 'String'); |
||
477 | CellData(Row, '%', 'String'); |
||
478 | // Digestibilit? f?cale de l'azote
|
||
479 | Row := Table.AddChild('Row');
|
||
480 | CellData(Row, Format('%s, %s', [LabeldN.Caption, _('growing pig')]), 'String'); |
||
481 | if EditdNc.Text <> '' |
||
482 | then
|
||
483 | with DataModuleDeclaration do |
||
484 | CellData(Row, FloatToStrF(dNc, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
485 | else
|
||
486 | CellData(Row, '', 'String'); |
||
487 | CellData(Row, '%', 'String'); |
||
488 | Row := Table.AddChild('Row');
|
||
489 | CellData(Row, Format('%s, %s', [LabeldN.Caption, _('adult pig')]), 'String'); |
||
490 | if EditdNt.Text <> '' |
||
491 | then
|
||
492 | with DataModuleDeclaration do |
||
493 | CellData(Row, FloatToStrF(dNt, ffFixed, 15, 1, USFormatSettings), 'Number') |
||
494 | else
|
||
495 | CellData(Row, '', 'String'); |
||
496 | CellData(Row, '%', 'String'); |
||
497 | XMLDoc.SaveToFile(SaveDialogExport.FileName); |
||
498 | XmlDoc.Active := False; |
||
499 | finally
|
||
500 | XMLDoc := nil;
|
||
501 | end;
|
||
502 | end;
|
||
503 | end;
|
||
504 | |||
505 | procedure TFormPredictionDetail.ActionHelpExecute(Sender: TObject);
|
||
506 | begin
|
||
507 | Application.HelpContext(HelpContext); |
||
508 | end;
|
||
509 | |||
510 | procedure TFormPredictionDetail.ActionPrintExecute(Sender: TObject);
|
||
511 | begin
|
||
512 | if RpDev.PrinterSetupDialog
|
||
513 | then
|
||
514 | begin
|
||
515 | RvSystemReport.DoNativeOutput := false; |
||
516 | RvSystemReport.DefaultDest := rdPrinter; |
||
517 | RvSystemReport.RenderObject := nil;
|
||
518 | RvSystemReport.OutputFileName := '';
|
||
519 | RvProjectReport.Open; |
||
520 | BuildReport; |
||
521 | RvProjectReport.Execute; |
||
522 | RvProjectReport.Close; |
||
523 | end;
|
||
524 | end;
|
||
525 | |||
526 | procedure TFormPredictionDetail.BuildReport;
|
||
527 | var
|
||
528 | i: Integer; |
||
529 | Page: TRavePage; |
||
530 | begin
|
||
531 | Page := RvProjectReport.ProjMan.FindRaveComponent('ReportPrediction.PagePrediction', nil) as TRavePage; |
||
532 | for i := 0 to Page.ComponentCount - 1 do |
||
533 | if Page.Components[i].ClassNameIs('TRaveText') |
||
534 | then // Traduire |
||
535 | begin
|
||
536 | if Screen.Fonts.IndexOf('Arial Unicode MS') <> -1 |
||
537 | then
|
||
538 | (Page.Components[i] as TRaveText).Font.Name := 'Arial Unicode MS'; |
||
539 | TranslateComponent(Page.Components[i]); |
||
540 | if (Page.Components[i] as TRaveText).Name = 'DataTextName' |
||
541 | then
|
||
542 | (Page.Components[i] as TRaveText).Text := EditName.Text;
|
||
543 | if (Page.Components[i] as TRaveText).Name = 'TextMS' |
||
544 | then
|
||
545 | with FormOptions do |
||
546 | (Page.Components[i] as TRaveText).Text := Format('%s (%s)', [(Page.Components[i] as TRaveText).Text, ComboBoxProximal.Items[Proximal]]); |
||
547 | if (Page.Components[i] as TRaveText).Name = 'TextUnitProximal' |
||
548 | then
|
||
549 | with FormOptions do |
||
550 | if Expression = 0 |
||
551 | then // sur frais |
||
552 | (Page.Components[i] as TRaveText).Text := Format('(%s)', [ComboBoxProximal.Items[Proximal]]) |
||
553 | else // sur mati?re s?che |
||
554 | (Page.Components[i] as TRaveText).Text := Format('(%s %s)', [ComboBoxProximal.Items[Proximal], _('DM')]); |
||
555 | if (Page.Components[i] as TRaveText).Name = 'TextUnitEnergyC' |
||
556 | then
|
||
557 | with FormOptions do |
||
558 | if Expression = 0 |
||
559 | then // sur frais |
||
560 | (Page.Components[i] as TRaveText).Text := Format('(%s)', [ComboBoxEnergy.Items[Energy]]) |
||
561 | else // sur mati?re s?che |
||
562 | (Page.Components[i] as TRaveText).Text := Format('(%s %s)', [ComboBoxEnergy.Items[Energy], _('DM')]); |
||
563 | if (Page.Components[i] as TRaveText).Name = 'TextUnitEnergyT' |
||
564 | then
|
||
565 | with FormOptions do |
||
566 | if Expression = 0 |
||
567 | then // sur frais |
||
568 | (Page.Components[i] as TRaveText).Text := Format('(%s)', [ComboBoxEnergy.Items[Energy]]) |
||
569 | else // sur mati?re s?che |
||
570 | (Page.Components[i] as TRaveText).Text := Format('(%s %s)', [ComboBoxEnergy.Items[Energy], _('DM')]); |
||
571 | if (Page.Components[i] as TRaveText).Name = 'TextUnitEnergyRatio' |
||
572 | then
|
||
573 | (Page.Components[i] as TRaveText).Text := '(%)'; |
||
574 | if (Page.Components[i] as TRaveText).Name = 'TextBonus' |
||
575 | then
|
||
576 | (Page.Components[i] as TRaveText).Text := Format('%s (%%)', [(Page.Components[i] as TRaveText).Text]); |
||
577 | if (Page.Components[i] as TRaveText).Name = 'TextdE' |
||
578 | then
|
||
579 | (Page.Components[i] as TRaveText).Text := Format('%s (%%)', [(Page.Components[i] as TRaveText).Text]); |
||
580 | if (Page.Components[i] as TRaveText).Name = 'TextME_DE' |
||
581 | then
|
||
582 | (Page.Components[i] as TRaveText).Text := Format('%s (%%)', [(Page.Components[i] as TRaveText).Text]); |
||
583 | if (Page.Components[i] as TRaveText).Name = 'TextNE_ME' |
||
584 | then
|
||
585 | (Page.Components[i] as TRaveText).Text := Format('%s (%%)', [(Page.Components[i] as TRaveText).Text]); |
||
586 | if (Page.Components[i] as TRaveText).Name = 'TextdN' |
||
587 | then
|
||
588 | (Page.Components[i] as TRaveText).Text := Format('%s (%%)', [(Page.Components[i] as TRaveText).Text]); |
||
589 | // Affichage des valeurs
|
||
590 | if (Page.Components[i] as TRaveText).Name = 'DataTextMS' |
||
591 | then
|
||
592 | (Page.Components[i] as TRaveText).Text := EditMS.Text;
|
||
593 | if (Page.Components[i] as TRaveText).Name = 'DataTextMM' |
||
594 | then
|
||
595 | (Page.Components[i] as TRaveText).Text := EditMM.Text;
|
||
596 | if (Page.Components[i] as TRaveText).Name = 'DataTextMAT' |
||
597 | then
|
||
598 | (Page.Components[i] as TRaveText).Text := EditMAT.Text;
|
||
599 | if (Page.Components[i] as TRaveText).Name = 'DataTextMG' |
||
600 | then
|
||
601 | (Page.Components[i] as TRaveText).Text := EditMG.Text;
|
||
602 | if (Page.Components[i] as TRaveText).Name = 'DataTextCB' |
||
603 | then
|
||
604 | (Page.Components[i] as TRaveText).Text := EditCB.Text;
|
||
605 | if (Page.Components[i] as TRaveText).Name = 'DataTextNDF' |
||
606 | then
|
||
607 | (Page.Components[i] as TRaveText).Text := EditNDF.Text;
|
||
608 | if (Page.Components[i] as TRaveText).Name = 'DataTextADF' |
||
609 | then
|
||
610 | (Page.Components[i] as TRaveText).Text := EditADF.Text;
|
||
611 | if (Page.Components[i] as TRaveText).Name = 'DataTextAmidon' |
||
612 | then
|
||
613 | (Page.Components[i] as TRaveText).Text := EditAmidon.Text;
|
||
614 | if (Page.Components[i] as TRaveText).Name = 'DataTextSucres' |
||
615 | then
|
||
616 | (Page.Components[i] as TRaveText).Text := EditSucres.Text;
|
||
617 | if (Page.Components[i] as TRaveText).Name = 'DataTextMOdv' |
||
618 | then
|
||
619 | (Page.Components[i] as TRaveText).Text := EditMOdv.Text;
|
||
620 | if (Page.Components[i] as TRaveText).Name = 'DataTextEBc' |
||
621 | then
|
||
622 | (Page.Components[i] as TRaveText).Text := EditEBc.Text;
|
||
623 | if (Page.Components[i] as TRaveText).Name = 'DataTextEBt' |
||
624 | then
|
||
625 | (Page.Components[i] as TRaveText).Text := EditEBt.Text;
|
||
626 | if (Page.Components[i] as TRaveText).Name = 'DataTextEBt_EBc' |
||
627 | then
|
||
628 | (Page.Components[i] as TRaveText).Text := EditEBt_EBc.Text;
|
||
629 | if (Page.Components[i] as TRaveText).Name = 'DataTextEDc' |
||
630 | then
|
||
631 | (Page.Components[i] as TRaveText).Text := EditEDc.Text;
|
||
632 | if (Page.Components[i] as TRaveText).Name = 'DataTextEDt' |
||
633 | then
|
||
634 | (Page.Components[i] as TRaveText).Text := EditEDt.Text;
|
||
635 | if (Page.Components[i] as TRaveText).Name = 'DataTextEDt_EDc' |
||
636 | then
|
||
637 | (Page.Components[i] as TRaveText).Text := EditEDt_EDc.Text;
|
||
638 | if (Page.Components[i] as TRaveText).Name = 'DataTextEMc' |
||
639 | then
|
||
640 | (Page.Components[i] as TRaveText).Text := EditEMc.Text;
|
||
641 | if (Page.Components[i] as TRaveText).Name = 'DataTextEMt' |
||
642 | then
|
||
643 | (Page.Components[i] as TRaveText).Text := EditEMt.Text;
|
||
644 | if (Page.Components[i] as TRaveText).Name = 'DataTextEMt_EMc' |
||
645 | then
|
||
646 | (Page.Components[i] as TRaveText).Text := EditEMt_EMc.Text;
|
||
647 | if (Page.Components[i] as TRaveText).Name = 'DataTextENc' |
||
648 | then
|
||
649 | (Page.Components[i] as TRaveText).Text := EditENc.Text;
|
||
650 | if (Page.Components[i] as TRaveText).Name = 'DataTextENt' |
||
651 | then
|
||
652 | (Page.Components[i] as TRaveText).Text := EditENt.Text;
|
||
653 | if (Page.Components[i] as TRaveText).Name = 'DataTextENt_ENc' |
||
654 | then
|
||
655 | (Page.Components[i] as TRaveText).Text := EditENt_ENc.Text;
|
||
656 | if (Page.Components[i] as TRaveText).Name = 'DataTextBonusC' |
||
657 | then
|
||
658 | (Page.Components[i] as TRaveText).Text := EditBonusC.Text;
|
||
659 | if (Page.Components[i] as TRaveText).Name = 'DataTextBonusT' |
||
660 | then
|
||
661 | (Page.Components[i] as TRaveText).Text := EditBonusT.Text;
|
||
662 | if (Page.Components[i] as TRaveText).Name = 'DataTextdEc' |
||
663 | then
|
||
664 | (Page.Components[i] as TRaveText).Text := EditdEc.Text;
|
||
665 | if (Page.Components[i] as TRaveText).Name = 'DataTextdEt' |
||
666 | then
|
||
667 | (Page.Components[i] as TRaveText).Text := EditdEt.Text;
|
||
668 | if (Page.Components[i] as TRaveText).Name = 'DataTextEMc_EDc' |
||
669 | then
|
||
670 | (Page.Components[i] as TRaveText).Text := EditEMc_EDc.Text;
|
||
671 | if (Page.Components[i] as TRaveText).Name = 'DataTextEMt_EDt' |
||
672 | then
|
||
673 | (Page.Components[i] as TRaveText).Text := EditEMt_EDt.Text;
|
||
674 | if (Page.Components[i] as TRaveText).Name = 'DataTextENc_EMc' |
||
675 | then
|
||
676 | (Page.Components[i] as TRaveText).Text := EditENc_EMc.Text;
|
||
677 | if (Page.Components[i] as TRaveText).Name = 'DataTextENt_EMt' |
||
678 | then
|
||
679 | (Page.Components[i] as TRaveText).Text := EditENt_EMt.Text;
|
||
680 | if (Page.Components[i] as TRaveText).Name = 'DataTextdNc' |
||
681 | then
|
||
682 | (Page.Components[i] as TRaveText).Text := EditdNc.Text;
|
||
683 | if (Page.Components[i] as TRaveText).Name = 'DataTextdNt' |
||
684 | then
|
||
685 | (Page.Components[i] as TRaveText).Text := EditdNt.Text;
|
||
686 | end;
|
||
687 | end;
|
||
688 | |||
689 | procedure TFormPredictionDetail.FormCreate(Sender: TObject);
|
||
690 | var
|
||
691 | ProximalUnit, EnergyUnit: String;
|
||
692 | begin
|
||
693 | if Screen.Fonts.IndexOf('Arial Unicode MS') <> -1 |
||
694 | then
|
||
695 | Font.Name := 'Arial Unicode MS';
|
||
696 | // PanelButtons.Font.Size := PanelButtons.Font.Size + 2;
|
||
697 | PanelButtons.Font.Style := [fsBold]; |
||
698 | LabelName.Font.Style := [fsBold]; |
||
699 | EditName.Font.Style := [fsBold]; |
||
700 | TranslateComponent(Self); |
||
701 | with FormOptions do |
||
702 | if Expression = 0 |
||
703 | then // sur frais |
||
704 | begin
|
||
705 | ProximalUnit := ComboBoxProximal.Items[Proximal]; |
||
706 | EnergyUnit := ComboBoxEnergy.Items[Energy]; |
||
707 | end
|
||
708 | else // sur mati?re s?che |
||
709 | begin
|
||
710 | ProximalUnit := Format('%s %s', [ComboBoxProximal.Items[Proximal], _('DM')]); |
||
711 | EnergyUnit := Format('%s %s', [ComboBoxEnergy.Items[Energy], _('DM')]); |
||
712 | end;
|
||
713 | with FormOptions do |
||
714 | LabelMS.Caption := Format('%s (%s)', [LabelMS.Caption, ComboBoxProximal.Items[Proximal]]);
|
||
715 | GroupBoxProximal.Caption := Format('%s (%s)', [GroupBoxProximal.Caption, ProximalUnit]);
|
||
716 | GroupBoxEnergy.Caption := Format('%s (%s)', [GroupBoxEnergy.Caption, EnergyUnit]);
|
||
717 | LabelRatio.Caption := Format('%s (%%)', [LabelRatio.Caption]);
|
||
718 | GroupBoxEnergyUtilization.Caption := Format('%s (%%)', [GroupBoxEnergyUtilization.Caption]);
|
||
719 | GroupBoxAzote.Caption := Format('%s (%%)', [GroupBoxAzote.Caption]);
|
||
720 | end;
|
||
721 | |||
722 | procedure TFormPredictionDetail.FormShow(Sender: TObject);
|
||
723 | var
|
||
724 | Nb: Integer; |
||
725 | EqCB, EqNDF, EqADF, NUri, EUri, Res, ResD, ECH4, dMO: Double; |
||
726 | CurrentFormatSettings: TFormatSettings; |
||
727 | begin
|
||
728 | GetLocaleFormatSettings(GetUserDefaultLCID, CurrentFormatSettings); |
||
729 | with DataModuleDeclaration do |
||
730 | begin
|
||
731 | EditName.Text := FormPredictionCreate.EditName.Text; |
||
732 | // Analyse proximale -> valeurs saisies
|
||
733 | RapMS := InputProximal(FormPredictionCreate.ValidateEditMS.AsFloat, 1, 0, FormPredictionCreate.ComboBoxMS.ItemIndex); |
||
734 | MS := OutputProximal(RapMS, 1, 1, FormOptions.Proximal); |
||
735 | EditMS.Text := FloatToStrF(MS, ffFixed, 15, FormOptions.ProximalDecimals, CurrentFormatSettings);
|
||
736 | if FormPredictionCreate.CheckBoxMM.Checked
|
||
737 | then
|
||
738 | begin
|
||
739 | MM := InputProximal(FormPredictionCreate.ValidateEditMM.AsFloat, RapMS, FormPredictionCreate.ComboBoxMM.ItemIndex div 2, FormPredictionCreate.ComboBoxMM.ItemIndex mod 2); |
||
740 | EditMM.Text := FloatToStrF(OutputProximal(MM, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, CurrentFormatSettings);
|
||
741 | end;
|
||
742 | if FormPredictionCreate.CheckBoxMAT.Checked
|
||
743 | then
|
||
744 | begin
|
||
745 | MAT := InputProximal(FormPredictionCreate.ValidateEditMAT.AsFloat, RapMS, FormPredictionCreate.ComboBoxMAT.ItemIndex div 2, FormPredictionCreate.ComboBoxMAT.ItemIndex mod 2); |
||
746 | EditMAT.Text := FloatToStrF(OutputProximal(MAT, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, CurrentFormatSettings);
|
||
747 | end;
|
||
748 | if FormPredictionCreate.CheckBoxMG.Checked
|
||
749 | then
|
||
750 | begin
|
||
751 | MG := InputProximal(FormPredictionCreate.ValidateEditMG.AsFloat, RapMS, FormPredictionCreate.ComboBoxMG.ItemIndex div 2, FormPredictionCreate.ComboBoxMG.ItemIndex mod 2); |
||
752 | EditMG.Text := FloatToStrF(OutputProximal(MG, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, CurrentFormatSettings);
|
||
753 | end;
|
||
754 | if FormPredictionCreate.CheckBoxCB.Checked
|
||
755 | then
|
||
756 | begin
|
||
757 | CB := InputProximal(FormPredictionCreate.ValidateEditCB.AsFloat, RapMS, FormPredictionCreate.ComboBoxFibre.ItemIndex div 2, FormPredictionCreate.ComboBoxFibre.ItemIndex mod 2); |
||
758 | EditCB.Text := FloatToStrF(OutputProximal(CB, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, CurrentFormatSettings);
|
||
759 | end;
|
||
760 | if FormPredictionCreate.CheckBoxNDF.Checked
|
||
761 | then
|
||
762 | begin
|
||
763 | NDF := InputProximal(FormPredictionCreate.ValidateEditNDF.AsFloat, RapMS, FormPredictionCreate.ComboBoxFibre.ItemIndex div 2, FormPredictionCreate.ComboBoxFibre.ItemIndex mod 2); |
||
764 | EditNDF.Text := FloatToStrF(OutputProximal(NDF, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, CurrentFormatSettings);
|
||
765 | end;
|
||
766 | if FormPredictionCreate.CheckBoxADF.Checked
|
||
767 | then
|
||
768 | begin
|
||
769 | ADF := InputProximal(FormPredictionCreate.ValidateEditADF.AsFloat, RapMS, FormPredictionCreate.ComboBoxFibre.ItemIndex div 2, FormPredictionCreate.ComboBoxFibre.ItemIndex mod 2); |
||
770 | EditADF.Text := FloatToStrF(OutputProximal(ADF, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, CurrentFormatSettings);
|
||
771 | end;
|
||
772 | if FormPredictionCreate.CheckBoxAmidon.Checked
|
||
773 | then
|
||
774 | begin
|
||
775 | Amidon := InputProximal(FormPredictionCreate.ValidateEditAmidon.AsFloat, RapMS, FormPredictionCreate.ComboBoxAmidon.ItemIndex div 2, FormPredictionCreate.ComboBoxAmidon.ItemIndex mod 2); |
||
776 | EditAmidon.Text := FloatToStrF(OutputProximal(Amidon, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, CurrentFormatSettings);
|
||
777 | end;
|
||
778 | if FormPredictionCreate.CheckBoxSucres.Checked
|
||
779 | then
|
||
780 | begin
|
||
781 | Sucres := InputProximal(FormPredictionCreate.ValidateEditSucres.AsFloat, RapMS, FormPredictionCreate.ComboBoxSucres.ItemIndex div 2, FormPredictionCreate.ComboBoxSucres.ItemIndex mod 2); |
||
782 | EditSucres.Text := FloatToStrF(OutputProximal(Sucres, RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, CurrentFormatSettings);
|
||
783 | end;
|
||
784 | if FormPredictionCreate.CheckBoxdMOv.Checked
|
||
785 | then
|
||
786 | begin
|
||
787 | dMOv := FormPredictionCreate.ValidateEditdMOv.AsFloat / 100;
|
||
788 | if FormPredictionCreate.CheckBoxMM.Checked
|
||
789 | then // MOdv = dMOv * MO avec MO = 1 - MM |
||
790 | EditMOdv.Text := FloatToStrF(OutputProximal(dMOv * (1 - MM), RapMS, FormOptions.Expression, FormOptions.Proximal), ffFixed, 15, FormOptions.ProximalDecimals, CurrentFormatSettings); |
||
791 | end;
|
||
792 | // Energie
|
||
793 | if FormPredictionCreate.CheckBoxEB.Checked
|
||
794 | then // EB fournie par l'utilisateur |
||
795 | begin
|
||
796 | EB := InputEnergy(FormPredictionCreate.ValidateEditEB.AsFloat, RapMS, FormPredictionCreate.ComboBoxEB.ItemIndex div 2, FormPredictionCreate.ComboBoxEB.ItemIndex mod 2); |
||
797 | EditEBc.Text := FloatToStrF(OutputEnergy(EB, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, CurrentFormatSettings);
|
||
798 | end
|
||
799 | else
|
||
800 | if FormPredictionCreate.CheckBoxMM.Checked and FormPredictionCreate.CheckBoxMAT.Checked and FormPredictionCreate.CheckBoxMG.Checked |
||
801 | then // EB calcul?e |
||
802 | begin
|
||
803 | if FormPredictionCreate.CheckBoxCB.Checked
|
||
804 | then
|
||
805 | if FormPredictionCreate.CheckBoxSucres.Checked
|
||
806 | then // Equation AVEC sucres |
||
807 | EqCB := 17.56 + 5.51 * MAT + 21.48 * MG - 17.74 * MM + 2.59 * CB - 1.14 * Sucres |
||
808 | else // Equation SANS sucres |
||
809 | EqCB := 17.57 + 5.35 * MAT + 21.68 * MG - 18.61 * MM + 2.84 * CB |
||
810 | else
|
||
811 | EqCB := 0;
|
||
812 | if FormPredictionCreate.CheckBoxNDF.Checked
|
||
813 | then
|
||
814 | if FormPredictionCreate.CheckBoxSucres.Checked
|
||
815 | then // Equation AVEC sucres |
||
816 | EqNDF := 17.41 + 5.79 * MAT + 21.63 * MG - 18.12 * MM + 1.48 * NDF - 0.72 * Sucres |
||
817 | else // Equation SANS sucres |
||
818 | EqNDF := 17.40 + 5.73 * MAT + 21.76 * MG - 18.73 * MM + 1.61 * NDF |
||
819 | else
|
||
820 | EqNDF := 0;
|
||
821 | if FormPredictionCreate.CheckBoxADF.Checked
|
||
822 | then
|
||
823 | if FormPredictionCreate.CheckBoxSucres.Checked
|
||
824 | then // Equation AVEC sucres |
||
825 | EqADF := 17.56 + 5.45 * MAT + 21.50 * MG - 17.69 * MM + 2.16 * ADF - 1.15 * Sucres |
||
826 | else // Equation SANS sucres |
||
827 | EqADF := 17.58 + 5.29 * MAT + 21.71 * MG - 18.58 * MM + 2.38 * ADF |
||
828 | else
|
||
829 | EqADF := 0;
|
||
830 | Nb := 0;
|
||
831 | if EqCB <> 0 then Inc(Nb); |
||
832 | if EqNDF <> 0 then Inc(Nb); |
||
833 | if EqADF <> 0 then Inc(Nb); |
||
834 | if Nb = 0 |
||
835 | then // Equations sans valeur de fibre |
||
836 | if FormPredictionCreate.CheckBoxAmidon.Checked
|
||
837 | then // Equation AVEC amidon |
||
838 | if FormPredictionCreate.CheckBoxSucres.Checked
|
||
839 | then // Equation AVEC sucres |
||
840 | EB := 18.88 + 4.24 * MAT + 20.25 * MG - 20.37 * MM - 1.42 * Amidon - 2.38 * Sucres |
||
841 | else // Equation SANS sucres |
||
842 | EB := 18.47 + 4.14 * MAT + 21.08 * MG - 19.64 * MM - 0.92 * Amidon |
||
843 | else // Equation SANS amidon |
||
844 | if FormPredictionCreate.CheckBoxSucres.Checked
|
||
845 | then // Equation AVEC sucres |
||
846 | EB := 17.61 + 5.05 * MAT + 21.53 * MG - 15.06 * MM - 1.48 * Sucres |
||
847 | else // Equation SANS sucres |
||
848 | EB := 17.64 + 4.78 * MAT + 21.80 * MG - 15.88 * MM |
||
849 | else // Moyenne des ?quations significatives |
||
850 | EB := (EqCB + EqNDF + EqADF) / Nb; |
||
851 | EditEBc.Text := FloatToStrF(OutputEnergy(EB, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, CurrentFormatSettings);
|
||
852 | end;
|
||
853 | BonusC := FormPredictionCreate.SpinEditBonusC.Value; |
||
854 | EditBonusC.Text := FormPredictionCreate.SpinEditBonusC.Text; |
||
855 | if FormPredictionCreate.CheckBoxdMOv.Checked
|
||
856 | then // Equation AVEC dMOv |
||
857 | begin
|
||
858 | if FormPredictionCreate.CheckBoxCB.Checked
|
||
859 | then
|
||
860 | if FormPredictionCreate.CheckBoxMM.Checked
|
||
861 | then // Equation AVEC MM |
||
862 | EqCB := 35.5 + 64.0 * dMOv - 68.0 * CB - 68.0 * MM |
||
863 | else // Equation SANS MM |
||
864 | EqCB := 30.1 + 66.3 * dMOv - 77.0 * CB |
||
865 | else
|
||
866 | EqCB := 0;
|
||
867 | if FormPredictionCreate.CheckBoxADF.Checked
|
||
868 | then
|
||
869 | if FormPredictionCreate.CheckBoxMM.Checked
|
||
870 | then // Equation AVEC MM |
||
871 | EqADF := 41.0 + 58.5 * dMOv - 74.0 * ADF - 64.0 * MM |
||
872 | else // Equation SANS MM |
||
873 | EqADF := 36.2 + 60.2 * dMOv - 82.0 * ADF |
||
874 | else
|
||
875 | EqADF := 0;
|
||
876 | Nb := 0;
|
||
877 | if EqCB <> 0 then Inc(Nb); |
||
878 | if EqADF <> 0 then Inc(Nb); |
||
879 | if Nb = 0 |
||
880 | then // Equation sans valeur de fibre (dMOv seule) |
||
881 | dEc := 97.6 * dMOv |
||
882 | else // Moyenne des ?quations significatives |
||
883 | dEc := (EqCB + EqADF) / Nb; |
||
884 | EditdEc.Text := FloatToStrF(dEc + BonusC, ffFixed, 15, 1, CurrentFormatSettings); |
||
885 | end
|
||
886 | else // Equation SANS dMOv |
||
887 | begin
|
||
888 | if FormPredictionCreate.CheckBoxCB.Checked
|
||
889 | then
|
||
890 | if FormPredictionCreate.CheckBoxMM.Checked
|
||
891 | then // Equation AVEC MM |
||
892 | EqCB := 98.0 - 160.0 * MM - 126.0 * CB |
||
893 | else // Equation SANS MM |
||
894 | EqCB := 90.1 - 156.6 * CB |
||
895 | else
|
||
896 | EqCB := 0;
|
||
897 | if FormPredictionCreate.CheckBoxNDF.Checked
|
||
898 | then
|
||
899 | if FormPredictionCreate.CheckBoxMM.Checked
|
||
900 | then // Equation AVEC MM |
||
901 | EqNDF := 102.6 - 106.1 * MM - 79.5 * NDF |
||
902 | else // Equation SANS MM |
||
903 | EqNDF := 98.3 - 90.1 * NDF |
||
904 | else
|
||
905 | EqNDF := 0;
|
||
906 | if FormPredictionCreate.CheckBoxADF.Checked
|
||
907 | then
|
||
908 | if FormPredictionCreate.CheckBoxMM.Checked
|
||
909 | then // Equation AVEC MM |
||
910 | EqADF := 97.9 - 146.2 * MM - 117.5 * ADF |
||
911 | else // Equation SANS MM |
||
912 | EqADF := 90.8 - 142.7 * ADF |
||
913 | else
|
||
914 | EqADF := 0;
|
||
915 | Nb := 0;
|
||
916 | if EqCB <> 0 then Inc(Nb); |
||
917 | if EqNDF <> 0 then Inc(Nb); |
||
918 | if EqADF <> 0 then Inc(Nb); |
||
919 | if Nb > 0 |
||
920 | then // Moyenne des ?quations significatives |
||
921 | begin
|
||
922 | dEc := (EqCB + EqNDF + EqADF) / Nb; |
||
923 | EditdEc.Text := FloatToStrF(dEc + BonusC, ffFixed, 15, 1, CurrentFormatSettings); |
||
924 | end;
|
||
925 | end;
|
||
926 | if (EditEBc.Text <> '') and (EditdEc.Text <> '') |
||
927 | then
|
||
928 | begin
|
||
929 | EDc := EB * (dEc + BonusC) / 100;
|
||
930 | EditEDc.Text := FloatToStrF(OutputEnergy(EDc, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, CurrentFormatSettings);
|
||
931 | end;
|
||
932 | if (EditEDc.Text <> '') and FormPredictionCreate.CheckBoxMM.Checked and FormPredictionCreate.CheckBoxMAT.Checked and FormPredictionCreate.CheckBoxMG.Checked and FormPredictionCreate.CheckBoxAmidon.Checked |
||
933 | then
|
||
934 | begin
|
||
935 | NUri := 0.4 * MAT / 6.25; |
||
936 | EUri := CALORIE * (0.046 + 7.4 * NUri); |
||
937 | if FormPredictionCreate.CheckBoxSucres.Checked
|
||
938 | then // Equation AVEC sucres |
||
939 | Res := 1 - MM - MAT - MG - Amidon - Sucres
|
||
940 | else // Equation SANS sucres (par d?faut, on estime les sucres ? 2 % MS) |
||
941 | Res := 1 - MM - MAT - MG - Amidon - 0.02; |
||
942 | ResD := 0.5 * Res;
|
||
943 | ECH4 := CALORIE * 0.16 * ResD;
|
||
944 | EMc := EDc - EUri - ECH4; |
||
945 | EditEMc.Text := FloatToStrF(OutputEnergy(EMc, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, CurrentFormatSettings);
|
||
946 | if EDc <> 0 |
||
947 | then
|
||
948 | EditEMc_EDc.Text := FloatToStrF(EMc / EDc * 100, ffFixed, 15, 1, CurrentFormatSettings); |
||
949 | end;
|
||
950 | if (EditEDc.Text <> '') and FormPredictionCreate.CheckBoxMAT.Checked and FormPredictionCreate.CheckBoxMG.Checked and FormPredictionCreate.CheckBoxAmidon.Checked |
||
951 | then
|
||
952 | begin
|
||
953 | if FormPredictionCreate.CheckBoxCB.Checked
|
||
954 | then
|
||
955 | EqCB := 0.703 * EDc - 4.04 * MAT + 6.62 * MG + 1.97 * Amidon - 4.09 * CB |
||
956 | else
|
||
957 | EqCB := 0;
|
||
958 | if FormPredictionCreate.CheckBoxNDF.Checked
|
||
959 | then
|
||
960 | EqNDF := 0.703 * EDc - 4.10 * MAT + 6.64 * MG + 1.97 * Amidon - 1.34 * NDF |
||
961 | else
|
||
962 | EqNDF := 0;
|
||
963 | if FormPredictionCreate.CheckBoxADF.Checked
|
||
964 | then
|
||
965 | EqADF := 0.700 * EDc - 3.82 * MAT + 6.74 * MG + 2.02 * Amidon - 3.65 * ADF |
||
966 | else
|
||
967 | EqADF := 0;
|
||
968 | Nb := 0;
|
||
969 | if EqCB <> 0 then Inc(Nb); |
||
970 | if EqNDF <> 0 then Inc(Nb); |
||
971 | if EqADF <> 0 then Inc(Nb); |
||
972 | if Nb > 0 |
||
973 | then // Moyenne des ?quations significatives |
||
974 | begin
|
||
975 | ENc := (EqCB + EqNDF + EqADF) / Nb; |
||
976 | EditENc.Text := FloatToStrF(OutputEnergy(ENc, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, CurrentFormatSettings);
|
||
977 | if EMc <> 0 |
||
978 | then
|
||
979 | EditENc_EMc.Text := FloatToStrF(ENc / EMc * 100, ffFixed, 15, 1, CurrentFormatSettings); |
||
980 | end;
|
||
981 | end;
|
||
982 | EditEBt.Text := EditEBc.Text; |
||
983 | BonusT := FormPredictionCreate.SpinEditBonusT.Value; |
||
984 | EditBonusT.Text := FormPredictionCreate.SpinEditBonusT.Text; |
||
985 | if (EditEDc.Text <> '') and FormPredictionCreate.CheckBoxMM.Checked and FormPredictionCreate.CheckBoxMAT.Checked |
||
986 | then
|
||
987 | begin
|
||
988 | dMO := (7.45 + 0.949 * dEc - 4.0 * MAT) / 100; |
||
989 | EDt := EB * dEc / 100 + CALORIE * (1 - MM) * (1 - dMO); |
||
990 | if (EditEBt.Text <> '') and (EB <> 0) |
||
991 | then
|
||
992 | begin
|
||
993 | dEt := EDt / EB * 100;
|
||
994 | EditdEt.Text := FloatToStrF(dEt + BonusT, ffFixed, 15, 1, CurrentFormatSettings); |
||
995 | // Recalculer EDt pour prendre en compte le bonus
|
||
996 | EDt := EB * (dEt + BonusT) / 100;
|
||
997 | EditEDt.Text := FloatToStrF(OutputEnergy(EDt, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, CurrentFormatSettings);
|
||
998 | end;
|
||
999 | end;
|
||
1000 | if (EditEDt.Text <> '') and FormPredictionCreate.CheckBoxMM.Checked and FormPredictionCreate.CheckBoxMAT.Checked and FormPredictionCreate.CheckBoxMG.Checked and FormPredictionCreate.CheckBoxAmidon.Checked |
||
1001 | then
|
||
1002 | begin
|
||
1003 | NUri := 0.4 * MAT / 6.25; |
||
1004 | EUri := CALORIE * (0.052 + 7.4 * NUri); |
||
1005 | if FormPredictionCreate.CheckBoxSucres.Checked
|
||
1006 | then // Equation AVEC sucres |
||
1007 | Res := 1 - MM - MAT - MG - Amidon - Sucres
|
||
1008 | else // Equation SANS sucres (par d?faut, on estime les sucres ? 2 % MS) |
||
1009 | Res := 1 - MM - MAT - MG - Amidon - 0.02; |
||
1010 | ResD := 0.6 * Res;
|
||
1011 | ECH4 := CALORIE * 0.32 * ResD;
|
||
1012 | EMt := EDt - EUri - ECH4; |
||
1013 | EditEMt.Text := FloatToStrF(OutputEnergy(EMt, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, CurrentFormatSettings);
|
||
1014 | if EDt <> 0 |
||
1015 | then
|
||
1016 | EditEMt_EDt.Text := FloatToStrF(EMt / EDt * 100, ffFixed, 15, 1, CurrentFormatSettings); |
||
1017 | end;
|
||
1018 | if (EditEDt.Text <> '') and FormPredictionCreate.CheckBoxMAT.Checked and FormPredictionCreate.CheckBoxMG.Checked and FormPredictionCreate.CheckBoxAmidon.Checked |
||
1019 | then
|
||
1020 | begin
|
||
1021 | if FormPredictionCreate.CheckBoxCB.Checked
|
||
1022 | then
|
||
1023 | EqCB := 0.703 * EDt - 4.04 * MAT + 6.62 * MG + 1.97 * Amidon - 4.09 * CB |
||
1024 | else
|
||
1025 | EqCB := 0;
|
||
1026 | if FormPredictionCreate.CheckBoxNDF.Checked
|
||
1027 | then
|
||
1028 | EqNDF := 0.703 * EDt - 4.10 * MAT + 6.64 * MG + 1.97 * Amidon - 1.34 * NDF |
||
1029 | else
|
||
1030 | EqNDF := 0;
|
||
1031 | if FormPredictionCreate.CheckBoxADF.Checked
|
||
1032 | then
|
||
1033 | EqADF := 0.700 * EDt - 3.82 * MAT + 6.74 * MG + 2.02 * Amidon - 3.65 * ADF |
||
1034 | else
|
||
1035 | EqADF := 0;
|
||
1036 | Nb := 0;
|
||
1037 | if EqCB <> 0 then Inc(Nb); |
||
1038 | if EqNDF <> 0 then Inc(Nb); |
||
1039 | if EqADF <> 0 then Inc(Nb); |
||
1040 | if Nb > 0 |
||
1041 | then // Moyenne des ?quations significatives |
||
1042 | begin
|
||
1043 | ENt := (EqCB + EqNDF + EqADF) / Nb; |
||
1044 | EditENt.Text := FloatToStrF(OutputEnergy(ENt, RapMS, FormOptions.Expression, FormOptions.Energy), ffFixed, 15, FormOptions.EnergyDecimals, CurrentFormatSettings);
|
||
1045 | if EMt <> 0 |
||
1046 | then
|
||
1047 | EditENt_EMt.Text := FloatToStrF(ENt / EMt * 100, ffFixed, 15, 1, CurrentFormatSettings); |
||
1048 | end;
|
||
1049 | end;
|
||
1050 | if EditEBc.Text <> '' |
||
1051 | then
|
||
1052 | EditEBt_EBc.Text := FloatToStrF(100, ffFixed, 15, 1, CurrentFormatSettings); |
||
1053 | if (EditEDt.Text <> '') and (EditEDc.Text <> '') and (EDc <> 0) |
||
1054 | then
|
||
1055 | EditEDt_EDc.Text := FloatToStrF(EDt / EDc * 100, ffFixed, 15, 1, CurrentFormatSettings); |
||
1056 | if (EditEMt.Text <> '') and (EditEMc.Text <> '') and (EMc <> 0) |
||
1057 | then
|
||
1058 | EditEMt_EMc.Text := FloatToStrF(EMt / EMc * 100, ffFixed, 15, 1, CurrentFormatSettings); |
||
1059 | if (EditENt.Text <> '') and (EditENc.Text <> '') and (ENc <> 0) |
||
1060 | then
|
||
1061 | EditENt_ENc.Text := FloatToStrF(ENt / ENc * 100, ffFixed, 15, 1, CurrentFormatSettings); |
||
1062 | // Digestibilit? f?cale de l'azote
|
||
1063 | if FormPredictionCreate.CheckBoxMAT.Checked
|
||
1064 | then
|
||
1065 | begin
|
||
1066 | if FormPredictionCreate.CheckBoxCB.Checked
|
||
1067 | then
|
||
1068 | EqCB := 76.8 + 69.0 * MAT - 122.0 * CB |
||
1069 | else
|
||
1070 | EqCB := 0;
|
||
1071 | if FormPredictionCreate.CheckBoxNDF.Checked
|
||
1072 | then
|
||
1073 | EqNDF := 81.3 + 79.0 * MAT - 69.0 * NDF |
||
1074 | else
|
||
1075 | EqNDF := 0;
|
||
1076 | if FormPredictionCreate.CheckBoxADF.Checked
|
||
1077 | then
|
||
1078 | EqADF := 77.4 + 70.0 * MAT - 116.0 * ADF |
||
1079 | else
|
||
1080 | EqADF := 0;
|
||
1081 | Nb := 0;
|
||
1082 | if EqCB <> 0 then Inc(Nb); |
||
1083 | if EqNDF <> 0 then Inc(Nb); |
||
1084 | if EqADF <> 0 then Inc(Nb); |
||
1085 | if Nb > 0 |
||
1086 | then // Moyenne des ?quations significatives |
||
1087 | begin
|
||
1088 | dNc := (EqCB + EqNDF + EqADF) / Nb; |
||
1089 | EditdNc.Text := FloatToStrF(dNc, ffFixed, 15, 1, CurrentFormatSettings); |
||
1090 | end;
|
||
1091 | if FormPredictionCreate.CheckBoxCB.Checked
|
||
1092 | then
|
||
1093 | EqCB := 77.9 + 77.0 * MAT - 87.0 * CB |
||
1094 | else
|
||
1095 | EqCB := 0;
|
||
1096 | if FormPredictionCreate.CheckBoxNDF.Checked
|
||
1097 | then
|
||
1098 | EqNDF := 79.9 + 86.0 * MAT - 44.0 * NDF |
||
1099 | else
|
||
1100 | EqNDF := 0;
|
||
1101 | if FormPredictionCreate.CheckBoxADF.Checked
|
||
1102 | then
|
||
1103 | EqADF := 78.3 + 78.0 * MAT - 83.0 * ADF |
||
1104 | else
|
||
1105 | EqADF := 0;
|
||
1106 | Nb := 0;
|
||
1107 | if EqCB <> 0 then Inc(Nb); |
||
1108 | if EqNDF <> 0 then Inc(Nb); |
||
1109 | if EqADF <> 0 then Inc(Nb); |
||
1110 | if Nb > 0 |
||
1111 | then // Moyenne des ?quations significatives |
||
1112 | begin
|
||
1113 | dNt := (EqCB + EqNDF + EqADF) / Nb; |
||
1114 | EditdNt.Text := FloatToStrF(dNt, ffFixed, 15, 1, CurrentFormatSettings); |
||
1115 | end;
|
||
1116 | end;
|
||
1117 | end;
|
||
1118 | end;
|
||
1119 | |||
1120 | end. |