查看: 134|回复: 0

NEON的vsub方法溢出

[复制链接]
发表于 2020-2-16 09:53:48 | 显示全部楼层 |阅读模式
关于NEON的vsub方法的溢出,效果如下:

  • vsub会产生溢出,根据数据bit表示规律,可知溢出效果和理论正确效果形成互补,比如249-(-7)=256
  • 使用类vreinterpretq_s16_u16方法可以得到正确的效果
  1. void neontest(){    uchar v1[] = {0,1,2,3,4,5,6,7};    uchar v2[] = {7,6,5,4,3, 2, 1, 7};    uchar vr[8];    short vr2[8];    unsigned short vr3[8];    uint8x8_t d1 = vld1_u8(v1);    uint8x8_t d2 = vld1_u8(v2);    uint8x8_t r1 = vsub_u8(d1, d2);    vst1_u8(vr, r1);    LOGD("%d %d %d %d %d %d %d %d", vr[0], vr[1], vr[2], vr[3], vr[4], vr[5], vr[6], vr[7]);    int16x8_t r2 =  vreinterpretq_s16_u16(vsubl_u8(d1, d2));    vst1q_s16(vr2, r2);    LOGD("%d %d %d %d %d %d %d %d", vr2[0], vr2[1], vr2[2], vr2[3], vr2[4], vr2[5], vr2[6], vr2[7]);    uint16x8_t r3 =  vsubl_u8(d1, d2);    vst1q_u16(vr3, r3);    LOGD("%d %d %d %d %d %d %d %d", vr3[0], vr3[1], vr3[2], vr3[3], vr3[4], vr3[5], vr3[6], vr3[7]);}///////////////out putD/LOG:==========main start================D/LOG:249 251 253 255 1 3 5 0D/LOG:-7 -5 -3 -1 1 3 5 0D/LOG:65529 65531 65533 65535 1 3 5 0D/LOG:==========main end================
复制代码

天涯海角也要找到Ni:NEON的vsub方法溢出

中发现Ni: NEON的vsub方法溢出
中发现Ni: NEON的vsub方法溢出
中发现Ni: NEON的vsub方法溢出
中发现Ni: NEON的vsub方法溢出
中发现Ni: NEON的vsub方法溢出
中发现Ni: NEON的vsub方法溢出
相关技术服务需求,请联系管理员和客服QQ:2753533861或QQ:619920289
您需要登录后才可以回帖 登录 | 用户注册

本版积分规则

帖子推荐:
客服咨询

QQ:2753533861

服务时间 9:00-22:00

快速回复 返回顶部 返回列表