<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Non-linear constraint in Mathematical Optimization, Discrete-Event Simulation, and OR</title>
    <link>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126462#M696</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;No, (x1+x2) / (y1+y2) = 2 is not a linear equation and in fact it is not exactly equivalent to the linear equation x1+x2 = 2*(y1+y2) since the latter allows the solution (0,0,0,0).&amp;nbsp; When you linearize constraints of this form (and even more so for inequalities), you have to be careful about the sign of the denominator.&amp;nbsp; For example, (x1+x2) / (y1+y2) &amp;gt;= 2 is equivalent to x1+x2 &amp;gt;= 2*(y1+y2) if and only if y1+y2 &amp;gt; 0.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Fri, 25 May 2012 14:40:30 GMT</pubDate>
    <dc:creator>RobPratt</dc:creator>
    <dc:date>2012-05-25T14:40:30Z</dc:date>
    <item>
      <title>Non-linear constraint</title>
      <link>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126459#M693</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;When I write an equation in the form:&lt;/P&gt;&lt;P&gt;(x1+x2)/(y1+y2)=2 (where x(i), y(i) are decision variables)&lt;/P&gt;&lt;P&gt;SAS-OR considers the equation as a non-linear constraint.&lt;/P&gt;&lt;P&gt;However when I re-write the same equation in the form:&lt;/P&gt;&lt;P&gt;x1+x2=2*(y1+y2), SAS-OR considers it as a linear constraint.&lt;/P&gt;&lt;P&gt;Can somebody please help?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 25 May 2012 07:47:46 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126459#M693</guid>
      <dc:creator>Abhik</dc:creator>
      <dc:date>2012-05-25T07:47:46Z</dc:date>
    </item>
    <item>
      <title>Re: Non-linear constraint</title>
      <link>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126460#M694</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;There is no auto linearization in SAS/OR yet. We do have plans to do some auto linearization in the future.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Are you using OPTMODEL or PROC NLP?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 25 May 2012 14:15:17 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126460#M694</guid>
      <dc:creator>YanXu</dc:creator>
      <dc:date>2012-05-25T14:15:17Z</dc:date>
    </item>
    <item>
      <title>Re: Non-linear constraint</title>
      <link>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126461#M695</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I am using OPTMODEL. I am not very sure about what you mean by 'auto-linearization'. But (x1+x2)/(y1+y2)=2 is a linear equation, and if SAS considers this as a non-linear one, then it's wrong.&amp;nbsp; &lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 25 May 2012 14:22:24 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126461#M695</guid>
      <dc:creator>Abhik</dc:creator>
      <dc:date>2012-05-25T14:22:24Z</dc:date>
    </item>
    <item>
      <title>Re: Non-linear constraint</title>
      <link>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126462#M696</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;No, (x1+x2) / (y1+y2) = 2 is not a linear equation and in fact it is not exactly equivalent to the linear equation x1+x2 = 2*(y1+y2) since the latter allows the solution (0,0,0,0).&amp;nbsp; When you linearize constraints of this form (and even more so for inequalities), you have to be careful about the sign of the denominator.&amp;nbsp; For example, (x1+x2) / (y1+y2) &amp;gt;= 2 is equivalent to x1+x2 &amp;gt;= 2*(y1+y2) if and only if y1+y2 &amp;gt; 0.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 25 May 2012 14:40:30 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126462#M696</guid>
      <dc:creator>RobPratt</dc:creator>
      <dc:date>2012-05-25T14:40:30Z</dc:date>
    </item>
    <item>
      <title>Re: Non-linear constraint</title>
      <link>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126463#M697</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Linearization is technique to transfer nonlinear items to linear items.&lt;/P&gt;&lt;P&gt;Rob is right,&amp;nbsp; (x1+x2) / (y1+y2) = 2 ---&amp;gt; x1+x2 = 2*(y1+y2), only if you know that y1+y2 is never going to be 0. Otherwise, they are not equivalent.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 25 May 2012 14:47:38 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126463#M697</guid>
      <dc:creator>YanXu</dc:creator>
      <dc:date>2012-05-25T14:47:38Z</dc:date>
    </item>
    <item>
      <title>Re: Non-linear constraint</title>
      <link>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126464#M698</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thanks for the clarification.&lt;/P&gt;&lt;P&gt;By the way, I have an equation of the form x/y+z=c (where x,y,z are decision variables and &amp;gt;0, c is a constant).Is there a possible way of converting this to a linear form? &lt;BR /&gt; &lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 28 May 2012 07:32:17 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126464#M698</guid>
      <dc:creator>Abhik</dc:creator>
      <dc:date>2012-05-28T07:32:17Z</dc:date>
    </item>
    <item>
      <title>Re: Non-linear constraint</title>
      <link>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126465#M699</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;If you multiply both sides by y, you get x + y z = c y.&amp;nbsp; If y and z are binary variables, you can replace the product y z with a new binary variable w and add some constraints.&amp;nbsp; If only one of y and z is binary and the other is bounded, you can linearize the product in a similar manner.&amp;nbsp; If neither of y and z is binary, you can discretize one of them and apply the same techniques.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;For details, please see Chapters 10 and 24 in the new book of mathematical programming examples available as part of the SAS/OR documentation:&lt;/P&gt;&lt;P&gt;&lt;A class="jive-link-external-small" href="https://support.sas.com/pubscat/bookdetails.jsp?pc=64980"&gt;&lt;SPAN style="color: black;"&gt;https://support.sas.com/pubscat/bookdetails.jsp?pc=64980&lt;/SPAN&gt;&lt;/A&gt; (click on View This Title Online for a free pdf version).&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 28 May 2012 14:20:23 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126465#M699</guid>
      <dc:creator>RobPratt</dc:creator>
      <dc:date>2012-05-28T14:20:23Z</dc:date>
    </item>
    <item>
      <title>Re: Non-linear constraint</title>
      <link>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126466#M700</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Neither of y and z is binary. Rob, I am not sure how I can discretize them so that the equation becomes linear.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 07 Jun 2012 06:25:48 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126466#M700</guid>
      <dc:creator>Abhik</dc:creator>
      <dc:date>2012-06-07T06:25:48Z</dc:date>
    </item>
    <item>
      <title>Re: Non-linear constraint</title>
      <link>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126467#M701</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Here is how to discretize a bounded variable y:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc optmodel;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; var y &amp;gt;= 0 &amp;lt;= 3;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; num num_steps = 10;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; set STEPS = 0..num_steps-1;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; num a {s in STEPS} = (s - y.lb) / (y.ub - y.lb);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; var yb {STEPS} binary;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; con assign: sum {s in STEPS} yb&lt;S&gt; = 1;&lt;/S&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; con link: sum {s in STEPS} a&lt;S&gt; * yb&lt;S&gt; = y;&lt;/S&gt;&lt;/S&gt;&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 09 Jun 2012 15:29:16 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Mathematical-Optimization/Non-linear-constraint/m-p/126467#M701</guid>
      <dc:creator>RobPratt</dc:creator>
      <dc:date>2012-06-09T15:29:16Z</dc:date>
    </item>
  </channel>
</rss>

