Skip to content

Conversation

@DimitriAlston
Copy link
Member

No description provided.

JuMP.optimize!(model)

@test isapprox(JuMP.value(x), 0.000297, atol=1E-6)
@test isapprox(JuMP.value(y), 0.000297, atol=1E-6)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This test doesn't seem to require constraint propagation. Passing it to my version of EAGO without constraint propagation, the problem still solves. I see the value of constraint propagation here as eliminating the negative portion of the domain from x (due to sqrt) and then reducing the positive portion of the domains of x and y to satisfy the constraint. But, since x is only non-negative in this problem, we don't see the benefit of propagating the sqrt, and while shrinking the positive part of the domain helps, it's not required to obtain a solution since Ipopt returns a good solution regardless of the size of the (non-negative) domain.

I'd recommend changing x from non-negative to unbounded (@variable(model, x)). If you pass the problem with an unbounded x to Ipopt, you get a numerical error, which is why EAGO keeps iterating with an upper bound of Inf in this case. Constraint propagation would eliminate this and the problem should solve instantly.

Also, I wouldn't check these particular values as the solution to verify that the problem is working. By inspection, the solution to the problem is (x, y) = (0, 0). Though, depending on your convergence tolerance, you might get higher values. E.g., if your absolute tolerance for convergence is 1E-6, either x or y could be as high as 1E-3 and you'd still be within tolerance of the correct objective function value of 0 (since any x and y satisfying x^2 + y^2 <= 1E-6 is "correct"). I suppose you could check that x and y are both within [0, 1E-3], if your tolerance is 1E-6.

JuMP.optimize!(model)

@test isapprox(JuMP.value(x), 0.00567, atol=1E-3)
@test isapprox(JuMP.value(y), 1.4943, atol=1E-3)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This example solves without constraint propagation. Might be better to create a problem that solves in 1 iteration with constraint propagation and more iterations without, and then @test for the required number of iterations?

@constraint(model, acos(x) <= 1)
JuMP.optimize!(model)

@test 0.540302 <= JuMP.value(x) <= 1.0
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same comment as previous, this example solves without constraint propagation.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

EAGO times out out trivial problem @NLconstraint(model, x^1.852 <= 1) not infeasible over |R

3 participants