12
extern double boom_factor;
14
#define MIN_RDS 0.05 /* Minimum reflector-driven spacing in lambda */
16
void randomise(int randomisation_method, double frequency, double max_percent, double **driven_data, double**parasitic_data, int driven, int parasites)
19
static int run_first_time=0;
20
double y, old_boom_length, new_boom_length, a, lambda,**z,l,x,taper;
21
static double max_boom_length;
25
max_boom_length=(1+boom_factor/100)*parasitic_data[parasites][X];
28
if ((randomisation_method & DRIVEN_LENGTH) == DRIVEN_LENGTH) /* 1 */
30
for(i=1;i<=driven; ++i) /* randomise the driven */
32
y=1+0.02*max_percent*(randreal()-0.5);
33
driven_data[i][LENGTH]*=y;
36
if ((randomisation_method & DRIVEN_POSITION) == DRIVEN_POSITION) /* 2 */
38
for(i=1;i<=driven; ++i) /* randomise the driven position */
40
y=1+0.02*max_percent*(randreal()-0.5);
44
if ((randomisation_method & REFLECTOR_LENGTH) == REFLECTOR_LENGTH) /* 4 */
47
/* reflector position stays at x=0 */
48
y=1+0.02*max_percent*(randreal()-0.5);
49
parasitic_data[1][LENGTH]*=y;
52
if ((randomisation_method & DIRECTOR_LENGTH) == DIRECTOR_LENGTH) /* 8 */
54
for(i=2; i<=parasites; ++i)
56
y=1+0.02*max_percent*(randreal()-0.5);
57
parasitic_data[i][LENGTH]*=y;
58
/* make sure directors dont get longer down the boom */
59
if((parasitic_data[i][LENGTH]>parasitic_data[i-1][LENGTH]) && (i>2))
60
parasitic_data[i][LENGTH]=parasitic_data[i-1][LENGTH];
64
if ((randomisation_method & DIRECTOR_POSITION) == DIRECTOR_POSITION) /* 16 */
66
old_boom_length=parasitic_data[parasites][X];
67
y=1+0.02*max_percent*(randreal()-0.5);
68
new_boom_length=old_boom_length*y;
69
if(new_boom_length > max_boom_length)
70
new_boom_length=max_boom_length;
71
/* rearrange directors */
72
for(i=2; i<=parasites; ++i)
74
y=1+0.02*max_percent*(randreal()-0.5);
75
parasitic_data[i][X]*=y*(new_boom_length/old_boom_length);
78
if ((randomisation_method & ALL_ELEMENT_LENGTHS_IDENTICAL)==ALL_ELEMENT_LENGTHS_IDENTICAL) /* 32 */
80
y=1+0.02*max_percent*(randreal()-0.5);
81
for(i=1; i<=driven; ++i)
82
driven_data[i][LENGTH]*=y;
83
for(i=1; i<=parasites; ++i)
84
parasitic_data[i][LENGTH]=driven_data[1][LENGTH];
86
if ((randomisation_method & LINEAR_TAPER)==LINEAR_TAPER) /* 64 */
88
a=1+(0.1*randreal()); /* 1.00 to 1.1 */
89
taper=(a-1)/driven_data[1][X];
90
parasitic_data[1][LENGTH]=a*driven_data[1][3]; /* reflector = a*driven */
91
for(i=2; i<=parasites; ++i)
92
parasitic_data[i][LENGTH]=parasitic_data[1][3]-taper*(parasitic_data[i][X]-driven_data[1][X]);
95
if ((randomisation_method & RESONATE_DRIVEN)==RESONATE_DRIVEN) /* 128 */
99
elements=driven+parasites;
100
z=dmatrix(1L,(long)elements,2L,2L*(long)elements);
104
driven_data[1][LENGTH]=l;
105
self_impedance(1, frequency*1e6,driven,parasites,driven_data,z);
107
driven_data[1][LENGTH]=l;
110
printf("Driven element set to :l=%f m = %f wavlengths\n",l,l/lambda);
111
free_dmatrix(z,1L,elements,1L,2L*elements);
117
fprintf(stderr,"Errno =%d in randomis.c\n", errno);