当前位置: 首页 > news >正文

avx指令集判断的坑

(一)背景
项目中依赖算法同学编写的算法模块,他们在使用avx,sse指令集来提高速度,结果在一些机器上崩溃,导致项目无法发版。

我给他们说,我们项目中使用了谷歌的 libyuv 库,也使用了avx,sse指令加速,在各种环境下都是运行正常的。

后来发现他们对比了 libyuv 的判断指令集的代码发现,没有判断系统,网速搜索了一波,发现了这个文章:开源库中检测当前系统是否支持AVX指令集的一个坑 

也就是说,某些系统OS下是不支持的,需要单独判断。

(二)解决

1、判断avx的代码参考  libyuv 的方式来编写,不要自己写,有很多坑。这是发现的一处,可能还有更多的坑没有发现,毕竟libyuv是谷歌开发的开源库,并且十分稳定了。

2、因为算法有几次都因为各种原因导致不稳定,所以我们想了一个办法来解决这个通用的问题,不然每次软件发版都很害怕,一旦出问题了会很麻烦,用户用不了了,也无法升级。对用户体验是一次很大的伤害。我们的开发节奏也完全被打乱了,忙着去救火。

具体的方法是,我们开发了一个Demo的进程,假设就要Demo.exe吧。算法模块每次更新,我们先在Demo.exe中运行,不在我们主进程(用户真实使用的进程)运行,运行一段时间后,如果没有崩溃(崩溃后我们会上传dump供分析),我们就把算法模块给主进程使用。这个相当于在使用用户环境来预跑我们的算法模块。这样即便是算法模块再不稳定,也不会对用户产生实际的影响。

(三)其他

这个过程中因为涉及到指令集的问题,所以推动他们在不同指令集的机器上先验证,没有问题之后再给到我们项目中去使用,之前推动过一次,很难推动,这次他们这么不稳定,终于说服他们了,他们也采购了2台设备来覆盖测试了,虽然不一定完全覆盖全,但是至少风险是降低了不少,因为有些机器是必须崩溃的。

http://www.lryc.cn/news/92243.html

相关文章:

  • 求内推,求明主!
  • 第十三章:约束
  • M.2 SSD接口详解
  • 在本地Windows 11 系统的桌面版Docker上搭建PlantUML
  • mysql的sql_mode模式
  • chatgpt赋能python:Python编程必备之OpenCV库下载与安装
  • sparkSQL的使用
  • gitignore的语法
  • 长袋除尘器
  • HTML+CSS实训——Day02——仿一个网易云音乐的登陆界面
  • css蓝桥杯--电影院排座位
  • c++学习——多态
  • Java SPI机制及原理详解
  • 不压缩打包layui
  • 过去、现在及未来
  • leetcode701. 二叉搜索树中的插入操作(java)
  • Docker的容器管理操作
  • 计算机组成原理——中央处理器
  • tidb变更大小写敏感问题的总结
  • 法规标准-UN R158标准解读
  • 160个CrackMe之002
  • 3. 响应状态码及Response对象的status_code属性
  • MIME 类型列表 03
  • SpringBoot项目登录并接入MFA二次认证
  • 算法与数据结构(三)
  • 亚马逊云科技出海日,让数字经济出海扩展到更多行业和领域
  • Pb协议的接口测试
  • 2. 分布式文件系统 HDFS
  • 借助金融科技差异化发展,不一样的“破茧”手法
  • typescript中type、interface的区别