Error in the codes. Please help
8 views (last 30 days)
Show older comments
Error: File: Fitnessfunc_g.m Line: 17 Column: 1
This statement is not inside any function.
(It follows the END that terminates the definition of the function
"Fitnessfunc_g".)
Error in createAnonymousFcn>@(x)fcn(x,FcnArgs{:}) (line 11)
fcn_handle = @(x) fcn(x,FcnArgs{:});
Error in makeState (line 48)
firstMemberScore =
FitnessFcn(state.Population(initScoreProvided+1,:));
Error in galincon (line 18)
state =
makeState(GenomeLength,FitnessFcn,Iterate,output.problemtype,options);
Error in ga (line 351)
[x,fval,exitFlag,output,population,scores] =
galincon(FitnessFcn,nvars, ...
Error in GAgear (line 12)
[x,fval,exitflag,output]= ga(ObjectiveFunction,nvars,[],[],LB,UB);
Caused by:
Failure in initial user-supplied fitness function evaluation. GA
cannot continue.
The codes wriiten are as follows
We=(3.14*rho)*{x*m^2*z1*(1+a^2)-(D1^2-d0^2)*(l-bw)-n*dp^2*bw-(d1^2+d2^2)*x}/4000;\\objective function
function GAgear
clc
D=Data_g;
nvars=1;
LB=20;
UB=40;
ObjectiveFunction=@Fitnessfunc_g;
%ConstraintFunction=@Constraintfunc;
options=gaoptimset('StallGenLimit',4,'PopulationSize',10);
disp('Optimization in progress.....');
% Run GA
[x,fval,exitflag,output]= ga(ObjectiveFunction,nvars,[],[],LB,UB);
% Display optimization results
disp('Optimization results:')
fprintf('Weight of best solution is: %6.8g\n',fval)
%fprintf('Number of function evaluations: %d\n',Z)
disp('Best solution:')
disp(x')
6 Comments
Walter Roberson
on 1 Oct 2015
I was mistaken about the problem possibly being options not being a structure.
I do not know what the problem is.
Answers (3)
Aliyu Bagudu
on 5 Apr 2016
I had the same problem however, I was able figure out where the problem actually comes from. The problem comes from the formula GA uses to calculate the number children of the next generation and thus the number of selected parents. There are 3 types of children in GA: Elite children(specified by EliteCount), Crossover children(specified by crossoverFraction) and calculated as crossoverFraction*(populationSize - EliteCount), and mutation children (calculated using populationSize - EliteCount - crossover children). You don't specify number of mutation children, it is calculated.
So the problem comes from rounding when calculation crossover fraction. The rounding is done to the nearest integer. So for some combination of populationSize, crossoverFraction, and EiltCount, this can result in total number of children that is not equal to populationSize.
Number of parents is 2 times number of children for crossover children. For mutation number of parents is equal to number of children.
So do your calculations and make sure populationSize stay fixed.
0 Comments
Jan
on 1 Oct 2015
Edited: Jan
on 1 Oct 2015
The command ga: input argument LB expects the 7.th input argument to be a double vector. But in your case it is a struct.
0 Comments
See Also
Categories
Find more on Genetic Algorithm in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!