-
Notifications
You must be signed in to change notification settings - Fork 0
/
Kromozom.cs
66 lines (54 loc) · 1.67 KB
/
Kromozom.cs
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace GenetikAlgoritmaOdev
{
public class Kromozom
{
public double gx1=-1.5, gx2=-3, hx=4;
public double genDeger1,genDeger2;
Random rnd = new Random();
double fx;
public double[] gen;
public Kromozom()
{
}
public Kromozom(double genDeger1,double genDeger2,double gx1, double gx2, double hx)
{
this.genDeger1 = genDeger1;
this.genDeger2 = genDeger2;
this.gx1 = gx1;
this.gx2 = gx2;
this.hx = hx;
}
public Kromozom(double gx1, double gx2,double hx)
{
this.gx1 = gx1;
this.gx2 = gx2;
this.hx = hx;
}
public Kromozom(double genDeger1,double genDeger2)
{
this.genDeger1 = genDeger1;
this.genDeger2 = genDeger2;
}
public Kromozom KromozomUret()
{
return (new Kromozom());
}
public Kromozom Fonksiyon(Kromozom kr1)
{
genDeger1 = rnd.Next(Convert.ToInt32(gx1), Convert.ToInt32(hx));
genDeger2 = rnd.Next(Convert.ToInt32(gx2), Convert.ToInt32(hx));
kr1.fx = Math.Sin(genDeger1 + genDeger2) - (genDeger1 * 2) - 1.5 * genDeger1 + 2.5 * genDeger2 + 1;
return kr1;
}
public double YeniDegerUret()
{
genDeger1 = rnd.Next(Convert.ToInt32(gx1), Convert.ToInt32(hx));
return genDeger1;
}
}
}