/src/libjxl/lib/jxl/transpose-inl.h
Line | Count | Source (jump to first uncovered line) |
1 | | // Copyright (c) the JPEG XL Project Authors. All rights reserved. |
2 | | // |
3 | | // Use of this source code is governed by a BSD-style |
4 | | // license that can be found in the LICENSE file. |
5 | | |
6 | | // Block transpose for DCT/IDCT |
7 | | |
8 | | #include "lib/jxl/base/compiler_specific.h" |
9 | | |
10 | | #if defined(LIB_JXL_TRANSPOSE_INL_H_) == defined(HWY_TARGET_TOGGLE) |
11 | | #ifdef LIB_JXL_TRANSPOSE_INL_H_ |
12 | | #undef LIB_JXL_TRANSPOSE_INL_H_ |
13 | | #else |
14 | | #define LIB_JXL_TRANSPOSE_INL_H_ |
15 | | #endif |
16 | | |
17 | | #include <stddef.h> |
18 | | |
19 | | #include <hwy/highway.h> |
20 | | #include <type_traits> |
21 | | |
22 | | #include "lib/jxl/base/status.h" |
23 | | #include "lib/jxl/dct_block-inl.h" |
24 | | |
25 | | HWY_BEFORE_NAMESPACE(); |
26 | | namespace jxl { |
27 | | namespace HWY_NAMESPACE { |
28 | | namespace { |
29 | | |
30 | | #ifndef JXL_INLINE_TRANSPOSE |
31 | | // Workaround for issue #42 - (excessive?) inlining causes invalid codegen. |
32 | | #if defined(__arm__) |
33 | | #define JXL_INLINE_TRANSPOSE HWY_NOINLINE |
34 | | #else |
35 | | #define JXL_INLINE_TRANSPOSE HWY_INLINE |
36 | | #endif |
37 | | #endif // JXL_INLINE_TRANSPOSE |
38 | | |
39 | | // Simple wrapper that ensures that a function will not be inlined. |
40 | | template <typename T, typename... Args> |
41 | 9.50M | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { |
42 | 9.50M | return f(args...); |
43 | 9.50M | } Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::NoInlineWrapper<void (jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::NoInlineWrapper<void (jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::NoInlineWrapper<void (jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::NoInlineWrapper<void (jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::NoInlineWrapper<void (jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Line | Count | Source | 41 | 138k | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 138k | return f(args...); | 43 | 138k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) Line | Count | Source | 41 | 39.0k | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 39.0k | return f(args...); | 43 | 39.0k | } |
Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::NoInlineWrapper<void (jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::NoInlineWrapper<void (jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::NoInlineWrapper<void (jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Line | Count | Source | 41 | 138k | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 138k | return f(args...); | 43 | 138k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) Line | Count | Source | 41 | 39.0k | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 39.0k | return f(args...); | 43 | 39.0k | } |
Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::NoInlineWrapper<void (jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::NoInlineWrapper<void (jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::NoInlineWrapper<void (jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Line | Count | Source | 41 | 7.12M | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 7.12M | return f(args...); | 43 | 7.12M | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) Line | Count | Source | 41 | 1.48M | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 1.48M | return f(args...); | 43 | 1.48M | } |
Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::NoInlineWrapper<void (jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::NoInlineWrapper<void (jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::NoInlineWrapper<void (jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Line | Count | Source | 41 | 422k | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 422k | return f(args...); | 43 | 422k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) Line | Count | Source | 41 | 117k | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 117k | return f(args...); | 43 | 117k | } |
Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::NoInlineWrapper<void (jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo, unsigned long, float* restrict>(void ( const&)(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, float*), jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long const&, float* restrict const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::NoInlineWrapper<void (*)(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo, unsigned long, unsigned long>(void (* const&)(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long), jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true> const&, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long const&, unsigned long const&) |
44 | | |
45 | | template <bool enabled> |
46 | | struct TransposeSimdTag {}; |
47 | | |
48 | | // TODO(veluca): it's not super useful to have this in the SIMD namespace. |
49 | | template <size_t ROWS_or_0, size_t COLS_or_0, class From, class To> |
50 | | JXL_INLINE_TRANSPOSE void GenericTransposeBlock( |
51 | | TransposeSimdTag<false> /* tag */, const From& from, const To& to, |
52 | 48.6M | size_t ROWSp, size_t COLSp) { |
53 | 48.6M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; |
54 | 48.6M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; |
55 | 303M | for (size_t n = 0; n < ROWS; ++n) { |
56 | 1.51G | for (size_t m = 0; m < COLS; ++m) { |
57 | 1.26G | to.Write(from.Read(n, m), m, n); |
58 | 1.26G | } |
59 | 254M | } |
60 | 48.6M | } Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 151k | size_t ROWSp, size_t COLSp) { | 53 | 151k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 151k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 1.36M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 6.04M | for (size_t m = 0; m < COLS; ++m) { | 57 | 4.83M | to.Write(from.Read(n, m), m, n); | 58 | 4.83M | } | 59 | 1.20M | } | 60 | 151k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 81.6k | size_t ROWSp, size_t COLSp) { | 53 | 81.6k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 81.6k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 408k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 2.93M | for (size_t m = 0; m < COLS; ++m) { | 57 | 2.61M | to.Write(from.Read(n, m), m, n); | 58 | 2.61M | } | 59 | 326k | } | 60 | 81.6k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 60.2k | size_t ROWSp, size_t COLSp) { | 53 | 60.2k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 60.2k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 301k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 1.20M | for (size_t m = 0; m < COLS; ++m) { | 57 | 963k | to.Write(from.Read(n, m), m, n); | 58 | 963k | } | 59 | 240k | } | 60 | 60.2k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 41.9k | size_t ROWSp, size_t COLSp) { | 53 | 41.9k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 41.9k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 83.8k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 125k | for (size_t m = 0; m < COLS; ++m) { | 57 | 83.8k | to.Write(from.Read(n, m), m, n); | 58 | 83.8k | } | 59 | 41.9k | } | 60 | 41.9k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 22.3k | size_t ROWSp, size_t COLSp) { | 53 | 22.3k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 22.3k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 66.9k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 89.2k | for (size_t m = 0; m < COLS; ++m) { | 57 | 44.6k | to.Write(from.Read(n, m), m, n); | 58 | 44.6k | } | 59 | 44.6k | } | 60 | 22.3k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 16.7k | size_t ROWSp, size_t COLSp) { | 53 | 16.7k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 16.7k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 50.3k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 100k | for (size_t m = 0; m < COLS; ++m) { | 57 | 67.1k | to.Write(from.Read(n, m), m, n); | 58 | 67.1k | } | 59 | 33.5k | } | 60 | 16.7k | } |
Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 14.1k | size_t ROWSp, size_t COLSp) { | 53 | 14.1k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 14.1k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 42.3k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 141k | for (size_t m = 0; m < COLS; ++m) { | 57 | 113k | to.Write(from.Read(n, m), m, n); | 58 | 113k | } | 59 | 28.2k | } | 60 | 14.1k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 7.68k | size_t ROWSp, size_t COLSp) { | 53 | 7.68k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 7.68k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 38.4k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 92.2k | for (size_t m = 0; m < COLS; ++m) { | 57 | 61.5k | to.Write(from.Read(n, m), m, n); | 58 | 61.5k | } | 59 | 30.7k | } | 60 | 7.68k | } |
Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 151k | size_t ROWSp, size_t COLSp) { | 53 | 151k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 151k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 1.36M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 6.04M | for (size_t m = 0; m < COLS; ++m) { | 57 | 4.83M | to.Write(from.Read(n, m), m, n); | 58 | 4.83M | } | 59 | 1.20M | } | 60 | 151k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 81.6k | size_t ROWSp, size_t COLSp) { | 53 | 81.6k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 81.6k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 408k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 2.93M | for (size_t m = 0; m < COLS; ++m) { | 57 | 2.61M | to.Write(from.Read(n, m), m, n); | 58 | 2.61M | } | 59 | 326k | } | 60 | 81.6k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 60.2k | size_t ROWSp, size_t COLSp) { | 53 | 60.2k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 60.2k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 301k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 1.20M | for (size_t m = 0; m < COLS; ++m) { | 57 | 963k | to.Write(from.Read(n, m), m, n); | 58 | 963k | } | 59 | 240k | } | 60 | 60.2k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 41.9k | size_t ROWSp, size_t COLSp) { | 53 | 41.9k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 41.9k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 83.8k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 125k | for (size_t m = 0; m < COLS; ++m) { | 57 | 83.8k | to.Write(from.Read(n, m), m, n); | 58 | 83.8k | } | 59 | 41.9k | } | 60 | 41.9k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 22.3k | size_t ROWSp, size_t COLSp) { | 53 | 22.3k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 22.3k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 66.9k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 89.2k | for (size_t m = 0; m < COLS; ++m) { | 57 | 44.6k | to.Write(from.Read(n, m), m, n); | 58 | 44.6k | } | 59 | 44.6k | } | 60 | 22.3k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 16.7k | size_t ROWSp, size_t COLSp) { | 53 | 16.7k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 16.7k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 50.3k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 100k | for (size_t m = 0; m < COLS; ++m) { | 57 | 67.1k | to.Write(from.Read(n, m), m, n); | 58 | 67.1k | } | 59 | 33.5k | } | 60 | 16.7k | } |
Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 14.1k | size_t ROWSp, size_t COLSp) { | 53 | 14.1k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 14.1k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 42.3k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 141k | for (size_t m = 0; m < COLS; ++m) { | 57 | 113k | to.Write(from.Read(n, m), m, n); | 58 | 113k | } | 59 | 28.2k | } | 60 | 14.1k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 7.68k | size_t ROWSp, size_t COLSp) { | 53 | 7.68k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 7.68k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 38.4k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 92.2k | for (size_t m = 0; m < COLS; ++m) { | 57 | 61.5k | to.Write(from.Read(n, m), m, n); | 58 | 61.5k | } | 59 | 30.7k | } | 60 | 7.68k | } |
Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 14.8M | size_t ROWSp, size_t COLSp) { | 53 | 14.8M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 14.8M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 133M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 593M | for (size_t m = 0; m < COLS; ++m) { | 57 | 474M | to.Write(from.Read(n, m), m, n); | 58 | 474M | } | 59 | 118M | } | 60 | 14.8M | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 14.8M | size_t ROWSp, size_t COLSp) { | 53 | 14.8M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 14.8M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 74.1M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 534M | for (size_t m = 0; m < COLS; ++m) { | 57 | 474M | to.Write(from.Read(n, m), m, n); | 58 | 474M | } | 59 | 59.3M | } | 60 | 14.8M | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 16.9M | size_t ROWSp, size_t COLSp) { | 53 | 16.9M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 16.9M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 84.7M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 339M | for (size_t m = 0; m < COLS; ++m) { | 57 | 271M | to.Write(from.Read(n, m), m, n); | 58 | 271M | } | 59 | 67.8M | } | 60 | 16.9M | } |
Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 458k | size_t ROWSp, size_t COLSp) { | 53 | 458k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 458k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 2.29M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 16.5M | for (size_t m = 0; m < COLS; ++m) { | 57 | 14.6M | to.Write(from.Read(n, m), m, n); | 58 | 14.6M | } | 59 | 1.83M | } | 60 | 458k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 249k | size_t ROWSp, size_t COLSp) { | 53 | 249k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 249k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 2.24M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 9.99M | for (size_t m = 0; m < COLS; ++m) { | 57 | 7.99M | to.Write(from.Read(n, m), m, n); | 58 | 7.99M | } | 59 | 1.99M | } | 60 | 249k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 188k | size_t ROWSp, size_t COLSp) { | 53 | 188k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 188k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 943k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 3.77M | for (size_t m = 0; m < COLS; ++m) { | 57 | 3.02M | to.Write(from.Read(n, m), m, n); | 58 | 3.02M | } | 59 | 755k | } | 60 | 188k | } |
Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 133k | size_t ROWSp, size_t COLSp) { | 53 | 133k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 133k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 400k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 534k | for (size_t m = 0; m < COLS; ++m) { | 57 | 267k | to.Write(from.Read(n, m), m, n); | 58 | 267k | } | 59 | 267k | } | 60 | 133k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 74.7k | size_t ROWSp, size_t COLSp) { | 53 | 74.7k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 74.7k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 149k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 224k | for (size_t m = 0; m < COLS; ++m) { | 57 | 149k | to.Write(from.Read(n, m), m, n); | 58 | 149k | } | 59 | 74.7k | } | 60 | 74.7k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 50.5k | size_t ROWSp, size_t COLSp) { | 53 | 50.5k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 50.5k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 151k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 303k | for (size_t m = 0; m < COLS; ++m) { | 57 | 202k | to.Write(from.Read(n, m), m, n); | 58 | 202k | } | 59 | 101k | } | 60 | 50.5k | } |
Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 42.3k | size_t ROWSp, size_t COLSp) { | 53 | 42.3k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 42.3k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 211k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 508k | for (size_t m = 0; m < COLS; ++m) { | 57 | 339k | to.Write(from.Read(n, m), m, n); | 58 | 339k | } | 59 | 169k | } | 60 | 42.3k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 52 | 23.0k | size_t ROWSp, size_t COLSp) { | 53 | 23.0k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 23.0k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 69.2k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 230k | for (size_t m = 0; m < COLS; ++m) { | 57 | 184k | to.Write(from.Read(n, m), m, n); | 58 | 184k | } | 59 | 46.1k | } | 60 | 23.0k | } |
Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 1ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<1ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 1ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<1ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 2ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<2ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<false>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) |
61 | | |
62 | | // TODO(veluca): AVX3? |
63 | | #if HWY_CAP_GE256 |
64 | 0 | constexpr bool TransposeUseSimd(size_t ROWS, size_t COLS) { |
65 | 0 | return ROWS % 8 == 0 && COLS % 8 == 0; |
66 | 0 | } Unexecuted instantiation: enc_adaptive_quantization.cc:jxl::N_AVX2::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:jxl::N_AVX2::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:jxl::N_AVX2::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:jxl::N_AVX2::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:jxl::N_AVX2::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) |
67 | | |
68 | | template <size_t ROWS_or_0, size_t COLS_or_0, class From, class To> |
69 | | JXL_INLINE_TRANSPOSE void GenericTransposeBlock( |
70 | | TransposeSimdTag<true> /* tag */, const From& from, const To& to, |
71 | 12.1M | size_t ROWSp, size_t COLSp) { |
72 | 12.1M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; |
73 | 12.1M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; |
74 | 12.1M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); |
75 | 12.1M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); |
76 | 12.1M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); |
77 | 32.4M | for (size_t n = 0; n < ROWS; n += 8) { |
78 | 63.1M | for (size_t m = 0; m < COLS; m += 8) { |
79 | 42.8M | const BlockDesc<8> d; |
80 | 42.8M | auto i0 = from.LoadPart(d, n + 0, m + 0); |
81 | 42.8M | auto i1 = from.LoadPart(d, n + 1, m + 0); |
82 | 42.8M | auto i2 = from.LoadPart(d, n + 2, m + 0); |
83 | 42.8M | auto i3 = from.LoadPart(d, n + 3, m + 0); |
84 | 42.8M | auto i4 = from.LoadPart(d, n + 4, m + 0); |
85 | 42.8M | auto i5 = from.LoadPart(d, n + 5, m + 0); |
86 | 42.8M | auto i6 = from.LoadPart(d, n + 6, m + 0); |
87 | 42.8M | auto i7 = from.LoadPart(d, n + 7, m + 0); |
88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) |
89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. |
90 | 42.8M | const auto q0 = InterleaveLower(d, i0, i2); |
91 | 42.8M | const auto q1 = InterleaveLower(d, i1, i3); |
92 | 42.8M | const auto q2 = InterleaveUpper(d, i0, i2); |
93 | 42.8M | const auto q3 = InterleaveUpper(d, i1, i3); |
94 | 42.8M | const auto q4 = InterleaveLower(d, i4, i6); |
95 | 42.8M | const auto q5 = InterleaveLower(d, i5, i7); |
96 | 42.8M | const auto q6 = InterleaveUpper(d, i4, i6); |
97 | 42.8M | const auto q7 = InterleaveUpper(d, i5, i7); |
98 | | |
99 | 42.8M | const auto r0 = InterleaveLower(d, q0, q1); |
100 | 42.8M | const auto r1 = InterleaveUpper(d, q0, q1); |
101 | 42.8M | const auto r2 = InterleaveLower(d, q2, q3); |
102 | 42.8M | const auto r3 = InterleaveUpper(d, q2, q3); |
103 | 42.8M | const auto r4 = InterleaveLower(d, q4, q5); |
104 | 42.8M | const auto r5 = InterleaveUpper(d, q4, q5); |
105 | 42.8M | const auto r6 = InterleaveLower(d, q6, q7); |
106 | 42.8M | const auto r7 = InterleaveUpper(d, q6, q7); |
107 | | |
108 | 42.8M | i0 = ConcatLowerLower(d, r4, r0); |
109 | 42.8M | i1 = ConcatLowerLower(d, r5, r1); |
110 | 42.8M | i2 = ConcatLowerLower(d, r6, r2); |
111 | 42.8M | i3 = ConcatLowerLower(d, r7, r3); |
112 | 42.8M | i4 = ConcatUpperUpper(d, r4, r0); |
113 | 42.8M | i5 = ConcatUpperUpper(d, r5, r1); |
114 | 42.8M | i6 = ConcatUpperUpper(d, r6, r2); |
115 | 42.8M | i7 = ConcatUpperUpper(d, r7, r3); |
116 | 42.8M | to.StorePart(d, i0, m + 0, n + 0); |
117 | 42.8M | to.StorePart(d, i1, m + 1, n + 0); |
118 | 42.8M | to.StorePart(d, i2, m + 2, n + 0); |
119 | 42.8M | to.StorePart(d, i3, m + 3, n + 0); |
120 | 42.8M | to.StorePart(d, i4, m + 4, n + 0); |
121 | 42.8M | to.StorePart(d, i5, m + 5, n + 0); |
122 | 42.8M | to.StorePart(d, i6, m + 6, n + 0); |
123 | 42.8M | to.StorePart(d, i7, m + 7, n + 0); |
124 | 42.8M | } |
125 | 20.3M | } |
126 | 12.1M | } Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 16.7k | size_t ROWSp, size_t COLSp) { | 72 | 16.7k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 16.7k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 16.7k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 16.7k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 16.7k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 50.3k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 100k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 67.1k | const BlockDesc<8> d; | 80 | 67.1k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 67.1k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 67.1k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 67.1k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 67.1k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 67.1k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 67.1k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 67.1k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 67.1k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 67.1k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 67.1k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 67.1k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 67.1k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 67.1k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 67.1k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 67.1k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 67.1k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 67.1k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 67.1k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 67.1k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 67.1k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 67.1k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 67.1k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 67.1k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 67.1k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 67.1k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 67.1k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 67.1k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 67.1k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 67.1k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 67.1k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 67.1k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 67.1k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 67.1k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 67.1k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 67.1k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 67.1k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 67.1k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 67.1k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 67.1k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 67.1k | } | 125 | 33.5k | } | 126 | 16.7k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 41.9k | size_t ROWSp, size_t COLSp) { | 72 | 41.9k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 41.9k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 41.9k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 41.9k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 41.9k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 125k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 167k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 83.8k | const BlockDesc<8> d; | 80 | 83.8k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 83.8k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 83.8k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 83.8k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 83.8k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 83.8k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 83.8k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 83.8k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 83.8k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 83.8k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 83.8k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 83.8k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 83.8k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 83.8k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 83.8k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 83.8k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 83.8k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 83.8k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 83.8k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 83.8k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 83.8k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 83.8k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 83.8k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 83.8k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 83.8k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 83.8k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 83.8k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 83.8k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 83.8k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 83.8k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 83.8k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 83.8k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 83.8k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 83.8k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 83.8k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 83.8k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 83.8k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 83.8k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 83.8k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 83.8k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 83.8k | } | 125 | 83.8k | } | 126 | 41.9k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 22.3k | size_t ROWSp, size_t COLSp) { | 72 | 22.3k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 22.3k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 22.3k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 22.3k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 22.3k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 44.6k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 66.9k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 44.6k | const BlockDesc<8> d; | 80 | 44.6k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 44.6k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 44.6k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 44.6k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 44.6k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 44.6k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 44.6k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 44.6k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 44.6k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 44.6k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 44.6k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 44.6k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 44.6k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 44.6k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 44.6k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 44.6k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 44.6k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 44.6k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 44.6k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 44.6k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 44.6k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 44.6k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 44.6k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 44.6k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 44.6k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 44.6k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 44.6k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 44.6k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 44.6k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 44.6k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 44.6k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 44.6k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 44.6k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 44.6k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 44.6k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 44.6k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 44.6k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 44.6k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 44.6k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 44.6k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 44.6k | } | 125 | 22.3k | } | 126 | 22.3k | } |
Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 39.0k | size_t ROWSp, size_t COLSp) { | 72 | 39.0k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 39.0k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 39.0k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 39.0k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 39.0k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 186k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 665k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 518k | const BlockDesc<8> d; | 80 | 518k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 518k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 518k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 518k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 518k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 518k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 518k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 518k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 518k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 518k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 518k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 518k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 518k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 518k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 518k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 518k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 518k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 518k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 518k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 518k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 518k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 518k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 518k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 518k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 518k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 518k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 518k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 518k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 518k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 518k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 518k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 518k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 518k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 518k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 518k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 518k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 518k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 518k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 518k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 518k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 518k | } | 125 | 147k | } | 126 | 39.0k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 167k | size_t ROWSp, size_t COLSp) { | 72 | 167k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 167k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 167k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 167k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 167k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 334k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 334k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 167k | const BlockDesc<8> d; | 80 | 167k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 167k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 167k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 167k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 167k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 167k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 167k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 167k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 167k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 167k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 167k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 167k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 167k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 167k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 167k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 167k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 167k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 167k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 167k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 167k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 167k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 167k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 167k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 167k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 167k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 167k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 167k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 167k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 167k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 167k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 167k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 167k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 167k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 167k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 167k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 167k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 167k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 167k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 167k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 167k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 167k | } | 125 | 167k | } | 126 | 167k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 16.7k | size_t ROWSp, size_t COLSp) { | 72 | 16.7k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 16.7k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 16.7k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 16.7k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 16.7k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 50.3k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 100k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 67.1k | const BlockDesc<8> d; | 80 | 67.1k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 67.1k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 67.1k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 67.1k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 67.1k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 67.1k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 67.1k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 67.1k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 67.1k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 67.1k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 67.1k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 67.1k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 67.1k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 67.1k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 67.1k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 67.1k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 67.1k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 67.1k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 67.1k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 67.1k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 67.1k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 67.1k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 67.1k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 67.1k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 67.1k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 67.1k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 67.1k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 67.1k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 67.1k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 67.1k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 67.1k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 67.1k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 67.1k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 67.1k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 67.1k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 67.1k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 67.1k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 67.1k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 67.1k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 67.1k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 67.1k | } | 125 | 33.5k | } | 126 | 16.7k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 41.9k | size_t ROWSp, size_t COLSp) { | 72 | 41.9k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 41.9k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 41.9k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 41.9k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 41.9k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 125k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 167k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 83.8k | const BlockDesc<8> d; | 80 | 83.8k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 83.8k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 83.8k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 83.8k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 83.8k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 83.8k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 83.8k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 83.8k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 83.8k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 83.8k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 83.8k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 83.8k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 83.8k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 83.8k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 83.8k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 83.8k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 83.8k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 83.8k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 83.8k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 83.8k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 83.8k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 83.8k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 83.8k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 83.8k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 83.8k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 83.8k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 83.8k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 83.8k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 83.8k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 83.8k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 83.8k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 83.8k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 83.8k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 83.8k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 83.8k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 83.8k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 83.8k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 83.8k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 83.8k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 83.8k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 83.8k | } | 125 | 83.8k | } | 126 | 41.9k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 22.3k | size_t ROWSp, size_t COLSp) { | 72 | 22.3k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 22.3k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 22.3k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 22.3k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 22.3k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 44.6k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 66.9k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 44.6k | const BlockDesc<8> d; | 80 | 44.6k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 44.6k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 44.6k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 44.6k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 44.6k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 44.6k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 44.6k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 44.6k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 44.6k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 44.6k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 44.6k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 44.6k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 44.6k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 44.6k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 44.6k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 44.6k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 44.6k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 44.6k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 44.6k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 44.6k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 44.6k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 44.6k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 44.6k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 44.6k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 44.6k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 44.6k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 44.6k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 44.6k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 44.6k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 44.6k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 44.6k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 44.6k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 44.6k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 44.6k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 44.6k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 44.6k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 44.6k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 44.6k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 44.6k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 44.6k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 44.6k | } | 125 | 22.3k | } | 126 | 22.3k | } |
Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 39.0k | size_t ROWSp, size_t COLSp) { | 72 | 39.0k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 39.0k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 39.0k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 39.0k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 39.0k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 186k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 665k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 518k | const BlockDesc<8> d; | 80 | 518k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 518k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 518k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 518k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 518k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 518k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 518k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 518k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 518k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 518k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 518k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 518k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 518k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 518k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 518k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 518k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 518k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 518k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 518k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 518k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 518k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 518k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 518k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 518k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 518k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 518k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 518k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 518k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 518k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 518k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 518k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 518k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 518k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 518k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 518k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 518k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 518k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 518k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 518k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 518k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 518k | } | 125 | 147k | } | 126 | 39.0k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 1.22M | size_t ROWSp, size_t COLSp) { | 72 | 1.22M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 1.22M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 1.22M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 1.22M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 1.22M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 2.45M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 2.45M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 1.22M | const BlockDesc<8> d; | 80 | 1.22M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 1.22M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 1.22M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 1.22M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 1.22M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 1.22M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 1.22M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 1.22M | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 1.22M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 1.22M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 1.22M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 1.22M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 1.22M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 1.22M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 1.22M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 1.22M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 1.22M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 1.22M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 1.22M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 1.22M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 1.22M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 1.22M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 1.22M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 1.22M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 1.22M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 1.22M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 1.22M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 1.22M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 1.22M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 1.22M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 1.22M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 1.22M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 1.22M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 1.22M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 1.22M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 1.22M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 1.22M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 1.22M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 1.22M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 1.22M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 1.22M | } | 125 | 1.22M | } | 126 | 1.22M | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 839k | size_t ROWSp, size_t COLSp) { | 72 | 839k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 839k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 839k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 839k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 839k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 2.51M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 5.03M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 3.35M | const BlockDesc<8> d; | 80 | 3.35M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 3.35M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 3.35M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 3.35M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 3.35M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 3.35M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 3.35M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 3.35M | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 3.35M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 3.35M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 3.35M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 3.35M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 3.35M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 3.35M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 3.35M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 3.35M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 3.35M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 3.35M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 3.35M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 3.35M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 3.35M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 3.35M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 3.35M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 3.35M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 3.35M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 3.35M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 3.35M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 3.35M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 3.35M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 3.35M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 3.35M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 3.35M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 3.35M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 3.35M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 3.35M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 3.35M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 3.35M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 3.35M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 3.35M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 3.35M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 3.35M | } | 125 | 1.67M | } | 126 | 839k | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 2.48M | size_t ROWSp, size_t COLSp) { | 72 | 2.48M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 2.48M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 2.48M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 2.48M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 2.48M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 7.46M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 9.95M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 4.97M | const BlockDesc<8> d; | 80 | 4.97M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 4.97M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 4.97M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 4.97M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 4.97M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 4.97M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 4.97M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 4.97M | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 4.97M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 4.97M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 4.97M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 4.97M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 4.97M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 4.97M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 4.97M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 4.97M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 4.97M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 4.97M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 4.97M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 4.97M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 4.97M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 4.97M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 4.97M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 4.97M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 4.97M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 4.97M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 4.97M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 4.97M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 4.97M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 4.97M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 4.97M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 4.97M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 4.97M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 4.97M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 4.97M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 4.97M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 4.97M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 4.97M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 4.97M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 4.97M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 4.97M | } | 125 | 4.97M | } | 126 | 2.48M | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 2.48M | size_t ROWSp, size_t COLSp) { | 72 | 2.48M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 2.48M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 2.48M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 2.48M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 2.48M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 4.97M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 7.46M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 4.97M | const BlockDesc<8> d; | 80 | 4.97M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 4.97M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 4.97M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 4.97M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 4.97M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 4.97M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 4.97M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 4.97M | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 4.97M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 4.97M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 4.97M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 4.97M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 4.97M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 4.97M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 4.97M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 4.97M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 4.97M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 4.97M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 4.97M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 4.97M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 4.97M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 4.97M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 4.97M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 4.97M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 4.97M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 4.97M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 4.97M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 4.97M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 4.97M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 4.97M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 4.97M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 4.97M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 4.97M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 4.97M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 4.97M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 4.97M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 4.97M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 4.97M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 4.97M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 4.97M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 4.97M | } | 125 | 2.48M | } | 126 | 2.48M | } |
Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 1.48M | size_t ROWSp, size_t COLSp) { | 72 | 1.48M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 1.48M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 1.48M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 1.48M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 1.48M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 7.09M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 27.3M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 21.7M | const BlockDesc<8> d; | 80 | 21.7M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 21.7M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 21.7M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 21.7M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 21.7M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 21.7M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 21.7M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 21.7M | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 21.7M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 21.7M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 21.7M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 21.7M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 21.7M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 21.7M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 21.7M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 21.7M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 21.7M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 21.7M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 21.7M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 21.7M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 21.7M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 21.7M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 21.7M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 21.7M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 21.7M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 21.7M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 21.7M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 21.7M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 21.7M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 21.7M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 21.7M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 21.7M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 21.7M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 21.7M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 21.7M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 21.7M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 21.7M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 21.7M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 21.7M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 21.7M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 21.7M | } | 125 | 5.61M | } | 126 | 1.48M | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 2.11M | size_t ROWSp, size_t COLSp) { | 72 | 2.11M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 2.11M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 2.11M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 2.11M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 2.11M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 4.23M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 4.23M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 2.11M | const BlockDesc<8> d; | 80 | 2.11M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 2.11M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 2.11M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 2.11M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 2.11M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 2.11M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 2.11M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 2.11M | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 2.11M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 2.11M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 2.11M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 2.11M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 2.11M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 2.11M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 2.11M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 2.11M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 2.11M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 2.11M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 2.11M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 2.11M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 2.11M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 2.11M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 2.11M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 2.11M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 2.11M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 2.11M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 2.11M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 2.11M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 2.11M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 2.11M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 2.11M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 2.11M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 2.11M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 2.11M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 2.11M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 2.11M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 2.11M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 2.11M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 2.11M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 2.11M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 2.11M | } | 125 | 2.11M | } | 126 | 2.11M | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 50.5k | size_t ROWSp, size_t COLSp) { | 72 | 50.5k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 50.5k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 50.5k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 50.5k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 50.5k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 151k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 303k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 202k | const BlockDesc<8> d; | 80 | 202k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 202k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 202k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 202k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 202k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 202k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 202k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 202k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 202k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 202k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 202k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 202k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 202k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 202k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 202k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 202k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 202k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 202k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 202k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 202k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 202k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 202k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 202k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 202k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 202k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 202k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 202k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 202k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 202k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 202k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 202k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 202k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 202k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 202k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 202k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 202k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 202k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 202k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 202k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 202k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 202k | } | 125 | 101k | } | 126 | 50.5k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 133k | size_t ROWSp, size_t COLSp) { | 72 | 133k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 133k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 133k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 133k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 133k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 267k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 400k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 267k | const BlockDesc<8> d; | 80 | 267k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 267k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 267k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 267k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 267k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 267k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 267k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 267k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 267k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 267k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 267k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 267k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 267k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 267k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 267k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 267k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 267k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 267k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 267k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 267k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 267k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 267k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 267k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 267k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 267k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 267k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 267k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 267k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 267k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 267k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 267k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 267k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 267k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 267k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 267k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 267k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 267k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 267k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 267k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 267k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 267k | } | 125 | 133k | } | 126 | 133k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 74.7k | size_t ROWSp, size_t COLSp) { | 72 | 74.7k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 74.7k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 74.7k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 74.7k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 74.7k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 224k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 298k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 149k | const BlockDesc<8> d; | 80 | 149k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 149k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 149k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 149k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 149k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 149k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 149k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 149k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 149k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 149k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 149k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 149k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 149k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 149k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 149k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 149k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 149k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 149k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 149k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 149k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 149k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 149k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 149k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 149k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 149k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 149k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 149k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 149k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 149k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 149k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 149k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 149k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 149k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 149k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 149k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 149k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 149k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 149k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 149k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 149k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 149k | } | 125 | 149k | } | 126 | 74.7k | } |
Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 117k | size_t ROWSp, size_t COLSp) { | 72 | 117k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 117k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 117k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 117k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 117k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 518k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 1.95M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 1.55M | const BlockDesc<8> d; | 80 | 1.55M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 1.55M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 1.55M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 1.55M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 1.55M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 1.55M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 1.55M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 1.55M | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 1.55M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 1.55M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 1.55M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 1.55M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 1.55M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 1.55M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 1.55M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 1.55M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 1.55M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 1.55M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 1.55M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 1.55M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 1.55M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 1.55M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 1.55M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 1.55M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 1.55M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 1.55M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 1.55M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 1.55M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 1.55M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 1.55M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 1.55M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 1.55M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 1.55M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 1.55M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 1.55M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 1.55M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 1.55M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 1.55M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 1.55M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 1.55M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 1.55M | } | 125 | 400k | } | 126 | 117k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Line | Count | Source | 71 | 704k | size_t ROWSp, size_t COLSp) { | 72 | 704k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 704k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 704k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 704k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 704k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 1.40M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 1.40M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 704k | const BlockDesc<8> d; | 80 | 704k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 704k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 704k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 704k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 704k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 704k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 704k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 704k | auto i7 = from.LoadPart(d, n + 7, m + 0); | 88 | | // Surprisingly, this straightforward implementation (24 cycles on port5) | 89 | | // is faster than load128+insert and LoadDup128+ConcatUpperLower+blend. | 90 | 704k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 704k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 704k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 704k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 704k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 704k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 704k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 704k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 704k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 704k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 704k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 704k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 704k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 704k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 704k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 704k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 704k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 704k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 704k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 704k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 704k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 704k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 704k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 704k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 704k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 704k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 704k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 704k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 704k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 704k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 704k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 704k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 704k | } | 125 | 704k | } | 126 | 704k | } |
|
127 | | #elif HWY_TARGET != HWY_SCALAR |
128 | 0 | constexpr bool TransposeUseSimd(size_t ROWS, size_t COLS) { |
129 | 0 | return ROWS % 4 == 0 && COLS % 4 == 0; |
130 | 0 | } Unexecuted instantiation: enc_adaptive_quantization.cc:jxl::N_SSE4::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:jxl::N_SSE2::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:jxl::N_SSE4::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:jxl::N_SSE2::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:jxl::N_SSE4::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:jxl::N_SSE2::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:jxl::N_SSE4::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:jxl::N_SSE2::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:jxl::N_SSE4::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:jxl::N_SSE2::(anonymous namespace)::TransposeUseSimd(unsigned long, unsigned long) |
131 | | |
132 | | template <size_t ROWS_or_0, size_t COLS_or_0, class From, class To> |
133 | | JXL_INLINE_TRANSPOSE void GenericTransposeBlock( |
134 | | TransposeSimdTag<true> /* tag */, const From& from, const To& to, |
135 | 0 | size_t ROWSp, size_t COLSp) { |
136 | 0 | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; |
137 | 0 | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; |
138 | 0 | JXL_DASSERT(Lanes(BlockDesc<4>()) == 4); |
139 | 0 | static_assert(ROWS_or_0 % 4 == 0, "Invalid number of rows"); |
140 | 0 | static_assert(COLS_or_0 % 4 == 0, "Invalid number of columns"); |
141 | 0 | for (size_t n = 0; n < ROWS; n += 4) { |
142 | 0 | for (size_t m = 0; m < COLS; m += 4) { |
143 | 0 | const BlockDesc<4> d; |
144 | 0 | const auto p0 = from.LoadPart(d, n + 0, m + 0); |
145 | 0 | const auto p1 = from.LoadPart(d, n + 1, m + 0); |
146 | 0 | const auto p2 = from.LoadPart(d, n + 2, m + 0); |
147 | 0 | const auto p3 = from.LoadPart(d, n + 3, m + 0); |
148 | |
|
149 | 0 | const auto q0 = InterleaveLower(d, p0, p2); |
150 | 0 | const auto q1 = InterleaveLower(d, p1, p3); |
151 | 0 | const auto q2 = InterleaveUpper(d, p0, p2); |
152 | 0 | const auto q3 = InterleaveUpper(d, p1, p3); |
153 | |
|
154 | 0 | const auto r0 = InterleaveLower(d, q0, q1); |
155 | 0 | const auto r1 = InterleaveUpper(d, q0, q1); |
156 | 0 | const auto r2 = InterleaveLower(d, q2, q3); |
157 | 0 | const auto r3 = InterleaveUpper(d, q2, q3); |
158 | |
|
159 | 0 | to.StorePart(d, r0, m + 0, n + 0); |
160 | 0 | to.StorePart(d, r1, m + 1, n + 0); |
161 | 0 | to.StorePart(d, r2, m + 2, n + 0); |
162 | 0 | to.StorePart(d, r3, m + 3, n + 0); |
163 | 0 | } |
164 | 0 | } |
165 | 0 | } Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<4ul, 4ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<16ul, 16ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 16ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<16ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 32ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<32ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<0ul, 0ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::GenericTransposeBlock<8ul, 8ul, jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::TransposeSimdTag<true>, jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&, unsigned long, unsigned long) |
166 | | #else |
167 | | constexpr bool TransposeUseSimd(size_t ROWS, size_t COLS) { return false; } |
168 | | #endif |
169 | | |
170 | | template <size_t N, size_t M, typename = void> |
171 | | struct Transpose { |
172 | | template <typename From, typename To> |
173 | 59.0M | static void Run(const From& from, const To& to) { |
174 | | // This does not guarantee anything, just saves from the most stupid |
175 | | // mistakes. |
176 | 59.0M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); |
177 | 59.0M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; |
178 | 59.0M | GenericTransposeBlock<N, M>(tag, from, to, N, M); |
179 | 59.0M | } Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 151k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 151k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 151k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 151k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 151k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 81.6k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 81.6k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 81.6k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 81.6k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 81.6k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 60.2k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 60.2k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 60.2k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 60.2k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 60.2k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 16.7k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 16.7k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 16.7k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 16.7k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 16.7k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 41.9k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 41.9k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 41.9k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 41.9k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 41.9k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 22.3k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 22.3k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 22.3k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 22.3k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 22.3k | } |
Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 167k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 167k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 167k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 167k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 167k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 41.9k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 41.9k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 41.9k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 41.9k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 41.9k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 22.3k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 22.3k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 22.3k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 22.3k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 22.3k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 16.7k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 16.7k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 16.7k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 16.7k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 16.7k | } |
Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 14.1k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 14.1k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 14.1k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 14.1k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 14.1k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 7.68k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 7.68k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 7.68k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 7.68k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 7.68k | } |
Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 151k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 151k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 151k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 151k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 151k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 81.6k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 81.6k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 81.6k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 81.6k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 81.6k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 60.2k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 60.2k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 60.2k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 60.2k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 60.2k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 16.7k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 16.7k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 16.7k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 16.7k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 16.7k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 41.9k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 41.9k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 41.9k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 41.9k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 41.9k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 22.3k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 22.3k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 22.3k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 22.3k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 22.3k | } |
Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 1.22M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 1.22M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 1.22M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 1.22M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 1.22M | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 41.9k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 41.9k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 41.9k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 41.9k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 41.9k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 22.3k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 22.3k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 22.3k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 22.3k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 22.3k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 16.7k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 16.7k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 16.7k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 16.7k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 16.7k | } |
Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 14.1k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 14.1k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 14.1k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 14.1k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 14.1k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 7.68k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 7.68k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 7.68k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 7.68k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 7.68k | } |
Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 14.8M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 14.8M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 14.8M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 14.8M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 14.8M | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 14.8M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 14.8M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 14.8M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 14.8M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 14.8M | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 16.9M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 16.9M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 16.9M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 16.9M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 16.9M | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 839k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 839k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 839k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 839k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 839k | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 2.48M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 2.48M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 2.48M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 2.48M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 2.48M | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 2.48M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 2.48M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 2.48M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 2.48M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 2.48M | } |
Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 2.11M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 2.11M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 2.11M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 2.11M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 2.11M | } |
Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 458k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 458k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 458k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 458k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 458k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 249k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 249k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 249k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 249k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 249k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 188k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 188k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 188k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 188k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 188k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 50.5k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 50.5k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 50.5k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 50.5k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 50.5k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 133k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 133k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 133k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 133k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 133k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 74.7k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 74.7k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 74.7k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 74.7k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 74.7k | } |
Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 704k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 704k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 704k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 704k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 704k | } |
Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<8ul, 8ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 133k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 133k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 133k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 133k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 133k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 74.7k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 74.7k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 74.7k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 74.7k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 74.7k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 50.5k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 50.5k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 50.5k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 50.5k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 50.5k | } |
Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 42.3k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 42.3k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 42.3k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 42.3k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 42.3k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 173 | 23.0k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 23.0k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 23.0k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 23.0k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 23.0k | } |
Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 1ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<1ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 1ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<1ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<4ul, 2ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<2ul, 4ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) |
180 | | }; |
181 | | |
182 | | // Avoid inlining and unrolling transposes for large blocks. |
183 | | template <size_t N, size_t M> |
184 | | struct Transpose< |
185 | | N, M, typename std::enable_if<(N >= 8 && M >= 8 && N * M >= 512)>::type> { |
186 | | template <typename From, typename To> |
187 | 1.67M | static void Run(const From& from, const To& to) { |
188 | | // This does not guarantee anything, just saves from the most stupid |
189 | | // mistakes. |
190 | 1.67M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); |
191 | 1.67M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; |
192 | 1.67M | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, |
193 | 1.67M | const From&, const To&, size_t, size_t) = |
194 | 1.67M | GenericTransposeBlock<0, 0, From, To>; |
195 | 1.67M | NoInlineWrapper(transpose, tag, from, to, N, M); |
196 | 1.67M | } Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_adaptive_quantization.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 14.1k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 14.1k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 14.1k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 14.1k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 14.1k | const From&, const To&, size_t, size_t) = | 194 | 14.1k | GenericTransposeBlock<0, 0, From, To>; | 195 | 14.1k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 14.1k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 7.68k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 7.68k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 7.68k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 7.68k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 7.68k | const From&, const To&, size_t, size_t) = | 194 | 7.68k | GenericTransposeBlock<0, 0, From, To>; | 195 | 7.68k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 7.68k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 15.6k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 15.6k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 15.6k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 15.6k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 15.6k | const From&, const To&, size_t, size_t) = | 194 | 15.6k | GenericTransposeBlock<0, 0, From, To>; | 195 | 15.6k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 15.6k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 1.26k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 1.26k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 1.26k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 1.26k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 1.26k | const From&, const To&, size_t, size_t) = | 194 | 1.26k | GenericTransposeBlock<0, 0, From, To>; | 195 | 1.26k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 1.26k | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 294 | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 294 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 294 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 294 | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 294 | const From&, const To&, size_t, size_t) = | 194 | 294 | GenericTransposeBlock<0, 0, From, To>; | 195 | 294 | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 294 | } |
enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 96 | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 96 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 96 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 96 | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 96 | const From&, const To&, size_t, size_t) = | 194 | 96 | GenericTransposeBlock<0, 0, From, To>; | 195 | 96 | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 96 | } |
Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 14.1k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 14.1k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 14.1k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 14.1k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 14.1k | const From&, const To&, size_t, size_t) = | 194 | 14.1k | GenericTransposeBlock<0, 0, From, To>; | 195 | 14.1k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 14.1k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 7.68k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 7.68k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 7.68k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 7.68k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 7.68k | const From&, const To&, size_t, size_t) = | 194 | 7.68k | GenericTransposeBlock<0, 0, From, To>; | 195 | 7.68k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 7.68k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 15.6k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 15.6k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 15.6k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 15.6k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 15.6k | const From&, const To&, size_t, size_t) = | 194 | 15.6k | GenericTransposeBlock<0, 0, From, To>; | 195 | 15.6k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 15.6k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 1.26k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 1.26k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 1.26k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 1.26k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 1.26k | const From&, const To&, size_t, size_t) = | 194 | 1.26k | GenericTransposeBlock<0, 0, From, To>; | 195 | 1.26k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 1.26k | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 294 | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 294 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 294 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 294 | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 294 | const From&, const To&, size_t, size_t) = | 194 | 294 | GenericTransposeBlock<0, 0, From, To>; | 195 | 294 | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 294 | } |
enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 96 | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 96 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 96 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 96 | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 96 | const From&, const To&, size_t, size_t) = | 194 | 96 | GenericTransposeBlock<0, 0, From, To>; | 195 | 96 | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 96 | } |
Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_chroma_from_luma.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 497k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 497k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 497k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 497k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 497k | const From&, const To&, size_t, size_t) = | 194 | 497k | GenericTransposeBlock<0, 0, From, To>; | 195 | 497k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 497k | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 497k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 497k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 497k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 497k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 497k | const From&, const To&, size_t, size_t) = | 194 | 497k | GenericTransposeBlock<0, 0, From, To>; | 195 | 497k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 497k | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 172k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 172k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 172k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 172k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 172k | const From&, const To&, size_t, size_t) = | 194 | 172k | GenericTransposeBlock<0, 0, From, To>; | 195 | 172k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 172k | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 30.0k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 30.0k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 30.0k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 30.0k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 30.0k | const From&, const To&, size_t, size_t) = | 194 | 30.0k | GenericTransposeBlock<0, 0, From, To>; | 195 | 30.0k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 30.0k | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 141k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 141k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 141k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 141k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 141k | const From&, const To&, size_t, size_t) = | 194 | 141k | GenericTransposeBlock<0, 0, From, To>; | 195 | 141k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 141k | } |
enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 141k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 141k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 141k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 141k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 141k | const From&, const To&, size_t, size_t) = | 194 | 141k | GenericTransposeBlock<0, 0, From, To>; | 195 | 141k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 141k | } |
Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: enc_ac_strategy.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE4::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_SSE4::(anonymous namespace)::DCTFrom, jxl::N_SSE4::(anonymous namespace)::DCTTo>(jxl::N_SSE4::(anonymous namespace)::DCTFrom const&, jxl::N_SSE4::(anonymous namespace)::DCTTo const&) dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 42.3k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 42.3k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 42.3k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 42.3k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 42.3k | const From&, const To&, size_t, size_t) = | 194 | 42.3k | GenericTransposeBlock<0, 0, From, To>; | 195 | 42.3k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 42.3k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 23.0k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 23.0k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 23.0k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 23.0k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 23.0k | const From&, const To&, size_t, size_t) = | 194 | 23.0k | GenericTransposeBlock<0, 0, From, To>; | 195 | 23.0k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 23.0k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 46.8k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 46.8k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 46.8k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 46.8k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 46.8k | const From&, const To&, size_t, size_t) = | 194 | 46.8k | GenericTransposeBlock<0, 0, From, To>; | 195 | 46.8k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 46.8k | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 882 | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 882 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 882 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 882 | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 882 | const From&, const To&, size_t, size_t) = | 194 | 882 | GenericTransposeBlock<0, 0, From, To>; | 195 | 882 | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 882 | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 288 | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 288 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 288 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 288 | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 288 | const From&, const To&, size_t, size_t) = | 194 | 288 | GenericTransposeBlock<0, 0, From, To>; | 195 | 288 | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 288 | } |
dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Line | Count | Source | 187 | 3.80k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 3.80k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 3.80k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 3.80k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 3.80k | const From&, const To&, size_t, size_t) = | 194 | 3.80k | GenericTransposeBlock<0, 0, From, To>; | 195 | 3.80k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 3.80k | } |
Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_AVX2::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_AVX2::(anonymous namespace)::DCTFrom, jxl::N_AVX2::(anonymous namespace)::DCTTo>(jxl::N_AVX2::(anonymous namespace)::DCTFrom const&, jxl::N_AVX2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<16ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 16ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<32ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 32ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<64ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 64ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<128ul, 256ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<256ul, 128ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) Unexecuted instantiation: dec_group.cc:void jxl::N_SSE2::(anonymous namespace)::Transpose<256ul, 256ul, void>::Run<jxl::N_SSE2::(anonymous namespace)::DCTFrom, jxl::N_SSE2::(anonymous namespace)::DCTTo>(jxl::N_SSE2::(anonymous namespace)::DCTFrom const&, jxl::N_SSE2::(anonymous namespace)::DCTTo const&) |
197 | | }; |
198 | | |
199 | | } // namespace |
200 | | // NOLINTNEXTLINE(google-readability-namespace-comments) |
201 | | } // namespace HWY_NAMESPACE |
202 | | } // namespace jxl |
203 | | HWY_AFTER_NAMESPACE(); |
204 | | |
205 | | #endif // LIB_JXL_TRANSPOSE_INL_H_ |