<?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: Parameter estimation (MLE) in SAS/IML Software and Matrix Computations</title>
    <link>https://communities.sas.com/t5/SAS-IML-Software-and-Matrix/Parameter-estimation-MLE/m-p/172311#M1670</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;You should always call your function before you try to optimize. The call gives an error:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;x = {2 2 2 2};&lt;/P&gt;&lt;P&gt;f = f_gglfr(x);&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The reason is that your TEMP variable has some large numbers (greater than 7000), so 1-exp(-temp) is numerically 0.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I think there might be another problem.When aarset is a vector, the function f_ggfr returns a vector.&amp;nbsp; I assume you intend for &lt;SPAN style="font-size: 13.3333330154419px;"&gt;f_ggfr to be a scalar function.&lt;/SPAN&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Tue, 17 Feb 2015 22:21:03 GMT</pubDate>
    <dc:creator>Rick_SAS</dc:creator>
    <dc:date>2015-02-17T22:21:03Z</dc:date>
    <item>
      <title>Parameter estimation (MLE)</title>
      <link>https://communities.sas.com/t5/SAS-IML-Software-and-Matrix/Parameter-estimation-MLE/m-p/172310#M1669</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Trying to estimate the parameters for the following log-likelihood, have the following code but sas keeps giving me the error "ERROR: (execution) Matrix has not been set to a value." here is my code; if anyone can help will appreciate it attached is also the function I am working with&lt;/P&gt;&lt;P&gt;proc iml; &lt;/P&gt;&lt;P&gt;aarset= &lt;/P&gt;&lt;P&gt;{0.1 0.2 1 1 1 1 1 2 3 6 7 11 12 18 18 18 18 18&lt;/P&gt;&lt;P&gt;21 32 36 40 45 46 47 50 55 60 63 63 67 67 67 67 &lt;/P&gt;&lt;P&gt;72 75 79 82 82 83 84 84 84 85 85 85 85 85 86 86}; &lt;/P&gt;&lt;P&gt;P = ncol(aarset); m = p;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;start f_gglfr(x) global(aarset); &lt;/P&gt;&lt;P&gt;/* use x&lt;L&gt;-a, x[2]-b, x[3]-d, x[4]-delta */ &lt;/L&gt;&lt;/P&gt;&lt;P&gt;p=ncol(aarset); m=p-4; &lt;/P&gt;&lt;P&gt;sum1 = 0.; sum2 = 0.; sum3 = 0.; sum4 = 0.;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do i = 1 to p;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; temp = (x[1]+(x[2]/2)*aarset##2);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if i &amp;lt;= m then sum1 = sum1 + (x[1]+x[2]*aarset);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; sum2 = sum2 + (-x[3]*log(1-exp(-temp)));&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum3 = sum3 + (x[1]*aarset+(x[2]/2)*aarset##2);&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum4 = sum4 + (1-exp(-temp));&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; f = m*log(x[3]) - m*log(Gamma(x[4])) + log(sum1) +(x[4]-1)*log(sum2) - sum3 + (x[3]-1)*log(sum4);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(f);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; finish f_gglfr;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; start g_gglfr(x) global(aarset);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* use x&lt;L&gt;-a, x[2]-b, x[3]-d, x[4]-delta */ &lt;/L&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; p=ncol(aarset); m=p-4; &lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; g = j(1,4,0.);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; sum1 = 0.; sum2 = 0.; sum3 = 0.; sum4 = 0.; sum5 = 0.; sum6 = 0.; sum7 = 0.; sum8 = 0.; sum9 = 0.; sum10 = 0.; sum11 = 0.;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do i = 1 to p;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; temp = (x[1]+(x[2]/2)*aarset##2);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if i &amp;lt;= m then sum1 = sum1 + (x[1]+x[2]*aarset);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; sum2 = sum2 + (aarset*exp(-temp))/((1-exp(-temp)*log(1-exp(-temp)));&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum3 = sum3 + (aarset*exp(temp))/(1-exp(temp));&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum4 = sum4 + aarset;&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum5 = sum5 + aarset/(x[1]+x[2]*aarset);&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum6 = sum6 + (aarset##2*exp(-temp))/(log(1-exp(-temp)*(1-exp(-temp));&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum7 = sum7 + aarset##2/2;&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum8 = sum8 + (aarset##2*exp(temp))/(1-exp(temp));&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum9 = sum9 + (log(1-exp(-temp)))/(log(1-exp(-temp)));&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum10 = sum10 + (log(1-exp(-temp)));&lt;/P&gt;&lt;P&gt;&amp;nbsp; sum11 = sum11 + log(-x[3]*log(1-exp(-temp)));&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp; temp = (1/2)*(2*x[1]+x[2]*aarset##2);&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; g[1] = 1/sum1+(x[4]-1)*sum2+sum4+(x[3]-1)*sum3;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; g[2] = sum5+(x[4]-1)/2*sum6+sum7+(x[3]-1)/2*sum8;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; g[3] = m/x[3] - (x[4]-1)/x[3]*sum9+sum10;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; g[4] = -m*psi(x[4])/Gamma(x[4])+sum11;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(g);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; finish g_gglfr;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; n = 4; &lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; x0 = j(1,n,2);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; optn = {1 2};&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; con = { 0 0 0 0,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; . . . . };&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; call nlptr(rc,xres,"f_gglfr",x0,optn,con,,,,"g_gglfr");&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; /*--- Save result in xopt, fopt ---*/&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; xopt = xres`; fopt = f_gglfr(xopt);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 17 Feb 2015 17:46:18 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-IML-Software-and-Matrix/Parameter-estimation-MLE/m-p/172310#M1669</guid>
      <dc:creator>seyibote</dc:creator>
      <dc:date>2015-02-17T17:46:18Z</dc:date>
    </item>
    <item>
      <title>Re: Parameter estimation (MLE)</title>
      <link>https://communities.sas.com/t5/SAS-IML-Software-and-Matrix/Parameter-estimation-MLE/m-p/172311#M1670</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;You should always call your function before you try to optimize. The call gives an error:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;x = {2 2 2 2};&lt;/P&gt;&lt;P&gt;f = f_gglfr(x);&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The reason is that your TEMP variable has some large numbers (greater than 7000), so 1-exp(-temp) is numerically 0.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I think there might be another problem.When aarset is a vector, the function f_ggfr returns a vector.&amp;nbsp; I assume you intend for &lt;SPAN style="font-size: 13.3333330154419px;"&gt;f_ggfr to be a scalar function.&lt;/SPAN&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 17 Feb 2015 22:21:03 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-IML-Software-and-Matrix/Parameter-estimation-MLE/m-p/172311#M1670</guid>
      <dc:creator>Rick_SAS</dc:creator>
      <dc:date>2015-02-17T22:21:03Z</dc:date>
    </item>
  </channel>
</rss>

