Drexel dragonThe Math ForumDonate to the Math Forum



Search All of the Math Forum:

Views expressed in these public forums are not endorsed by Drexel University or The Math Forum.


Math Forum » Discussions » Software » comp.soft-sys.math.mathematica

Topic: Unable to generate any initial points with NMaximize (or NMinimize)
Replies: 2   Last Post: Jun 19, 2013 1:19 AM

Advanced Search

Back to Topic List Back to Topic List Jump to Tree View Jump to Tree View   Messages: [ Previous | Next ]
Meike

Posts: 4
Registered: 10/16/12
Re: Unable to generate any initial points with NMaximize (or NMinimize)
Posted: Jun 19, 2013 1:19 AM
  Click to see the message monospaced in plain text Plain Text   Click to reply to this topic Reply


Thanks for your response. I think mathematica automatically converts > to >= in constraints. But even if I do that and use something like 0.00001 instead of $MachineEpsilon I get the same errors... I guess it's too hard for Mathematica to find the initial values and I have to specify them, but I shouldn't be that hard.

On Sunday, June 9, 2013 10:26:21 AM UTC+2, Dana DeLouis wrote:
> Hello. It appears you don't have a response, so I'll give it a try.
>
>
>

> > a > $MachineEpsilon
>
>
>
> When you have a constraint such as this, you are saying that a solution of 4.440892*10^-16
>
> is not really zero, and a valid solution.
>
>
>
> 2*$MachineEpsilon//N
>
> 4.440892*10^-16
>
>
>
>
>
> For optimization problems, using ">" is usually a problem because of limits. I believe one should use ">=" for constraints.
>
>
>
> If 'a was found to be around 0.000001, the program has to retry with a number smaller than this, yet greater than MachineEpsilon. The next try might be at 0.0000001, etc. There's not really a number smaller than MachineEpsilon (at machine precision of course) so what is the software to do?
>
>
>
> Try using ">="
>
>
>
> equ=1/(0.` +(0.012710615354858255` ... etc //FullSimplify;
>
>
>
> const={a>=0,b>=0,fm>=0,c>=0,p>=0,
>
> fm<=5,0.00009600189408524172` (5-fm)-40.451710009005595` b fm>=0};
>
>
>
>
>
> {val,sol}=NMaximize[{equ,const},{a,b,fm,c,p},MaxIterations->1000]
>
>
>
>
>
> However, I don't believe this problem has a solution as given. :>~
>
>
>
>
>
>
>
> = = = = = = = = = =
>
>
>
> HTH :>)
>
>
>
> Dana DeLouis
>
>
>
> Mac & Mathematica 9
>
>
>
> = = = = = = = = = =
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
> On Thursday, May 23, 2013 3:16:08 AM UTC-4, Meike wrote:
>
>
>

> > I often get the error:
>
>
>

> >
>
>
>

> > NMaximize::incst: NMaximize was unable to generate any initial points satisfying the inequality constraints
>
>
>

> > while there are clearly points satisfying the inequality constraints. For example:
>
>
>

> > NMaximize[{1/(0.` + (0.012710615354858255` (0.07879657698200958` +
>
>
>

> > a) (0.000046296899009293725` +
>
>
>

> > 0.003958158898356454` b) (233.02777267494722` +
>
>
>

> > 102.02996575509754` fm))/(a (4.892449413727213`*^-6 -
>
>
>

> > 9.784898827454427`*^-7 fm - 0.4123000838756304` b fm)) + (
>
>
>

> > 0.10155110608580004` (0.0367973376747971` +
>
>
>

> > c) (0.5030193912642286` + 16.257272679476753` b +
>
>
>

> > 0.0309411917473244` p))/b + (
>
>
>

> > 219.22680202984347` (0.03970570642848887` +
>
>
>

> > 0.013422101464134875` fm) (0.07972967880969935` +
>
>
>

> > 0.14421246041749264` p))/(fm p)), a > $MachineEpsilon,
>
>
>

> > b > $MachineEpsilon, fm > $MachineEpsilon, c > $MachineEpsilon,
>
>
>

> > p > $MachineEpsilon,
>
>
>

> >
>
>
>

> > 0.00009600189408524172` (5 - fm) -
>
>
>

> >
>
>
>

> > 40.451710009005595` b fm > $MachineEpsilon, fm < 5.`}, {a, b, fm,
>
>
>

> >
>
>
>

> > c, p}, MaxIterations -> 1000]
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > NMaximize::incst: NMaximize was unable to generate any initial points satisfying the inequality constraints {-0.000480009+0.0000960019 fm+40.4517 b fm<0}. The initial region specified may not contain any feasible points. Changing the initial region or specifying explicit initial points may provide a better solution. >>
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > Clearly there are initial points, for example:
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > 0.00009600189408524172` (5 - fm) -
>
>
>

> >
>
>
>

> > 40.451710009005595` b fm > $MachineEpsilon /. {b -> 0.0007,
>
>
>

> >
>
>
>

> > fm -> 0.00003}
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > True
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > Also, if I make a more simple example with the same constraint I do not get the same error. I know I could give initial values myself, but since I'm automatically generating many of the optimizations, I would prefer not to. And I would like to understand why I keep getting this error and if there is any way to solve it.



On Sunday, June 9, 2013 10:26:21 AM UTC+2, Dana DeLouis wrote:
> Hello. It appears you don't have a response, so I'll give it a try.
>
>
>

> > a > $MachineEpsilon
>
>
>
> When you have a constraint such as this, you are saying that a solution of 4.440892*10^-16
>
> is not really zero, and a valid solution.
>
>
>
> 2*$MachineEpsilon//N
>
> 4.440892*10^-16
>
>
>
>
>
> For optimization problems, using ">" is usually a problem because of limits. I believe one should use ">=" for constraints.
>
>
>
> If 'a was found to be around 0.000001, the program has to retry with a number smaller than this, yet greater than MachineEpsilon. The next try might be at 0.0000001, etc. There's not really a number smaller than MachineEpsilon (at machine precision of course) so what is the software to do?
>
>
>
> Try using ">="
>
>
>
> equ=1/(0.` +(0.012710615354858255` ... etc //FullSimplify;
>
>
>
> const={a>=0,b>=0,fm>=0,c>=0,p>=0,
>
> fm<=5,0.00009600189408524172` (5-fm)-40.451710009005595` b fm>=0};
>
>
>
>
>
> {val,sol}=NMaximize[{equ,const},{a,b,fm,c,p},MaxIterations->1000]
>
>
>
>
>
> However, I don't believe this problem has a solution as given. :>~
>
>
>
>
>
>
>
> = = = = = = = = = =
>
>
>
> HTH :>)
>
>
>
> Dana DeLouis
>
>
>
> Mac & Mathematica 9
>
>
>
> = = = = = = = = = =
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
> On Thursday, May 23, 2013 3:16:08 AM UTC-4, Meike wrote:
>
>
>

> > I often get the error:
>
>
>

> >
>
>
>

> > NMaximize::incst: NMaximize was unable to generate any initial points satisfying the inequality constraints
>
>
>

> > while there are clearly points satisfying the inequality constraints. For example:
>
>
>

> > NMaximize[{1/(0.` + (0.012710615354858255` (0.07879657698200958` +
>
>
>

> > a) (0.000046296899009293725` +
>
>
>

> > 0.003958158898356454` b) (233.02777267494722` +
>
>
>

> > 102.02996575509754` fm))/(a (4.892449413727213`*^-6 -
>
>
>

> > 9.784898827454427`*^-7 fm - 0.4123000838756304` b fm)) + (
>
>
>

> > 0.10155110608580004` (0.0367973376747971` +
>
>
>

> > c) (0.5030193912642286` + 16.257272679476753` b +
>
>
>

> > 0.0309411917473244` p))/b + (
>
>
>

> > 219.22680202984347` (0.03970570642848887` +
>
>
>

> > 0.013422101464134875` fm) (0.07972967880969935` +
>
>
>

> > 0.14421246041749264` p))/(fm p)), a > $MachineEpsilon,
>
>
>

> > b > $MachineEpsilon, fm > $MachineEpsilon, c > $MachineEpsilon,
>
>
>

> > p > $MachineEpsilon,
>
>
>

> >
>
>
>

> > 0.00009600189408524172` (5 - fm) -
>
>
>

> >
>
>
>

> > 40.451710009005595` b fm > $MachineEpsilon, fm < 5.`}, {a, b, fm,
>
>
>

> >
>
>
>

> > c, p}, MaxIterations -> 1000]
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > NMaximize::incst: NMaximize was unable to generate any initial points satisfying the inequality constraints {-0.000480009+0.0000960019 fm+40.4517 b fm<0}. The initial region specified may not contain any feasible points. Changing the initial region or specifying explicit initial points may provide a better solution. >>
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > Clearly there are initial points, for example:
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > 0.00009600189408524172` (5 - fm) -
>
>
>

> >
>
>
>

> > 40.451710009005595` b fm > $MachineEpsilon /. {b -> 0.0007,
>
>
>

> >
>
>
>

> > fm -> 0.00003}
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > True
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > Also, if I make a more simple example with the same constraint I do not get the same error. I know I could give initial values myself, but since I'm automatically generating many of the optimizations, I would prefer not to. And I would like to understand why I keep getting this error and if there is any way to solve it.



On Sunday, June 9, 2013 10:26:21 AM UTC+2, Dana DeLouis wrote:
> Hello. It appears you don't have a response, so I'll give it a try.
>
>
>

> > a > $MachineEpsilon
>
>
>
> When you have a constraint such as this, you are saying that a solution of 4.440892*10^-16
>
> is not really zero, and a valid solution.
>
>
>
> 2*$MachineEpsilon//N
>
> 4.440892*10^-16
>
>
>
>
>
> For optimization problems, using ">" is usually a problem because of limits. I believe one should use ">=" for constraints.
>
>
>
> If 'a was found to be around 0.000001, the program has to retry with a number smaller than this, yet greater than MachineEpsilon. The next try might be at 0.0000001, etc. There's not really a number smaller than MachineEpsilon (at machine precision of course) so what is the software to do?
>
>
>
> Try using ">="
>
>
>
> equ=1/(0.` +(0.012710615354858255` ... etc //FullSimplify;
>
>
>
> const={a>=0,b>=0,fm>=0,c>=0,p>=0,
>
> fm<=5,0.00009600189408524172` (5-fm)-40.451710009005595` b fm>=0};
>
>
>
>
>
> {val,sol}=NMaximize[{equ,const},{a,b,fm,c,p},MaxIterations->1000]
>
>
>
>
>
> However, I don't believe this problem has a solution as given. :>~
>
>
>
>
>
>
>
> = = = = = = = = = =
>
>
>
> HTH :>)
>
>
>
> Dana DeLouis
>
>
>
> Mac & Mathematica 9
>
>
>
> = = = = = = = = = =
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
> On Thursday, May 23, 2013 3:16:08 AM UTC-4, Meike wrote:
>
>
>

> > I often get the error:
>
>
>

> >
>
>
>

> > NMaximize::incst: NMaximize was unable to generate any initial points satisfying the inequality constraints
>
>
>

> > while there are clearly points satisfying the inequality constraints. For example:
>
>
>

> > NMaximize[{1/(0.` + (0.012710615354858255` (0.07879657698200958` +
>
>
>

> > a) (0.000046296899009293725` +
>
>
>

> > 0.003958158898356454` b) (233.02777267494722` +
>
>
>

> > 102.02996575509754` fm))/(a (4.892449413727213`*^-6 -
>
>
>

> > 9.784898827454427`*^-7 fm - 0.4123000838756304` b fm)) + (
>
>
>

> > 0.10155110608580004` (0.0367973376747971` +
>
>
>

> > c) (0.5030193912642286` + 16.257272679476753` b +
>
>
>

> > 0.0309411917473244` p))/b + (
>
>
>

> > 219.22680202984347` (0.03970570642848887` +
>
>
>

> > 0.013422101464134875` fm) (0.07972967880969935` +
>
>
>

> > 0.14421246041749264` p))/(fm p)), a > $MachineEpsilon,
>
>
>

> > b > $MachineEpsilon, fm > $MachineEpsilon, c > $MachineEpsilon,
>
>
>

> > p > $MachineEpsilon,
>
>
>

> >
>
>
>

> > 0.00009600189408524172` (5 - fm) -
>
>
>

> >
>
>
>

> > 40.451710009005595` b fm > $MachineEpsilon, fm < 5.`}, {a, b, fm,
>
>
>

> >
>
>
>

> > c, p}, MaxIterations -> 1000]
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > NMaximize::incst: NMaximize was unable to generate any initial points satisfying the inequality constraints {-0.000480009+0.0000960019 fm+40.4517 b fm<0}. The initial region specified may not contain any feasible points. Changing the initial region or specifying explicit initial points may provide a better solution. >>
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > Clearly there are initial points, for example:
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > 0.00009600189408524172` (5 - fm) -
>
>
>

> >
>
>
>

> > 40.451710009005595` b fm > $MachineEpsilon /. {b -> 0.0007,
>
>
>

> >
>
>
>

> > fm -> 0.00003}
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > True
>
>
>

> >
>
>
>

> >
>
>
>

> >
>
>
>

> > Also, if I make a more simple example with the same constraint I do not get the same error. I know I could give initial values myself, but since I'm automatically generating many of the optimizations, I would prefer not to. And I would like to understand why I keep getting this error and if there is any way to solve it.





Point your RSS reader here for a feed of the latest messages in this topic.

[Privacy Policy] [Terms of Use]

© Drexel University 1994-2014. All Rights Reserved.
The Math Forum is a research and educational enterprise of the Drexel University School of Education.