Global Search optimization error
3 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
I am trying to run a global search optimization in order to minimize a function. When I run it, I receive the following error:
Warning: Matrix is singular, close to
singular or badly scaled. Results may
be inaccurate. RCOND = NaN.
> In qpsub>eqnsolv at 953
In qpsub at 157
In nlconst at 619
In fmincon at 837
In C:\Program Files\MATLAB\R2012b\toolbox\globaloptim\globaloptim\private\globalsearchnlp.p>i_runLocalSolver at 684
In C:\Program Files\MATLAB\R2012b\toolbox\globaloptim\globaloptim\private\globalsearchnlp.p>globalsearchnlp at 292
In GlobalSearch>GlobalSearch.run at 327
In opt_model_ms at 52
Do you have any idea why is this happening? My function is well defined. On the other hand it has 6 variables, which could be difficult for global search to find the minimum. I could also post the function here if you need more information?
Risposta accettata
Giorgos Papakonstantinou
il 23 Gen 2013
Modificato: Giorgos Papakonstantinou
il 27 Gen 2013
1 Commento
Alan Weiss
il 23 Gen 2013
Perhaps your line
Aeq(2,6)=zeros;
should be
Aeq = zeros(2,6);
Also, I notice that you are integrating a function symbolically inside your function, then converting the answer to numeric. This is bound to be slow. It would probably be better to get a symbolic expression for the integral (if one exists) and use matlabFunction to give you a function handle or file for numeric computation. If there is no closed form symbolic expression for the integral, then I recommend you use a numeric integrator in MATLAB such as integral or quadgk.
Good luck,
Alan Weiss
MATLAB mathematical toolbox documentation
Più risposte (3)
Giorgos Papakonstantinou
il 23 Gen 2013
Modificato: Giorgos Papakonstantinou
il 3 Feb 2013
0 Commenti
Alan Weiss
il 23 Gen 2013
The warning indicates that you are using the fmincon active-set algorithm. The first thing I would try is to use the interior-point algorithm. Then the sqp algorithm. See the documentation for details.
opts = optimset('Algorithm','interior-point');
problem = createOptimProblem('fmincon','options',opts);
Obviously, you will have other things in your problem structure, I just wanted to show you how to include the options to change the algorithm.
Alan Weiss
MATLAB mathematical toolbox documentation
0 Commenti
Giorgos Papakonstantinou
il 23 Gen 2013
2 Commenti
Matt J
il 23 Gen 2013
Either could be the case, but there is no reason to doubt the solution just because it lies at the boundaries.
Alan Weiss
il 24 Gen 2013
You could also try some of the suggestions in the documentation for how to check whether your answer is indeed an optimum.
If you feel that I have sufficiently answered your questions, please accept the appropriate answer.
Alan Weiss
MATLAB mathematical toolbox documentation
Vedere anche
Categorie
Scopri di più su Linear Least Squares in Help Center e File Exchange
Prodotti
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!