• Sayed Adel's avatar
    Merge pull request #15510 from seiko2plus:issue15506 · f2fe6f40
    Sayed Adel authored
    * core: rework and optimize SIMD implementation of dotProd
    
      - add new universal intrinsics v_dotprod[int32], v_dotprod_expand[u&int8, u&int16, int32], v_cvt_f64(int64)
      - add a boolean param for all v_dotprod&_expand intrinsics that change the behavior of addition order between
        pairs in some platforms in order to reach the maximum optimization when the sum among all lanes is what only matters
      - fix clang build on ppc64le
      - support wide universal intrinsics for dotProd_32s
      - remove raw SIMD and activate universal intrinsics for dotProd_8
      - implement SIMD optimization for dotProd_s16&u16
      - extend performance test data types of dotprod
      - fix GCC VSX workaround of vec_mule and vec_mulo (in little-endian it must be swapped)
      - optimize v_mul_expand(int32) on VSX
    
    * core: remove boolean param from v_dotprod&_expand and implement v_dotprod_fast&v_dotprod_expand_fast
    
      this changes made depend on "terfendail" review
    f2fe6f40
Name
Last commit
Last update
..
cuda Loading commit data...
opencl Loading commit data...
perf_abs.cpp Loading commit data...
perf_addWeighted.cpp Loading commit data...
perf_arithm.cpp Loading commit data...
perf_bitwise.cpp Loading commit data...
perf_compare.cpp Loading commit data...
perf_convertTo.cpp Loading commit data...
perf_cvround.cpp Loading commit data...
perf_dft.cpp Loading commit data...
perf_dot.cpp Loading commit data...
perf_inRange.cpp Loading commit data...
perf_io_base64.cpp Loading commit data...
perf_lut.cpp Loading commit data...
perf_main.cpp Loading commit data...
perf_mat.cpp Loading commit data...
perf_math.cpp Loading commit data...
perf_merge.cpp Loading commit data...
perf_minmaxloc.cpp Loading commit data...
perf_norm.cpp Loading commit data...
perf_precomp.hpp Loading commit data...
perf_reduce.cpp Loading commit data...
perf_sort.cpp Loading commit data...
perf_split.cpp Loading commit data...
perf_stat.cpp Loading commit data...
perf_umat.cpp Loading commit data...