[x265] [PATCH] asm: Unit test code for scale1D_128to64 Routine

chen chenm003 at 163.com
Thu Nov 14 08:20:42 CET 2013



On Thu, Nov 14, 2013 at 12:07 AM, <murugan at multicorewareinc.com> wrote:
# HG changeset patch
# User Murugan Vairavel <murugan at multicorewareinc.com>
# Date 1384409049 -19800
#      Thu Nov 14 11:34:09 2013 +0530
# Node ID c9fdf510182348c979a58be67101446c84b36569
# Parent  481cdfc251de0f99ef0a3c4fd53c786b79b5f182
asm: Unit test code for scale1D_128to64 Routine

diff -r 481cdfc251de -r c9fdf5101823 source/test/pixelharness.cpp
--- a/source/test/pixelharness.cpp      Wed Nov 13 12:46:07 2013 +0530
+++ b/source/test/pixelharness.cpp      Thu Nov 14 11:34:09 2013 +0530
@@ -586,6 +586,29 @@
     return true;
 }

+bool PixelHarness::check_scale_pixel_t(scale_t ref, scale_t opt)
+{
+    ALIGN_VAR_16(pixel, ref_dest[64 * 64]);
+    ALIGN_VAR_16(pixel, opt_dest[64 * 64]);
+
+    memset(ref_dest, 0, sizeof(ref_dest));
+    memset(opt_dest, 0, sizeof(opt_dest));
+
+    int j = 0;
+    for (int i = 0; i < ITERS; i++)
+    {
+        opt(opt_dest, pbuf1 + j, STRIDE);
+        ref(ref_dest, pbuf1 + j, STRIDE);
+
+        if (memcmp(ref_dest, opt_dest, 64 * 64 * sizeof(pixel)))
+            return false;
+
+        j += INCR;
+    }
+
+    return true;
+}
+
 bool PixelHarness::testPartition(int part, const EncoderPrimitives& ref, const EncoderPrimitives& opt)
 {
     if (opt.satd[part])
@@ -880,6 +903,15 @@
             return false;
         }
     }
+
+    if (opt.scale1D_128to64)
+    {
+        if (!check_scale_pixel_t(ref.scale1D_128to64, opt.scale1D_128to64))
+        {
+            printf("scale1D_128to64 failed!\n");
+            return false;
+        }
+    }
     return true;
 }

@@ -1093,4 +1125,10 @@
         printf("downscale");
         REPORT_SPEEDUP(opt.frame_init_lowres_core, ref.frame_init_lowres_core, pbuf2, pbuf1, pbuf2, pbuf3, pbuf4, 64, 64, 64, 64);
     }
+
+    if (opt.scale1D_128to64)
+    {
+        printf("scale1D_128to64");
+        REPORT_SPEEDUP(opt.scale1D_128to64, ref.scale1D_128to64, pbuf2, pbuf1, 64);
+    }
 }
diff -r 481cdfc251de -r c9fdf5101823 source/test/pixelharness.h
--- a/source/test/pixelharness.h        Wed Nov 13 12:46:07 2013 +0530
+++ b/source/test/pixelharness.h        Thu Nov 14 11:34:09 2013 +0530
@@ -61,6 +61,8 @@
     bool check_blockfill_s(blockfill_s_t ref, blockfill_s_t opt);

     bool check_pixel_sub_ps(pixel_sub_ps_t ref, pixel_sub_ps_t opt);
+
+    bool check_scale_pixel_t(scale_t ref, scale_t opt);



drop _t suffix from the function name
 
increment _pp in end of name is better, since this function convert Pixel to Pixel
 
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mailman.videolan.org/pipermail/x265-devel/attachments/20131114/444cd902/attachment-0001.html>


More information about the x265-devel mailing list