亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ch07test.c

?? arm嵌入式系統開發--軟件設計與優化隨書源代碼。開發環境c。基本運算優化部分。
?? C
字號:
/* ____________________________________________________________________
 *
 * Copyright (c) 2003, Andrew N. Sloss, Dominic Symes, Chris Wright
 * All rights reserved.
 * ____________________________________________________________________
 * 
 * NON-COMMERCIAL USE License
 * 
 * Redistribution and use in source and binary forms, with or without 
 * modification, are permitted provided that the following conditions 
 * are met: 
 *
 * 1. For NON-COMMERCIAL USE only.
 * 
 * 2. Redistributions of source code must retain the above copyright 
 *    notice, this list of conditions and the following disclaimer. 
 *
 * 3. Redistributions in binary form must reproduce the above 
 *    copyright notice, this list of conditions and the following 
 *    disclaimer in the documentation and/or other materials provided 
 *    with the distribution. 
 *
 * 4. All advertising materials mentioning features or use of this 
 *    software must display the following acknowledgement:
 *
 *    This product includes software developed by Andrew N. Sloss,
 *    Chris Wright and Dominic Symes. 
 *
 *  THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS ``AS IS'' AND ANY 
 *  EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
 *  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
 *  PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE CONTRIBUTORS BE 
 *  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, 
 *  OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
 *  PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, 
 *  OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 
 *  THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR 
 *  TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 
 *  OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY 
 *  OF SUCH DAMAGE. 
 *
 * If you have questions about this license or would like a different
 * license please email : andrew@sloss.net
 *
 * Test module for the example routines of Chapter 7
 */
 
#include <stdio.h>
#include "ch07test.h"

int main(void)
{
  int errors=0;

  printf("Testing examples for Chapter 7\n");

  /* Section 7.1 */
  TEST_B64(mul_64to64, gen_s64, gen_s64, 1);
  TEST_B64TO128(umul_64to128_arm7m, gen_s64, gen_s64, 1);
  TEST_B64TO128(umul_64to128_arm9e, gen_s64, gen_s64, 1);
  TEST_B64TO128(smul_64to128, gen_s64, gen_s64, 1);
  /* Section 7.2 */
  TEST_U32TOB32(unorm_arm9e, gen_s32, 1);
  TEST_U32TOB32(snorm_arm9e, gen_s32, 1);
  TEST_U32TOB32(unorm_arm7m, gen_s32, 1);
  TEST_U32TOB32(unorm_arm7m_hash, gen_s32, 1);
  TEST_U32(ctz_arm9e, gen_s32_ctz, 1);
  TEST_U32(ctz_arm7m, gen_s32_ctz, 1);
  /* Section 7.3 */
  TEST_B32TOB32(udiv_simple_test, gen_s32, gen_s32, 1);
  TEST_B32TOB32(udiv_32by32_arm7m, gen_s32, gen_s32, 1);
  TEST_B32TOB32(udiv_32by16_arm7m, gen_u15, gen_s32, 1);
  TEST_32_64TOB32(udiv_64by32_arm7m, gen_u31, gen_s64, 1);
  TEST_B32TOB32(udiv_32by32_arm9e, gen_s32, gen_s32, 1);
  TEST_B32(udiv_q15_arm9e, gen_u15, gen_u31, 1);
  TEST_B32(udiv_q31_arm9e, gen_u31, gen_s32, 1);
  TEST_B32TOB32(sdiv_32by32_arm7m, gen_s32, gen_s32, 1);
  /* Section 7.4 */
  TEST_U32(usqr_simple_test, gen_s32, 1);
  TEST_U32(usqr_32, gen_s32, 1);
  TEST_U32(ucbr_32, gen_s32, 1);
  TEST_U32(rsqr_32, gen_s32, 2);
  /* Section 7.5 */
  TEST_U32(ulog2_32, gen_s32, 2);
  TEST_U32(uexp2_32, gen_s32, 4);
  TEST_U32(sin_32, gen_s32, 4);
  TEST_U32(cos_32, gen_s32, 4);
  /* Section 7.6 */
  TEST_U32(byte_reverse, gen_s32, 1);
  TEST_U32(byte_reverse_2reg, gen_s32, 1);
  TEST_U32(bit_count, gen_s32, 1);
  TEST_U32(bit_reverse, gen_s32, 1);
  TEST_U32(bit_spread, gen_s32, 1);
  TEST_U32(bit_rev_spread, gen_s32, 1);
  /* Section 7.7 */
  TEST_U32(qsat_16, gen_s32, 1);
  TEST_B32(qshl_32, gen_s32, gen_shift, 1);
  TEST_B32(qshr_32, gen_s32, gen_shift, 1);
  TEST_B32(qadd_32, gen_s32, gen_s32, 1);
  TEST_B32(qsub_32, gen_s32, gen_s32, 1);
  TEST_B32(absa_32, gen_s32, gen_s32, 1);
  TEST_U32(qabs_32, gen_s32, 1);
  /* Section 7.8 */
  TEST_RAND(rand_32);
    
  if (errors)
  {
    printf("Test finished with %d errors.\n", errors);
    return 1;
  }
  else
  {
    printf("Test passed.\n");
  }
  return 0;
}

int test_b64(
  char *name,           /* function name */
  fn_b64 *ref,          /* reference to test against */
  fn_b64 *fn,           /* function to test */
  fn_u64 *nextb,        /* generator for "b" values */
  fn_u64 *nextc,        /* generator for "c" values */
  int maxerr            /* maximum error alowed */
)
{
  int64 b=0,c=0,out,refout,d;
  int err=0;
  
  printf("Testing function: %s\n", name);
  
  do
  {
#if VERBOSE
    printf("b = %016llx\n", b);
#endif
    do
    {
      /* test the function */
      refout = (*ref)(b,c);
      out = (*fn)(b,c);
      d = out-refout;
      if (d<0) d=-d;
      if (d>=maxerr)
      {
        printf("FAIL %s(%016llx, %016llx) = ", name, b, c);
        printf("%016llx (ref: %016llx)\n", out, refout);
        err++;
      }
      c = (*nextc)(c);
    } while (c);
    
    b = (*nextb)(b);
  } while (b);

  return err;
}

int test_b64to128(
  char *name,           /* function name */
  fn_b64to128 *ref,     /* reference to test against */
  fn_b64to128 *fn,      /* function to test */
  fn_u64 *nextb,        /* generator for "b" values */
  fn_u64 *nextc,        /* generator for "c" values */
  int maxerr            /* maximum error alowed */
)
{
  int64 b=0,c=0;
  uint128 refout, out;
  int d;
  int err=0;
  
  printf("Testing function: %s\n", name);
  
  do
  {
#if VERBOSE
    printf("b = %016llx\n", b);
#endif
    do
    {
      /* test the function */
      refout = (*ref)(b,c);
      out = (*fn)(b,c);
      d = (int)(out.a0-refout.a0);
      if (d<0) d=-d;
      if (out.a1!=refout.a1 ||
          out.a2!=refout.a2 ||
          out.a3!=refout.a3 ||
          d>=maxerr)
      {
        printf("FAIL %s(%016llx, %016llx)\n", name, b, c);
        printf("  out: ");
        print128(out);
        printf("\n  ref: ");
        print128(refout);
        printf("\n");
        err++;
      }
      c = (*nextc)(c);
    } while (c);
    
    b = (*nextb)(b);
  } while (b);

  return err;
}

int test_b32tob32(
  char *name,           /* function name */
  fn_b32tob32 *ref,     /* reference to test against */
  fn_b32tob32 *fn,      /* function to test */
  fn_u32 *nextb,        /* generator for "b" values */
  fn_u32 *nextc,        /* generator for "c" values */
  int maxerr            /* maximum error alowed */
)
{
  int32 b=0, c=0;
  pair32 refout, out;
  int d;
  int err=0;
  
  printf("Testing function: %s\n", name);
  
  do
  {
#if VERBOSE
    printf("b = %08lx\n", b);
#endif
    do
    {
      /* test the function */
      refout = (*ref)(b,c);
      out = (*fn)(b,c);
      d = (int)(out.a-refout.a);
      if (d<0) d=-d;
      if (out.b!=refout.b || d>=maxerr)
      {
        printf("FAIL %s(%08lx,%08lx) = ", name, b, c);
        printf("%08lx %08lx ", out.a, out.b);
        printf("(ref: %08lx %08lx)\n", refout.a, refout.b);
        err++;
      }
      c = (*nextc)(c);
    } while (c);
    
    b = (*nextb)(b);
  } while (b);

  return err;
}

int test_32_64tob32(
  char *name,           /* function name */
  fn_32_64tob32 *ref,     /* reference to test against */
  fn_32_64tob32 *fn,      /* function to test */
  fn_u32 *nextb,        /* generator for "b" values */
  fn_u64 *nextc,        /* generator for "c" values */
  int maxerr            /* maximum error alowed */
)
{
  int32 b=0;
  int64 c=0;
  pair32 refout, out;
  int d;
  int err=0;
  
  printf("Testing function: %s\n", name);
  
  do
  {
#if VERBOSE
    printf("b = %08lx\n", b);
#endif
    do
    {
      /* test the function */
      refout = (*ref)(b,c);
      out = (*fn)(b,c);
      d = (int)(out.a-refout.a);
      if (d<0) d=-d;
      if (out.b!=refout.b || d>=maxerr)
      {
        printf("FAIL %s(%08lx,%016llx) = ", name, b, c);
        printf("%08lx %08lx ", out.a, out.b);
        printf("(ref: %08lx %08lx)\n", refout.a, refout.b);
        err++;
      }
      c = (*nextc)(c);
    } while (c);
    
    b = (*nextb)(b);
  } while (b);

  return err;
}

int test_u32tob32(
  char *name,           /* function name */
  fn_u32tob32 *ref,     /* reference to test against */
  fn_u32tob32 *fn,      /* function to test */
  fn_u32 *nextb,        /* generator for "b" values */
  int maxerr            /* maximum error alowed */
)
{
  int32 b=0;
  pair32 refout, out;
  int d;
  int err=0;
  
  printf("Testing function: %s\n", name);
  
  do
  {
#if VERBOSE
    printf("b = %08lx\n", b);
#endif
    /* test the function */
    refout = (*ref)(b);
    out = (*fn)(b);
    d = (int)(out.a-refout.a);
    if (d<0) d=-d;
    if (out.b!=refout.b || d>=maxerr)
    {
      printf("FAIL %s(%08lx) = ", name, b);
      printf("%08lx %08lx ", out.a, out.b);
      printf("(ref: %08lx %08lx)\n", refout.a, refout.b);
      err++;
    }
    
    b = (*nextb)(b);
  } while (b);

  return err;
}

int test_u32(
  char *name,           /* function name */
  fn_u32 *ref,     /* reference to test against */
  fn_u32 *fn,      /* function to test */
  fn_u32 *nextb,        /* generator for "b" values */
  int maxerr            /* maximum error alowed */
)
{
  int32 b=0;
  int32 refout, out;
  int d;
  int err=0;
  
  printf("Testing function: %s\n", name);
  
  do
  {
#if VERBOSE
    printf("b = %08lx\n", b);
#endif
    /* test the function */
    refout = (*ref)(b);
    out = (*fn)(b);
    d = (int)(out-refout);
    if (d<0) d=-d;
    if (d>=maxerr)
    {
      printf("FAIL %s(%08lx) = ", name, b);
      printf("%08lx ", out);
      printf("(ref: %08lx)\n", refout);
      err++;
    }
    
    b = (*nextb)(b);
  } while (b);

  return err;
}

int test_b32(
  char *name,           /* function name */
  fn_b32 *ref,          /* reference to test against */
  fn_b32 *fn,           /* function to test */
  fn_u32 *nextb,        /* generator for "b" values */
  fn_u32 *nextc,        /* generator for "c" values */
  int maxerr            /* maximum error alowed */
)
{
  int32 b=0, c=0;
  int32 refout, out;
  int d;
  int err=0;
  
  printf("Testing function: %s\n", name);
  
  do
  {
#if VERBOSE
    printf("b = %08lx\n", b);
#endif
    do
    {
      /* test the function */
      refout = (*ref)(b,c);
      out = (*fn)(b,c);
      d = (int)(out-refout);
      if (d<0) d=-d;
      if (d>=maxerr)
      {
        printf("FAIL %s(%08lx,%08lx) = ", name, b, c);
        printf("%08lx ", out);
        printf("(ref: %08lx)\n", refout);
        err++;
      }
      c = (*nextc)(c);
    } while (c);
    
    b = (*nextb)(b);
  } while (b);

  return err;
}

#define RANDSIZE 10     /* generate random numbers between 0 and 10 */

int test_rand(
  char *name,           /* function name */
  fn_u32 *fn            /* function to test */
)
{
  /* Test a random number generator using Chi Squared test */
  /* See Knuth Seminumerical Algorithms, Section 3.3.1 for the theory */
  unsigned i, n;
  unsigned bins[RANDSIZE];
  
  for (i=0; i<RANDSIZE; i++)
  {
    bins[i]=0;
  }
  
  printf("Testing function: %s\n", name);

  n = RANDSIZE*100;
  for (i=0; i<n; i++)
  {
    unsigned r;
    
    r = (unsigned)(*fn)(RANDSIZE);        /* generate the random number */
    if (r>=RANDSIZE)
    {
      printf("Random number not in range %d\n", r);
      return 1;
    }
#if VERBOSE
    if (i<40) printf("%ld ", (*fn)(10));
#endif
    bins[r]++;
  }
#if VERBOSE
  printf("\n");
#endif
  
  /* now work out the Chi Square */
  {
    unsigned sum=0;
    double chi;
    
    for (i=0; i<RANDSIZE; i++)
    {
#if VERBOSE
      printf("Frequency[%d] = %d\n", i, bins[i]);
#endif
      sum += bins[i]*bins[i];
    }
    chi = (double)RANDSIZE*(double)sum/(double)n - (double)n;
#if VERBOSE
    printf("Chi square = %lf\n", chi);
#endif
    /* check probability of this Chi Square is between 25% and 75% */
    if (chi < 5.0 || chi > 12.0 )
    {
      printf("Chi square not in correct range: %lf\n", chi);
      return 1;
    }
  }
  return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产毛片aaaaa无费看| 久久精品久久综合| av中文字幕在线不卡| 国产精品视频看| 97精品久久久午夜一区二区三区| 国产精品国产精品国产专区不蜜| 91麻豆精品视频| 午夜久久电影网| 韩日av一区二区| 久久新电视剧免费观看| 青椒成人免费视频| 日韩免费观看2025年上映的电影| 久久精品免费看| 国产日产欧美一区二区三区| 不卡电影免费在线播放一区| 亚洲午夜免费电影| 日韩欧美视频一区| jlzzjlzz欧美大全| 性久久久久久久| 26uuu国产日韩综合| 91香蕉视频污| 免费日韩伦理电影| 国产精品久久毛片a| 欧美日韩在线不卡| 国产高清在线精品| 亚洲国产中文字幕| 国产午夜精品在线观看| 欧美影院午夜播放| 7799精品视频| 欧美一区二区大片| 国产精品小仙女| 亚洲精品国产精华液| 日韩精品一区二区在线观看| 成人免费视频播放| 日韩精品一级二级 | 亚洲一区二区欧美日韩| 日韩欧美综合一区| 91啪亚洲精品| 国产美女视频一区| 亚洲一区二区精品3399| 久久亚洲一区二区三区四区| 欧美制服丝袜第一页| 福利一区二区在线观看| www.欧美日韩| 久久99精品久久久久久国产越南 | 国内精品免费**视频| 国产精品久久国产精麻豆99网站| 欧美精品久久99| 久久久久久久久久久久久女国产乱| 一本久久a久久免费精品不卡| 久久精品噜噜噜成人av农村| 夜夜嗨av一区二区三区四季av| 久久久久久久久久美女| 6080日韩午夜伦伦午夜伦| 色综合久久天天| 国产盗摄一区二区三区| 日本强好片久久久久久aaa| 一区二区三区在线观看动漫| 国产精品系列在线| 久久无码av三级| 日韩精品一区二区三区三区免费 | 日韩精品亚洲一区| 一区二区欧美在线观看| 亚洲天堂成人在线观看| 麻豆视频一区二区| 五月天激情综合网| 亚洲综合一区二区| 亚洲综合一二三区| 一区二区三区四区中文字幕| 亚洲色图视频免费播放| 国产精品国产三级国产专播品爱网 | 91福利小视频| 9久草视频在线视频精品| 成人综合婷婷国产精品久久免费| 国产原创一区二区三区| 理论电影国产精品| 卡一卡二国产精品 | 国v精品久久久网| 国产乱人伦偷精品视频免下载| 乱一区二区av| 国产剧情在线观看一区二区| 蜜桃视频免费观看一区| 久久er精品视频| 国产在线精品一区二区不卡了| 国产麻豆精品久久一二三| 国产精品一二三四| 99久久久精品| 欧美性xxxxxx少妇| 欧美高清视频在线高清观看mv色露露十八| 在线亚洲精品福利网址导航| 欧美性高清videossexo| 777奇米四色成人影色区| 日韩丝袜美女视频| 国产三级一区二区| 精品一区二区在线看| 韩国女主播一区| 成人激情av网| 欧美三级视频在线观看| 欧美一区二区视频在线观看2022 | 精品美女被调教视频大全网站| 精品卡一卡二卡三卡四在线| 国产午夜精品久久| 有码一区二区三区| 日本不卡中文字幕| 国产成人精品三级| 91久久一区二区| 欧美xxxx老人做受| 成人免费在线播放视频| 午夜一区二区三区视频| 国内精品国产三级国产a久久| a级高清视频欧美日韩| 欧美日韩亚洲丝袜制服| 国产三级一区二区三区| 亚洲一区二区三区视频在线播放| 久久超级碰视频| 91在线码无精品| 日韩欧美色电影| 亚洲人成精品久久久久| 久久精品二区亚洲w码| 99久久综合色| 精品欧美久久久| 一区二区三区久久| 国产成人亚洲综合a∨婷婷图片 | 国产伦精品一区二区三区免费迷| av电影一区二区| 日韩精品在线一区| 国产一区二区毛片| 欧美在线啊v一区| 久久久久久久久久久久电影| 亚洲成人7777| jlzzjlzz亚洲女人18| 日韩精品一区二区三区四区| 亚洲精品老司机| 高清国产一区二区| 日韩午夜激情电影| 亚洲福利国产精品| 99精品视频中文字幕| 久久综合久久综合久久综合| 亚洲成在人线免费| 一本色道久久加勒比精品| 久久久久久久综合色一本| 日韩成人av影视| 欧美在线你懂得| 亚洲日本一区二区三区| 国产69精品久久99不卡| 2020国产精品久久精品美国| 日本中文一区二区三区| 欧美午夜电影在线播放| 综合激情成人伊人| 成人福利视频在线看| 久久久久久亚洲综合影院红桃| 日韩福利电影在线| 欧美日韩aaaaa| 亚洲自拍偷拍麻豆| 在线免费观看一区| 亚洲免费在线看| 99在线精品视频| 国产精品天干天干在线综合| 国产精品456露脸| 久久久久高清精品| 国产精品自拍三区| 国产日韩欧美综合在线| 国产乱码精品一区二区三区av| 欧美r级在线观看| 久久精品国产精品青草| 欧美大片一区二区| 激情综合色播激情啊| 精品国产一区二区三区av性色| 免费在线观看不卡| 日韩欧美一区在线观看| 久久99精品网久久| 久久女同精品一区二区| 国产福利一区二区三区视频| 久久久噜噜噜久噜久久综合| 国产精品伊人色| 国产精品免费人成网站| 99久久国产综合精品色伊| 亚洲精品国产无套在线观| 欧美亚洲动漫精品| 成人av电影在线观看| 国产精品久久久久久福利一牛影视 | 欧美视频日韩视频在线观看| 亚洲午夜视频在线| 日韩情涩欧美日韩视频| 国产精品99久久久久久久女警| 国产欧美日韩在线| 91蝌蚪porny九色| 亚洲福利视频一区二区| 日韩精品中午字幕| 福利91精品一区二区三区| 亚洲乱码国产乱码精品精可以看| 欧美三级欧美一级| 毛片av一区二区三区| 国产农村妇女毛片精品久久麻豆| 97久久久精品综合88久久| 亚瑟在线精品视频| 久久久久国产一区二区三区四区 | 精品sm在线观看| 成人福利电影精品一区二区在线观看| 亚洲精品日日夜夜|