С Новым годом! Форум программистов, компьютерный форум, киберфорум
Java
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
81 / 15 / 0
Регистрация: 19.03.2012
Сообщений: 465
Записей в блоге: 1

Из Делфи в Java

13.02.2013, 16:50. Показов 1074. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
есть код на Делфи нужно переделать под Java, кто знает как, подскажите!

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
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
unit Unit1;
 
interface
 
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, ExtCtrls, StdCtrls, Menus, Spin, Gauges, jpeg;
 
type
  TForm1 = class(TForm)
    Button1: TButton;
    Button2: TButton;
    Image1: TImage;
    Image2: TImage;
    SpinEdit1: TSpinEdit;
    SpinEdit2: TSpinEdit;
    Edit1: TEdit;
    Edit2: TEdit;
    Edit3: TEdit;
    Edit4: TEdit;
    Button3: TButton;
    Button4: TButton;
    Button5: TButton;
    Button6: TButton;
    Button7: TButton;
    Gauge1: TGauge;
    Label1: TLabel;
    Label2: TLabel;
    Label3: TLabel;
    Label4: TLabel;
    Label5: TLabel;
    Label6: TLabel;
    Label7: TLabel;
    Label10: TLabel;
    Memo1: TMemo;
    Image3: TImage;
    procedure Button2Click(Sender: TObject);
    procedure FormCreate(Sender: TObject);
    procedure Button3Click(Sender: TObject);
    procedure Button4Click(Sender: TObject);
    procedure Button5Click(Sender: TObject);
    procedure Button6Click(Sender: TObject);
    procedure Button7Click(Sender: TObject);
    procedure SpinEdit1Change(Sender: TObject);
    procedure Edit1Change(Sender: TObject);
    procedure Edit2Change(Sender: TObject);
    procedure Edit3Change(Sender: TObject);
    procedure Edit4Change(Sender: TObject);
    procedure SpinEdit2Change(Sender: TObject);
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
 
var
  Form1: TForm1;
 
implementation
 
{$R *.dfm}
TYPE {типы данных}
Neuron=record {элемент нейрополя - нейрон}
 WX,WY:real;     {веса входных связей}
 LockX,LockY:integer; {координаты расположении на поле}
 N_OUT:real;     {выходной сигнал нейрона}
end;
VAR {переменные, используемые при моделировании}
 Neurons:integer; {число нейронов в нейрополе}
 ALPHA:real;   {коэффициент пластичности}
 R_ACTIV:Byte; {радиус "пузырька" активности}
 Node:array[1..40,1..40] of Neuron; {нейрополе - одномерная сеть Кохонена}
 KOEFF_ALPHA:real; {множитель для коэффициента пластичности}
 SHOW_CONNECTIONS:BOOLEAN; {флаг разрешения отображения связей}
 U:integer;{ Общее число производимых итераций в сети }
 Step:integer;{ Значение шага модификации размера области активации и коэффициента пластичности}
 
 
Procedure Line(X1,Y1,X2,Y2:integer);
begin { рисование линии }
     With Form1.Image1.Canvas do
     begin
          MoveTo(X1,Y1);
          LineTo(X2,Y2);
     end;
     With Form1.Image2.Canvas do
     begin
          MoveTo(X1,Y1);
          LineTo(X2,Y2);
     end;
end;
 
 
procedure CLEAR_SCREEN; { ОЧИСТКА ЭКРАНА }
Var NewRect: Trect; { тип прямоугольного элемента в Delphi}
begin
   With Form1 do { Работа с "формой" Delphi}
   begin
   { основной экран }
   Image1.Canvas.Brush.Color:=clNavy; { цвет фона  }
   { размер области изображения }
   NewRect := Rect(0, 0, Image1.Width, Image1.Height);
   Image1.Refresh; { очистить рабочую область памяти под изображение }
   Image1.Canvas.FillRect(NewRect); { изобразить пустой прямоугольник }
 
   { вспомогательный экран }
   Image2.Canvas.Brush.Color:=clNavy; { цвет фона  }
   { размер области изображения }
   NewRect := Rect(0, 0, Image2.Width, Image2.Height);
   Image2.Refresh; { очистить рабочую область памяти под изображение }
   Image2.Canvas.FillRect(NewRect); { изобразить пустой прямоугольник }
   end; {of With Formi }
end;
 
 
Procedure DRAW_NET;
{ ПРОЦЕДУРА ОТОБРАЖЕНИЯ СОСТОЯНИЯ СЕТИ В ВИДЕ УЗЛОВ, СОЕДИНЕННЫХ СВЯЗЯМИ }
 Const
R=2; { радиус изображения нейрона - узла сети }
CLine=clBlack; { цвет линии межнейронной связи }
CFace=clBlack; { цвет обрамления тела нейрона }
CBody=clYellow; { цвет заполнения тела нейрона }
Var i,j,k:integer; { счетчики }
 
begin
     if SHOW_CONNECTIONS then { проверить флаг отображения связей}
     begin { ОТОБРАЗИТЬ СВЯЗИ }
          Form1.Image1.Canvas.Pen.Color:=CLine; { цвет связей }
       {отображение связей от нейрона к нейрону, с учетом их общего количества}
       for i:=1 to Neurons do
       begin
         for j:=1 to Neurons do
         begin
           With Form1.Image1.Canvas do
           begin { установить перо в положение i-го нейрона}
                 MoveTo(Node[i,j].LockX,Node[i,j].LockY);
                 if i<>Neurons then { если это не последний нейрон}
                 begin
                      LineTo(Node[i+1,j].LockX,Node[i+1,j].LockY);
                 end;
                 MoveTo(Node[i,j].LockX,Node[i,j].LockY);
                 if j<>Neurons then
                 begin
                      LineTo(Node[i,j+1].LockX,Node[i,j+1].LockY);
                 end;
                 { провести линию до i+1-го нейрона}
           end;
         end;
       end;
     end;
       {ОТОБРАЗИТЬ УЗЛЫ}
       Form1.Image1.Canvas.Pen.Color:=CFace; { цвет обрамления узла}
       Form1.Image1.Canvas.Brush.Color:=CBody; { цвет узла }
       for i:=1 to Neurons do { Для всех нейронов в сети Кохонена}
       for j:=1 to Neurons do
       With Node[i,j] do { Отобразить нейрон в его координатах }
       Form1.Image1.Canvas.Ellipse(LockX-R,LockY-R,LockX+R,LockY+R);
end;
 
 
Procedure GET_IMAGE; { ПОСТРОИТЬ ИСХОДНЫЙ ОБРАЗ }
Var NewRect: Trect; { тип прямоугольного элемента в Delphi}
begin
   With Form1 do { Работа с "формой" Delphi}
   begin
   Image1.Canvas.Brush.Color:=clSilver; { цвет фона  }
   { размер области изображения }
   NewRect := Rect(0, 0, Image1.Width, Image1.Height);
   Image1.Refresh; { очистить рабочую область памяти под изображение }
   Image1.Canvas.FillRect(NewRect); { изобразить пустой прямоугольник }
   With Image1.Canvas do { работа с изображением русла }
   begin { Копировать изображение микрососудов из резервной области, }
         { хранящей начальное изображение }
         CopyRect(Image1.ClientRect, Image2.Canvas, Image2.ClientRect);
   end; { of With Image1.Canvas }
   end; {of With Formi }
end;
 
 
procedure GetRandomNet;
{ ЗАДАТЬ НАЧАЛЬНОЕ ПОЛОЖЕНИЕ НЕЙРОНОВ, РАСПОЛОЖИВ ИХ СЛУЧАЙНЫМ ОБРАЗОМ }
Var i,j:integer; {счетчик}
begin
     With Form1.Image1. Canvas do { с полем изображения }
     for i:=1 to Neurons do { для всех нейронов сети }
     for j:=1 to Neurons do
     With Node[i,j] do { для i-ro нейрона в сети }
     begin
          LockX:=RANDOM(Form1.Image1.Width); {Случайная координата по Х }
          LockY:=RANDOM(Form1.Image1.Height); {Случайная координата по Y}
          WX:=LockX; { Вес по Х как координата }
          WY:=LockY; { Вес по Y как координата }
     end;
end;
 
 
procedure TForm1.SpinEdit2Change(Sender: TObject);
begin
    R_ACTIV:=SpinEdit1.Value;
end;
 
procedure TForm1.Button1Click(Sender: TObject);
{ПРОЦЕДУРА САМООБУЧЕНИЯ ДВУМЕРНОЙ СЕТИ КОХОНЕНА С ЦЕЛЬЮ
РАВНОМЕРНОЙ АППРОКСИМАЦИИ ПЛОТНОСТИ РАСПРЕДЕЛЕНИЯ ОПТИЧЕСКОГО
ИЗОБРАЖЕНИЯ }
Const
ColorS=clRed; { Условие о том, что  на изображении - красный }
 Var
i,j:integer; {счетчики}
T:integer; { счетчик общего числа итераций в нейросети}
Sum:real; { переменная накопления значений суммы}
Max:real; { Переменная для контроля максимального выхода нейрона}
dmX,dmY:real; { дифференциалы весов связей }
inY,inX,outY,outX:integer; { коордтнаты нейронов, чьи веса модифицируются}
{в соответствии с размерами области активации }
iMax,jMax: integer; { координаты нейрона с максимальным значением возбуждения}
{ что соответствует минимуму значения параметра N_OUT }
xS,yS: integer; { Координаты точки изображения o сигнала "возбуждения"}
R:real;
Code:integer;
 
begin { ИТЕРАЦИИ ДВУМЕРНОЙ СЕТИ КОХОНЕНА }
 
 
 
 
{Шаг 1}
GetRandomNet;
DRAW_NET; { новая отрисовка сети } {Шаг 1}
 
{ Установить цвет начальной точки как цвет фона} {Шаг 2}
Val(Edit1.Text, R, Code);
ALPHA:=R;
Val(Edit3.Text, R, Code);
KOEFF_ALPHA:=R;
Gauge1.MinValue:=1;
Gauge1.MaxValue:=U;
for T:=1 to U do { Цикл по полному числу итераций в сети}
begin {ШагЗ}
      Gauge1.Progress:=T;
 
      if(T Mod Step)=0
      then
      begin {Шаг 4}
         ALPHA:=ALPHA*KOEFF_ALPHA; { изменить степень пластичности }
         if R_ACTIV>1 then R_ACTIV:=R_ACTIV-1; { изменить радиус области активации }
      end;
      {Шаг 5}
      GET_IMAGE; { Обновить исходный образ } {Шаг 6}
      i:=1;j:=1; { Начальное значение положения точки на изображении }
      while Image2.Canvas.Pixels[j,i]<>clRed do { Выбрать случайную точку изображения }
      begin        { для использования в качестве сигнала возбуждения }
         i:=RANDOM(Image1.Height);
         j:=RANDOM(Image1.Width);
      end;
      yS:=i; { Координата Y точки, принадлежащей фигуре }
      xS:=j; { Координата X точки, принадлежащей фигуре } {Шаг 7}
      for i:=1 to Neurons do { вычисление выходных сигналов для всех нейронов }
      begin
         for j:=1 to Neurons do
         begin
            With Node[i,j] do { выход i-ro нейрона }
            N_OUT:=SQRT(SQR(xS-WX)+SQR(yS-WY));
            { Вычисление значения выходного сигнала как суммы векторных разностей}
            { координат i,j-ro нейрона и точки изображения с сигналом возбуждения }
         end;
      end;
      {Шаг 8}
      { определение нейрона с максимальным значением выхода}
      { !!! Минимальным значением N_OUT !!! }
      Max:=1E+20; { условный начальный максимум сигнала }
      for i:=1 to Neurons do { для всех нейронов в сети }
      begin
         for j:=1 to Neurons do
         With Node[i,j] do { для i-ro нейрона }
         begin
              if N_OUT<=Max then { если сигнал выхода меньше минимального }
              begin
                Max:=N_OUT;
                iMax:=i; { позиция нейрона максимальной активности }
                jMax:=j;
              end;
         end;
      end;
      { модификация связей внутри области возбуждения }
      { Определение номеров начального и конечного нейрона в области активации }
      {Шаг 9}
      if (iMax-R_ACTIV)<=0
      then inY:=1 { область активации вдоль оси сети }
      else inY:=iMax-R_ACTIV; { номер начального (левого) нейрона в области }
      if (iMax+R_ACTIV)>Neurons
      then outY:=Neurons
      else outY:=iMax+R_ACTIV;
 
      if (jMax-R_ACTIV)<=0
      then inX:=1 { область активации вдоль оси сети }
      else inX:=jMax-R_ACTIV; { номер начального (левого) нейрона в области }
      if (jMax+R_ACTIV)>Neurons
      then outX:=Neurons
      else outX:=jMax+R_ACTIV;
 
      { модификация весов связей внутри области активации }
      for i:=inY to outY do
      begin
         for j:=inX to outX do
         begin
              With Node[i,j] do
              begin
                   WX:=WX+ALPHA*(xS-WX);
                   LockX:=ROUND(WX); { новое положение по X}
                   WY:=WY+ALPHA*(yS-WY);
                   LockY:=ROUND(WY); { новое положение по Y }
              end;
         end;
      end;
      {Шаг 11}
      DRAW_NET; { новая отрисовка сети } {Шаг 12}
      { завершение полного цикла по заданному числу итераций }
end; { завершение процедуры итерирования нейросети Кохонена }
end;
 
 
 
 
 
 
 
 
 
 
 
 
 
procedure TForm1.FormCreate(Sender: TObject);
Var
   S:String;
begin
      SHOW_CONNECTIONS:=TRUE; {флаг разрешения отображения связей}
      Neurons:=10; { число нейронов в нейрополе }
      SpinEdit1.Value:=Neurons;
      SpinEdit2.MaxValue:=Neurons;
      SpinEdit2.Value:=5;
      R_ACTIV:=SpinEdit2.Value;
      Image2.Height:=Image1.Height;
      Image2.Width:=Image1.Width;
 
      { начальное задание коэффициента пластичности }
      ALPHA:=0.8;
      Str(ALPHA :6:4,S);
      Edit1.Text:=S;
 
      { начальное задание множителя коэффициента пластичности }
      KOEFF_ALPHA:=0.9;
      Str(KOEFF_ALPHA :6:4,S);
      Edit3.Text:=S;
 
      { начальное задание числа итераций }
      U:=2000;
      Edit2.Text:=IntToStr(U);
 
{ Значение шага модификации размера области активации и коэффициента пластичности}
      Step:=100;
      Edit4.Text:=IntToStr(Step);
 
      Button2Click(Self); { сразу нарисовать треугольник }
 
end;
 
procedure TForm1.Button2Click(Sender: TObject);
begin
     CLEAR_SCREEN; { ОЧИСТКА ЭКРАНА }
     Image1.Canvas.Pen.Color:=clBlack;
     Image2.Canvas.Pen.Color:=clBlack;
     Line(ROUND(Image1.Width/2),1,Image1.Width-2,Image1.Height-2);
     Line(Image1.Width-2,Image1.Height-2,2,Image1.Height-2);
     Line(2,Image1.Height-2,ROUND(Image1.Width/2),1);
     Image1.Canvas.Brush.Color:=clRed;
     Image2.Canvas.Brush.Color:=clRed;
     Image1.Canvas.FloodFill(ROUND(Image1.ClientWidth/2),ROUND(Image1.ClientHeight/2), clBlack, fsBorder);
     Image2.Canvas.FloodFill(ROUND(Image2.ClientWidth/2), ROUND(Image2.ClientHeight/2), clBlack, fsBorder);
end;
 
 
 
procedure TForm1.Button3Click(Sender: TObject);
Const
     L=50;
     R=100;
Var
   X,Y:integer;
begin
     { КВАДРАТ }
     CLEAR_SCREEN; { ОЧИСТКА ЭКРАНА }
     X:=ROUND(Image1.Width/2);
     Y:=ROUND(Image1.Height/2);
     Image1.Canvas.Pen.Color:=clBlack;
     Image2.Canvas.Pen.Color:=clBlack;
     Image1.Canvas.Brush.Color:=clRed;
     Image2.Canvas.Brush.Color:=clRed;
     Image1.Canvas.Rectangle(X-R, Y-R, X+R, Y+R);
     Image2.Canvas.Rectangle(X-R, Y-R, X+R, Y+R);
end;
 
procedure TForm1.Button4Click(Sender: TObject);
Const
     R=100; { величина смещения от центра для построения эллипса }
Var
   XEllipse,YEllipse:integer; {  координаты центра эллипса }
 
begin
     { КРУГ }
     CLEAR_SCREEN; { ОЧИСТКА ЭКРАНА }
     Image1.Canvas.Pen.Color:=clBlack;
     Image2.Canvas.Pen.Color:=clBlack;
 
     XEllipse:=ROUND(Image1.ClientWidth/2);
     YEllipse:=ROUND(Image1.ClientHeight/2);
 
     Image1.Canvas.Ellipse(XEllipse-R,YEllipse-R,XEllipse+R,YEllipse+R);
     Image2.Canvas.Ellipse(XEllipse-R,YEllipse-R,XEllipse+R,YEllipse+R);
 
     Image1.Canvas.Brush.Color:=clRed;
     Image2.Canvas.Brush.Color:=clRed;
 
     Image1.Canvas.FloodFill(ROUND(Image1.ClientWidth/2),ROUND(Image1.ClientHeight/2), clBlack, fsBorder);
     Image2.Canvas.FloodFill(ROUND(Image2.ClientWidth/2), ROUND(Image2.ClientHeight/2), clBlack, fsBorder);
end;
 
 
 
 
procedure TForm1.Button5Click(Sender: TObject);
Const
     R=100; { величина смещения от центра для построения эллипса }
Var
   XEllipse,YEllipse:integer; {  координаты центра эллипса }
   X,Y:integer;
begin
     { ПОЛУКРУГ }
     CLEAR_SCREEN; { ОЧИСТКА ЭКРАНА }
     Image1.Canvas.Pen.Color:=clBlack;
     Image2.Canvas.Pen.Color:=clBlack;
     XEllipse:=ROUND(Image1.ClientWidth/2);
     YEllipse:=ROUND(Image1.ClientHeight/2);
     Image1.Canvas.Ellipse(XEllipse-R,YEllipse-R,XEllipse+R,YEllipse+R);
     Image2.Canvas.Ellipse(XEllipse-R,YEllipse-R,XEllipse+R,YEllipse+R);
     Image1.Canvas.Brush.Color:=clRed;
     Image2.Canvas.Brush.Color:=clRed;
     Image1.Canvas.FloodFill(XEllipse,YEllipse, clBlack, fsBorder);
     Image2.Canvas.FloodFill(XEllipse,YEllipse, clBlack, fsBorder);
     Image1.Canvas.Pen.Color:=clNavy;
     Image2.Canvas.Pen.Color:=clNavy;
     Image1.Canvas.Brush.Color:=clNavy;
     Image2.Canvas.Brush.Color:=clNavy;
     Image1.Canvas.Rectangle(XEllipse-R, YEllipse-R, XEllipse, YEllipse+R);
     Image2.Canvas.Rectangle(XEllipse-R, YEllipse-R, XEllipse, YEllipse+R);
end;
 
procedure TForm1.Button6Click(Sender: TObject);
Const
     R=100; { величина смещения от центра для построения эллипса }
     R2=50; { внутренний эллипс }
Var
   XEllipse,YEllipse:integer; {  координаты центра эллипса }
 
begin
     { КОЛЬЦО }
     CLEAR_SCREEN; { ОЧИСТКА ЭКРАНА }
     Image1.Canvas.Pen.Color:=clBlack;
     Image2.Canvas.Pen.Color:=clBlack;
 
     XEllipse:=ROUND(Image1.ClientWidth/2);
     YEllipse:=ROUND(Image1.ClientHeight/2);
 
     Image1.Canvas.Ellipse(XEllipse-R,YEllipse-R,XEllipse+R,YEllipse+R);
     Image2.Canvas.Ellipse(XEllipse-R,YEllipse-R,XEllipse+R,YEllipse+R);
 
     Image1.Canvas.Brush.Color:=clRed;
     Image2.Canvas.Brush.Color:=clRed;
 
     Image1.Canvas.FloodFill(ROUND(Image1.ClientWidth/2),ROUND(Image1.ClientHeight/2), clBlack, fsBorder);
     Image2.Canvas.FloodFill(ROUND(Image2.ClientWidth/2), ROUND(Image2.ClientHeight/2), clBlack, fsBorder);
 
     Image1.Canvas.Ellipse(XEllipse-R2,YEllipse-R2,XEllipse+R2,YEllipse+R2);
     Image2.Canvas.Ellipse(XEllipse-R2,YEllipse-R2,XEllipse+R2,YEllipse+R2);
 
     Image1.Canvas.Brush.Color:=clNavy;
     Image2.Canvas.Brush.Color:=clNavy;
 
     Image1.Canvas.FloodFill(ROUND(Image1.ClientWidth/2),ROUND(Image1.ClientHeight/2), clBlack, fsBorder);
     Image2.Canvas.FloodFill(ROUND(Image2.ClientWidth/2), ROUND(Image2.ClientHeight/2), clBlack, fsBorder);
 
 
end;
 
 
procedure TForm1.Button7Click(Sender: TObject);
Const
     R=100; { величина смещения от центра для построения эллипса }
     R2=50;
Var
   XEllipse,YEllipse:integer; {  координаты центра эллипса }
   X,Y:integer;
begin
     { ПОЛУКОЛЬЦО }
     CLEAR_SCREEN; { ОЧИСТКА ЭКРАНА }
     Image1.Canvas.Pen.Color:=clBlack;
     Image2.Canvas.Pen.Color:=clBlack;
     XEllipse:=ROUND(Image1.ClientWidth/2);
     YEllipse:=ROUND(Image1.ClientHeight/2);
     Image1.Canvas.Ellipse(XEllipse-R,YEllipse-R,XEllipse+R,YEllipse+R);
     Image2.Canvas.Ellipse(XEllipse-R,YEllipse-R,XEllipse+R,YEllipse+R);
     Image1.Canvas.Brush.Color:=clRed;
     Image2.Canvas.Brush.Color:=clRed;
     Image1.Canvas.FloodFill(XEllipse,YEllipse, clBlack, fsBorder);
     Image2.Canvas.FloodFill(XEllipse,YEllipse, clBlack, fsBorder);
 
     Image1.Canvas.Ellipse(XEllipse-R2,YEllipse-R2,XEllipse+R2,YEllipse+R2);
     Image2.Canvas.Ellipse(XEllipse-R2,YEllipse-R2,XEllipse+R2,YEllipse+R2);
 
     Image1.Canvas.Brush.Color:=clNavy;
     Image2.Canvas.Brush.Color:=clNavy;
 
     Image1.Canvas.FloodFill(ROUND(Image1.ClientWidth/2),ROUND(Image1.ClientHeight/2), clBlack, fsBorder);
     Image2.Canvas.FloodFill(ROUND(Image2.ClientWidth/2), ROUND(Image2.ClientHeight/2), clBlack, fsBorder);
 
 
     Image1.Canvas.Pen.Color:=clNavy;
     Image2.Canvas.Pen.Color:=clNavy;
     Image1.Canvas.Rectangle(XEllipse-R, YEllipse-R, XEllipse, YEllipse+R);
     Image2.Canvas.Rectangle(XEllipse-R, YEllipse-R, XEllipse, YEllipse+R);
end;
 
procedure TForm1.SpinEdit1Change(Sender: TObject);
begin  { установить число нейронов в сети }
     Neurons:=SpinEdit1.Value;
end;
 
 
procedure TForm1.Edit1Change(Sender: TObject);
var
  I, Code: Integer;
  R:Real;
begin
  { Получить данные из редактируемого поля }
  Val(Edit1.Text, R, Code);
  { Проверить на допустимое представление данных }
  if code = 0 then ALPHA:=R       { ошибки нет }
  else
    MessageDlg('Ошибка в позиции: ' + IntToStr(Code), mtWarning, [mbOk], 0);
end;
 
 
procedure TForm1.Edit2Change(Sender: TObject);
Var
   I,Code:integer;
begin
  { Получить данные из редактируемого поля }
  Val(Edit2.Text, i, Code);
  { Проверить на допустимое представление данных }
  if (code = 0)And((i>0)And(i<=MaxInt)) then U:=i       { ошибки нет }
  else
    MessageDlg('Ошибка в позиции: ' + IntToStr(Code), mtWarning, [mbOk], 0);
 
end;
 
 
procedure TForm1.Edit3Change(Sender: TObject);
var
  Code: Integer;
  R:Real;
begin
  { Получить данные из редактируемого поля }
  Val(Edit3.Text, R, Code);
  { Проверить на допустимое представление данных }
  if code = 0 then KOEFF_ALPHA:=R       { ошибки нет }
  else
    MessageDlg('Ошибка в позиции: ' + IntToStr(Code), mtWarning, [mbOk], 0);
end;
 
 
 
 
procedure TForm1.Edit4Change(Sender: TObject);
Var
   I,Code:integer;
begin
  { Получить данные из редактируемого поля }
  Val(Edit4.Text, i, Code);
  { Проверить на допустимое представление данных }
  if (code = 0)And((i>0)And(i<=MaxInt)) then Step:=i       { ошибки нет }
  else
    MessageDlg('Ошибка в позиции: ' + IntToStr(Code), mtWarning, [mbOk], 0);
 
end;
 
 
 
end.

Одним словом это карты Кохонена
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.02.2013, 16:50
Ответы с готовыми решениями:

Переписать код с делфи на Java
Доброе время суток, переведите, пожалуйста код с делфи на Java. С меня плюшки(если интересно какие - в личку)

перевести из Делфи в Java задача
Помогите перевести из Делфи в Java SE, пожалуйста) var Form1: TForm1; implementation {$R *.dfm} procedure...

перевести программу из делфи в java
Есть задача: Определить сумму первых трех цифр дробной части заданного положительного вещественного числа/ Нашёл её решение в Делфи ses...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.02.2013, 16:50
Помогаю со студенческими работами здесь

Как в Делфи выполнить код, написанный на Делфи, например в поле ввода?
Есть способ в Делфи выполнить код, написанный на Делфи, например в поле ввода?

У меня стоит Делфи 5, возможно еще поставить и Делфи 7, или будут проблемы?!
Где можно скачать Делфи 7, дайте ссылку! У меня стоит Делфи 5, возможно еще поставить и Делфи 7, или будут проблемы?!

Здр, пожалуйста попробуйте запутсить .exe написанное на делфи 10 у себя, те у кого делфи 7
и скиньте скрин пожалуйста срочно http://www.fayloobmennik.net/4874373 перед тес как запустить, создайте файлы: 1.txt, 2.txt и key.txt...

Как открыть doc в делфи? Или как можно написать огромный текст в делфи?
Думаю поймете. Я решил сделать сборник книг. И в Delphi добавил список книг (в виде кнопок) и при выборе я бы хотел открыть форму где был...

Exception in thread "main" java.lang.IllegalArgumentException: illegal component position at java.desktop/java.awt.Cont
import javax.swing.*; import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; public class...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru