<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Mon, Sep 30, 2013 at 8:27 PM, Aarthi Priya Thirumalai <span dir="ltr"><<a href="mailto:aarthi@multicorewareinc.com" target="_blank">aarthi@multicorewareinc.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><p></p><div><div class="h5"><br>
On Oct 1, 2013 1:44 AM, "Steve Borho" <<a href="mailto:steve@borho.org" target="_blank">steve@borho.org</a>> wrote:<br>
><br>
><br>
><br>
><br>
> On Fri, Sep 27, 2013 at 11:52 PM, Aarthi Thirumalai <<a href="mailto:aarthi@multicorewareinc.com" target="_blank">aarthi@multicorewareinc.com</a>> wrote:<br>
>><br>
>> # HG changeset patch<br>
>> # User Aarthi Thirumalai<br>
>> # Date 1380343885 -19800<br>
>> #      Sat Sep 28 10:21:25 2013 +0530<br>
>> # Node ID b1539ccab7bab1708433a9b8b18f5f8c090b1810<br>
>> # Parent  a8b00de495520f00a4648dac5d111e40b5570ca3<br>
>> integrated ssim computation for each CTURow<br>
>><br>
>> diff -r a8b00de49552 -r b1539ccab7ba source/encoder/frameencoder.cpp<br>
>> --- a/source/encoder/frameencoder.cpp   Sat Sep 28 10:18:23 2013 +0530<br>
>> +++ b/source/encoder/frameencoder.cpp   Sat Sep 28 10:21:25 2013 +0530<br>
>> @@ -91,6 +91,9 @@<br>
>>          delete[] m_rows;<br>
>>      }<br>
>><br>
>> +    if (tempBuf)<br>
><br>
><br>
> X265_FREE does the NULL check for you<br>
>  <br>
>><br>
>> +        X265_FREE(tempBuf);<br>
>> +<br>
>>      m_frameFilter.destroy();<br>
>><br>
>>      // wait for worker thread to exit<br>
>> @@ -106,6 +109,8 @@<br>
>>                          2 : (m_cfg->param.bEnableSAO || m_cfg->param.bEnableLoopFilter ? 1 : 0);<br>
>><br>
>>      m_rows = new CTURow[m_numRows];<br>
>> +    if(m_cfg->param.bEnableSsim)<br>
><br>
><br>
> white-space<br>
>  <br>
>><br>
>> +        CHECKED_MALLOC(tempBuf, int, m_cfg->param.bEnableSsim * 8 * (m_cfg->param.sourceWidth/4 + 3));<br>
>>      for (int i = 0; i < m_numRows; ++i)<br>
>>      {<br>
>>          m_rows[i].create(top);<br>
>> @@ -168,6 +173,8 @@<br>
>>          assert(0);<br>
>>      }<br>
>>      start();<br>
>> +fail:<br>
>> +    return;<br>
>>  }<br>
>><br>
>>  int FrameEncoder::getStreamHeaders(NALUnitEBSP **nalunits)<br>
>> @@ -540,6 +547,31 @@<br>
>>          slice->setSaoEnabledFlag((saoParam->bSaoFlag[0] == 1) ? true : false);<br>
>>      }<br>
>><br>
>> +    /*Compute SSIM if enabled*/<br>
>> +       if(m_cfg->param.bEnableSsim)<br>
><br>
> white-space <br>
>><br>
>> +       {<br>
>> +            pixel *rec = (pixel*)m_pic->getPicYuvRec()->getLumaAddr();<br>
>> +            pixel *org = (pixel*)m_pic->getPicYuvOrg()->getLumaAddr();<br>
>> +            int stride = m_pic->getPicYuvOrg()->getStride();<br>
>> +           for(int row = 0; row < m_numRows; row++)<br>
>> +           {<br>
>> +               int bEnd = ((row + 1) == (this->m_numRows - 1));<br>
>> +               int bStart = (row == 0);<br>
>> +               int minPixY = row * 64 - 4 * !bStart;<br>
>> +               int maxPixY = (row + 1)* 64 - 4 * !bEnd;<br>
>> +               int ssim_cnt;<br>
>> +               x265_emms();<br>
>> +               /* offset by 2 pixels to avoid alignment of ssim blocks with dct blocks,<br>
>> +               * and overlap by 4 */<br>
><br>
><br>
> do you understand what this comment implies?  I don't and we probably should<br>
> <br></div></div>
The function to calculate ssim for each row in this manner. Starting point : offset block by 2 in x axis. Do ssim for 2 4x4 blocks till row end. Offset by 4 in y axis from starting point n repeat above step for entire height(maxpicy - minpic) this offset is done so block positions don't match with dct sizes.</blockquote>
<div><br></div><div>Thanks.  Why is it important to not match dct sizes?  Are those less accurate for measuring SSIM because of blocking artifacts?  It seems like "cheating" almost, to avoid pixels you know will measure badly.</div>
<div><br></div><div>--</div><div>Steve</div></div></div></div>