-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathinitialize.c
74 lines (69 loc) · 1.35 KB
/
initialize.c
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
/* Data initializtion routines */
# include <stdio.h>
# include <stdlib.h>
# include <math.h>
# include "global.h"
# include "rand.h"
/* Function to initialize a population randomly */
void reset_pop_obj (population *pop, int size)
{
int i;
for (i=0; i<size; i++)
{
reset_ind_obj (&(pop->ind[i]));
}
return;
}
/* Function to initialize a population randomly */
void reset_ind_obj (individual *ind)
{
int i;
if (nobj==3)
{
for (i=0; i<nobj; i++)
{
ind->obj[i]=0.0;
}
}
return;
}
/* Function to initialize a population randomly */
void initialize_pop (population *pop)
{
int i;
for (i=0; i<popsize; i++)
{
initialize_ind (&(pop->ind[i]));
}
return;
}
/* Function to initialize an individual randomly */
void initialize_ind (individual *ind)
{
int j, k;
if (nreal!=0)
{
for (j=0; j<nreal; j++)
{
ind->xreal[j] = rndreal (min_realvar[j], max_realvar[j]);
}
}
if (nbin!=0)
{
for (j=0; j<nbin; j++)
{
for (k=0; k<nbits[j]; k++)
{
if (randomperc() <= 0.5)
{
ind->gene[j][k] = 0;
}
else
{
ind->gene[j][k] = 1;
}
}
}
}
return;
}