/src/libjxl/lib/jxl/transpose-inl.h
Line | Count | Source |
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 | 101M | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { |
42 | 101M | return f(args...); |
43 | 101M | } 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 | 1.23M | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 1.23M | return f(args...); | 43 | 1.23M | } |
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 | 283k | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 283k | return f(args...); | 43 | 283k | } |
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 | 1.23M | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 1.23M | return f(args...); | 43 | 1.23M | } |
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 | 283k | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 283k | return f(args...); | 43 | 283k | } |
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 | 78.2M | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 78.2M | return f(args...); | 43 | 78.2M | } |
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 | 15.3M | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 15.3M | return f(args...); | 43 | 15.3M | } |
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 | 3.73M | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 3.73M | return f(args...); | 43 | 3.73M | } |
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 | 849k | JXL_NOINLINE void NoInlineWrapper(const T& f, const Args&... args) { | 42 | 849k | return f(args...); | 43 | 849k | } |
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 | 499M | size_t ROWSp, size_t COLSp) { |
53 | 499M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; |
54 | 499M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; |
55 | 3.11G | for (size_t n = 0; n < ROWS; ++n) { |
56 | 15.6G | for (size_t m = 0; m < COLS; ++m) { |
57 | 12.9G | to.Write(from.Read(n, m), m, n); |
58 | 12.9G | } |
59 | 2.61G | } |
60 | 499M | } 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 | 726k | size_t ROWSp, size_t COLSp) { | 53 | 726k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 726k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 6.53M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 29.0M | for (size_t m = 0; m < COLS; ++m) { | 57 | 23.2M | to.Write(from.Read(n, m), m, n); | 58 | 23.2M | } | 59 | 5.80M | } | 60 | 726k | } |
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 | 442k | size_t ROWSp, size_t COLSp) { | 53 | 442k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 442k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 2.21M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 15.9M | for (size_t m = 0; m < COLS; ++m) { | 57 | 14.1M | to.Write(from.Read(n, m), m, n); | 58 | 14.1M | } | 59 | 1.77M | } | 60 | 442k | } |
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 | 384k | size_t ROWSp, size_t COLSp) { | 53 | 384k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 384k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 1.92M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 7.69M | for (size_t m = 0; m < COLS; ++m) { | 57 | 6.15M | to.Write(from.Read(n, m), m, n); | 58 | 6.15M | } | 59 | 1.53M | } | 60 | 384k | } |
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 | 455k | size_t ROWSp, size_t COLSp) { | 53 | 455k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 455k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 911k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 1.36M | for (size_t m = 0; m < COLS; ++m) { | 57 | 911k | to.Write(from.Read(n, m), m, n); | 58 | 911k | } | 59 | 455k | } | 60 | 455k | } |
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 | 239k | size_t ROWSp, size_t COLSp) { | 53 | 239k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 239k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 717k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 957k | for (size_t m = 0; m < COLS; ++m) { | 57 | 478k | to.Write(from.Read(n, m), m, n); | 58 | 478k | } | 59 | 478k | } | 60 | 239k | } |
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 | 161k | size_t ROWSp, size_t COLSp) { | 53 | 161k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 161k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 484k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 969k | for (size_t m = 0; m < COLS; ++m) { | 57 | 646k | to.Write(from.Read(n, m), m, n); | 58 | 646k | } | 59 | 323k | } | 60 | 161k | } |
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 | 95.2k | size_t ROWSp, size_t COLSp) { | 53 | 95.2k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 95.2k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 285k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 952k | for (size_t m = 0; m < COLS; ++m) { | 57 | 762k | to.Write(from.Read(n, m), m, n); | 58 | 762k | } | 59 | 190k | } | 60 | 95.2k | } |
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 | 48.3k | size_t ROWSp, size_t COLSp) { | 53 | 48.3k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 48.3k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 241k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 580k | for (size_t m = 0; m < COLS; ++m) { | 57 | 386k | to.Write(from.Read(n, m), m, n); | 58 | 386k | } | 59 | 193k | } | 60 | 48.3k | } |
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 | 726k | size_t ROWSp, size_t COLSp) { | 53 | 726k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 726k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 6.53M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 29.0M | for (size_t m = 0; m < COLS; ++m) { | 57 | 23.2M | to.Write(from.Read(n, m), m, n); | 58 | 23.2M | } | 59 | 5.80M | } | 60 | 726k | } |
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 | 442k | size_t ROWSp, size_t COLSp) { | 53 | 442k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 442k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 2.21M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 15.9M | for (size_t m = 0; m < COLS; ++m) { | 57 | 14.1M | to.Write(from.Read(n, m), m, n); | 58 | 14.1M | } | 59 | 1.77M | } | 60 | 442k | } |
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 | 384k | size_t ROWSp, size_t COLSp) { | 53 | 384k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 384k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 1.92M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 7.69M | for (size_t m = 0; m < COLS; ++m) { | 57 | 6.15M | to.Write(from.Read(n, m), m, n); | 58 | 6.15M | } | 59 | 1.53M | } | 60 | 384k | } |
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 | 455k | size_t ROWSp, size_t COLSp) { | 53 | 455k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 455k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 911k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 1.36M | for (size_t m = 0; m < COLS; ++m) { | 57 | 911k | to.Write(from.Read(n, m), m, n); | 58 | 911k | } | 59 | 455k | } | 60 | 455k | } |
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 | 239k | size_t ROWSp, size_t COLSp) { | 53 | 239k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 239k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 717k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 957k | for (size_t m = 0; m < COLS; ++m) { | 57 | 478k | to.Write(from.Read(n, m), m, n); | 58 | 478k | } | 59 | 478k | } | 60 | 239k | } |
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 | 161k | size_t ROWSp, size_t COLSp) { | 53 | 161k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 161k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 484k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 969k | for (size_t m = 0; m < COLS; ++m) { | 57 | 646k | to.Write(from.Read(n, m), m, n); | 58 | 646k | } | 59 | 323k | } | 60 | 161k | } |
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 | 95.2k | size_t ROWSp, size_t COLSp) { | 53 | 95.2k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 95.2k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 285k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 952k | for (size_t m = 0; m < COLS; ++m) { | 57 | 762k | to.Write(from.Read(n, m), m, n); | 58 | 762k | } | 59 | 190k | } | 60 | 95.2k | } |
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 | 48.3k | size_t ROWSp, size_t COLSp) { | 53 | 48.3k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 48.3k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 241k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 580k | for (size_t m = 0; m < COLS; ++m) { | 57 | 386k | to.Write(from.Read(n, m), m, n); | 58 | 386k | } | 59 | 193k | } | 60 | 48.3k | } |
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 | 154M | size_t ROWSp, size_t COLSp) { | 53 | 154M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 154M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 1.39G | for (size_t n = 0; n < ROWS; ++n) { | 56 | 6.19G | for (size_t m = 0; m < COLS; ++m) { | 57 | 4.95G | to.Write(from.Read(n, m), m, n); | 58 | 4.95G | } | 59 | 1.23G | } | 60 | 154M | } |
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 | 154M | size_t ROWSp, size_t COLSp) { | 53 | 154M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 154M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 774M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 5.57G | for (size_t m = 0; m < COLS; ++m) { | 57 | 4.95G | to.Write(from.Read(n, m), m, n); | 58 | 4.95G | } | 59 | 619M | } | 60 | 154M | } |
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 | 177M | size_t ROWSp, size_t COLSp) { | 53 | 177M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 177M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 885M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 3.54G | for (size_t m = 0; m < COLS; ++m) { | 57 | 2.83G | to.Write(from.Read(n, m), m, n); | 58 | 2.83G | } | 59 | 708M | } | 60 | 177M | } |
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 | 2.18M | size_t ROWSp, size_t COLSp) { | 53 | 2.18M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 2.18M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 10.9M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 78.8M | for (size_t m = 0; m < COLS; ++m) { | 57 | 70.0M | to.Write(from.Read(n, m), m, n); | 58 | 70.0M | } | 59 | 8.75M | } | 60 | 2.18M | } |
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 | 1.34M | size_t ROWSp, size_t COLSp) { | 53 | 1.34M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 1.34M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 12.0M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 53.6M | for (size_t m = 0; m < COLS; ++m) { | 57 | 42.8M | to.Write(from.Read(n, m), m, n); | 58 | 42.8M | } | 59 | 10.7M | } | 60 | 1.34M | } |
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 | 1.16M | size_t ROWSp, size_t COLSp) { | 53 | 1.16M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 1.16M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 5.83M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 23.3M | for (size_t m = 0; m < COLS; ++m) { | 57 | 18.6M | to.Write(from.Read(n, m), m, n); | 58 | 18.6M | } | 59 | 4.66M | } | 60 | 1.16M | } |
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 | 1.37M | size_t ROWSp, size_t COLSp) { | 53 | 1.37M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 1.37M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 4.13M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 5.51M | for (size_t m = 0; m < COLS; ++m) { | 57 | 2.75M | to.Write(from.Read(n, m), m, n); | 58 | 2.75M | } | 59 | 2.75M | } | 60 | 1.37M | } |
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 | 726k | size_t ROWSp, size_t COLSp) { | 53 | 726k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 726k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 1.45M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 2.18M | for (size_t m = 0; m < COLS; ++m) { | 57 | 1.45M | to.Write(from.Read(n, m), m, n); | 58 | 1.45M | } | 59 | 726k | } | 60 | 726k | } |
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 | 485k | size_t ROWSp, size_t COLSp) { | 53 | 485k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 485k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 1.45M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 2.91M | for (size_t m = 0; m < COLS; ++m) { | 57 | 1.94M | to.Write(from.Read(n, m), m, n); | 58 | 1.94M | } | 59 | 971k | } | 60 | 485k | } |
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) Line | Count | Source | 52 | 789 | size_t ROWSp, size_t COLSp) { | 53 | 789 | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 789 | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 3.94k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 6.31k | for (size_t m = 0; m < COLS; ++m) { | 57 | 3.15k | to.Write(from.Read(n, m), m, n); | 58 | 3.15k | } | 59 | 3.15k | } | 60 | 789 | } |
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) Line | Count | Source | 52 | 96 | size_t ROWSp, size_t COLSp) { | 53 | 96 | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 96 | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 192 | for (size_t n = 0; n < ROWS; ++n) { | 56 | 480 | for (size_t m = 0; m < COLS; ++m) { | 57 | 384 | to.Write(from.Read(n, m), m, n); | 58 | 384 | } | 59 | 96 | } | 60 | 96 | } |
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 | 285k | size_t ROWSp, size_t COLSp) { | 53 | 285k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 285k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 1.42M | for (size_t n = 0; n < ROWS; ++n) { | 56 | 3.43M | for (size_t m = 0; m < COLS; ++m) { | 57 | 2.28M | to.Write(from.Read(n, m), m, n); | 58 | 2.28M | } | 59 | 1.14M | } | 60 | 285k | } |
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 | 145k | size_t ROWSp, size_t COLSp) { | 53 | 145k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 54 | 145k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 55 | 435k | for (size_t n = 0; n < ROWS; ++n) { | 56 | 1.45M | for (size_t m = 0; m < COLS; ++m) { | 57 | 1.16M | to.Write(from.Read(n, m), m, n); | 58 | 1.16M | } | 59 | 290k | } | 60 | 145k | } |
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 | 127M | size_t ROWSp, size_t COLSp) { |
72 | 127M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; |
73 | 127M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; |
74 | 127M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); |
75 | 127M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); |
76 | 127M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); |
77 | 340M | for (size_t n = 0; n < ROWS; n += 8) { |
78 | 656M | for (size_t m = 0; m < COLS; m += 8) { |
79 | 443M | const BlockDesc<8> d; |
80 | 443M | auto i0 = from.LoadPart(d, n + 0, m + 0); |
81 | 443M | auto i1 = from.LoadPart(d, n + 1, m + 0); |
82 | 443M | auto i2 = from.LoadPart(d, n + 2, m + 0); |
83 | 443M | auto i3 = from.LoadPart(d, n + 3, m + 0); |
84 | 443M | auto i4 = from.LoadPart(d, n + 4, m + 0); |
85 | 443M | auto i5 = from.LoadPart(d, n + 5, m + 0); |
86 | 443M | auto i6 = from.LoadPart(d, n + 6, m + 0); |
87 | 443M | 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 | 443M | const auto q0 = InterleaveLower(d, i0, i2); |
91 | 443M | const auto q1 = InterleaveLower(d, i1, i3); |
92 | 443M | const auto q2 = InterleaveUpper(d, i0, i2); |
93 | 443M | const auto q3 = InterleaveUpper(d, i1, i3); |
94 | 443M | const auto q4 = InterleaveLower(d, i4, i6); |
95 | 443M | const auto q5 = InterleaveLower(d, i5, i7); |
96 | 443M | const auto q6 = InterleaveUpper(d, i4, i6); |
97 | 443M | const auto q7 = InterleaveUpper(d, i5, i7); |
98 | | |
99 | 443M | const auto r0 = InterleaveLower(d, q0, q1); |
100 | 443M | const auto r1 = InterleaveUpper(d, q0, q1); |
101 | 443M | const auto r2 = InterleaveLower(d, q2, q3); |
102 | 443M | const auto r3 = InterleaveUpper(d, q2, q3); |
103 | 443M | const auto r4 = InterleaveLower(d, q4, q5); |
104 | 443M | const auto r5 = InterleaveUpper(d, q4, q5); |
105 | 443M | const auto r6 = InterleaveLower(d, q6, q7); |
106 | 443M | const auto r7 = InterleaveUpper(d, q6, q7); |
107 | | |
108 | 443M | i0 = ConcatLowerLower(d, r4, r0); |
109 | 443M | i1 = ConcatLowerLower(d, r5, r1); |
110 | 443M | i2 = ConcatLowerLower(d, r6, r2); |
111 | 443M | i3 = ConcatLowerLower(d, r7, r3); |
112 | 443M | i4 = ConcatUpperUpper(d, r4, r0); |
113 | 443M | i5 = ConcatUpperUpper(d, r5, r1); |
114 | 443M | i6 = ConcatUpperUpper(d, r6, r2); |
115 | 443M | i7 = ConcatUpperUpper(d, r7, r3); |
116 | 443M | to.StorePart(d, i0, m + 0, n + 0); |
117 | 443M | to.StorePart(d, i1, m + 1, n + 0); |
118 | 443M | to.StorePart(d, i2, m + 2, n + 0); |
119 | 443M | to.StorePart(d, i3, m + 3, n + 0); |
120 | 443M | to.StorePart(d, i4, m + 4, n + 0); |
121 | 443M | to.StorePart(d, i5, m + 5, n + 0); |
122 | 443M | to.StorePart(d, i6, m + 6, n + 0); |
123 | 443M | to.StorePart(d, i7, m + 7, n + 0); |
124 | 443M | } |
125 | 213M | } |
126 | 127M | } 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 | 161k | size_t ROWSp, size_t COLSp) { | 72 | 161k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 161k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 161k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 161k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 161k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 484k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 969k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 646k | const BlockDesc<8> d; | 80 | 646k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 646k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 646k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 646k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 646k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 646k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 646k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 646k | 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 | 646k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 646k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 646k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 646k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 646k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 646k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 646k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 646k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 646k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 646k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 646k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 646k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 646k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 646k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 646k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 646k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 646k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 646k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 646k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 646k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 646k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 646k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 646k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 646k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 646k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 646k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 646k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 646k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 646k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 646k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 646k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 646k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 646k | } | 125 | 323k | } | 126 | 161k | } |
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 | 455k | size_t ROWSp, size_t COLSp) { | 72 | 455k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 455k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 455k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 455k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 455k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 1.36M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 1.82M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 911k | const BlockDesc<8> d; | 80 | 911k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 911k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 911k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 911k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 911k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 911k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 911k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 911k | 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 | 911k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 911k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 911k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 911k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 911k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 911k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 911k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 911k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 911k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 911k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 911k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 911k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 911k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 911k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 911k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 911k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 911k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 911k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 911k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 911k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 911k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 911k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 911k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 911k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 911k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 911k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 911k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 911k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 911k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 911k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 911k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 911k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 911k | } | 125 | 911k | } | 126 | 455k | } |
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 | 239k | size_t ROWSp, size_t COLSp) { | 72 | 239k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 239k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 239k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 239k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 239k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 478k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 717k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 478k | const BlockDesc<8> d; | 80 | 478k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 478k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 478k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 478k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 478k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 478k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 478k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 478k | 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 | 478k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 478k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 478k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 478k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 478k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 478k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 478k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 478k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 478k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 478k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 478k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 478k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 478k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 478k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 478k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 478k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 478k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 478k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 478k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 478k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 478k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 478k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 478k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 478k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 478k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 478k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 478k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 478k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 478k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 478k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 478k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 478k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 478k | } | 125 | 239k | } | 126 | 239k | } |
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 | 283k | size_t ROWSp, size_t COLSp) { | 72 | 283k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 283k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 283k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 283k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 283k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 1.52M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 6.56M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 5.32M | const BlockDesc<8> d; | 80 | 5.32M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 5.32M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 5.32M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 5.32M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 5.32M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 5.32M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 5.32M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 5.32M | 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 | 5.32M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 5.32M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 5.32M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 5.32M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 5.32M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 5.32M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 5.32M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 5.32M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 5.32M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 5.32M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 5.32M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 5.32M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 5.32M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 5.32M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 5.32M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 5.32M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 5.32M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 5.32M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 5.32M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 5.32M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 5.32M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 5.32M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 5.32M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 5.32M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 5.32M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 5.32M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 5.32M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 5.32M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 5.32M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 5.32M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 5.32M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 5.32M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 5.32M | } | 125 | 1.23M | } | 126 | 283k | } |
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 | 1.55M | size_t ROWSp, size_t COLSp) { | 72 | 1.55M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 1.55M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 1.55M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 1.55M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 1.55M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 3.11M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 3.11M | 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 | 1.55M | } | 126 | 1.55M | } |
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 | 161k | size_t ROWSp, size_t COLSp) { | 72 | 161k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 161k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 161k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 161k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 161k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 484k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 969k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 646k | const BlockDesc<8> d; | 80 | 646k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 646k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 646k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 646k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 646k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 646k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 646k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 646k | 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 | 646k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 646k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 646k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 646k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 646k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 646k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 646k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 646k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 646k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 646k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 646k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 646k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 646k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 646k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 646k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 646k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 646k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 646k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 646k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 646k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 646k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 646k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 646k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 646k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 646k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 646k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 646k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 646k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 646k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 646k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 646k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 646k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 646k | } | 125 | 323k | } | 126 | 161k | } |
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 | 455k | size_t ROWSp, size_t COLSp) { | 72 | 455k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 455k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 455k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 455k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 455k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 1.36M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 1.82M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 911k | const BlockDesc<8> d; | 80 | 911k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 911k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 911k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 911k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 911k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 911k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 911k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 911k | 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 | 911k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 911k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 911k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 911k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 911k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 911k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 911k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 911k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 911k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 911k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 911k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 911k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 911k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 911k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 911k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 911k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 911k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 911k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 911k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 911k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 911k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 911k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 911k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 911k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 911k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 911k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 911k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 911k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 911k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 911k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 911k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 911k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 911k | } | 125 | 911k | } | 126 | 455k | } |
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 | 239k | size_t ROWSp, size_t COLSp) { | 72 | 239k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 239k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 239k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 239k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 239k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 478k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 717k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 478k | const BlockDesc<8> d; | 80 | 478k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 478k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 478k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 478k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 478k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 478k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 478k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 478k | 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 | 478k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 478k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 478k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 478k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 478k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 478k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 478k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 478k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 478k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 478k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 478k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 478k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 478k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 478k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 478k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 478k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 478k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 478k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 478k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 478k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 478k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 478k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 478k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 478k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 478k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 478k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 478k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 478k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 478k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 478k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 478k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 478k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 478k | } | 125 | 239k | } | 126 | 239k | } |
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 | 283k | size_t ROWSp, size_t COLSp) { | 72 | 283k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 283k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 283k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 283k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 283k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 1.52M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 6.56M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 5.32M | const BlockDesc<8> d; | 80 | 5.32M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 5.32M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 5.32M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 5.32M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 5.32M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 5.32M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 5.32M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 5.32M | 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 | 5.32M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 5.32M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 5.32M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 5.32M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 5.32M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 5.32M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 5.32M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 5.32M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 5.32M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 5.32M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 5.32M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 5.32M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 5.32M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 5.32M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 5.32M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 5.32M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 5.32M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 5.32M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 5.32M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 5.32M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 5.32M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 5.32M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 5.32M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 5.32M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 5.32M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 5.32M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 5.32M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 5.32M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 5.32M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 5.32M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 5.32M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 5.32M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 5.32M | } | 125 | 1.23M | } | 126 | 283k | } |
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 | 12.6M | size_t ROWSp, size_t COLSp) { | 72 | 12.6M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 12.6M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 12.6M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 12.6M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 12.6M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 25.2M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 25.2M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 12.6M | const BlockDesc<8> d; | 80 | 12.6M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 12.6M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 12.6M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 12.6M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 12.6M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 12.6M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 12.6M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 12.6M | 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 | 12.6M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 12.6M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 12.6M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 12.6M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 12.6M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 12.6M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 12.6M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 12.6M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 12.6M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 12.6M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 12.6M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 12.6M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 12.6M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 12.6M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 12.6M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 12.6M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 12.6M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 12.6M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 12.6M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 12.6M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 12.6M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 12.6M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 12.6M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 12.6M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 12.6M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 12.6M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 12.6M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 12.6M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 12.6M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 12.6M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 12.6M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 12.6M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 12.6M | } | 125 | 12.6M | } | 126 | 12.6M | } |
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 | 9.43M | size_t ROWSp, size_t COLSp) { | 72 | 9.43M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 9.43M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 9.43M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 9.43M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 9.43M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 28.2M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 56.5M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 37.7M | const BlockDesc<8> d; | 80 | 37.7M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 37.7M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 37.7M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 37.7M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 37.7M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 37.7M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 37.7M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 37.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 | 37.7M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 37.7M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 37.7M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 37.7M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 37.7M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 37.7M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 37.7M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 37.7M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 37.7M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 37.7M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 37.7M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 37.7M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 37.7M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 37.7M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 37.7M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 37.7M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 37.7M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 37.7M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 37.7M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 37.7M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 37.7M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 37.7M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 37.7M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 37.7M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 37.7M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 37.7M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 37.7M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 37.7M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 37.7M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 37.7M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 37.7M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 37.7M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 37.7M | } | 125 | 18.8M | } | 126 | 9.43M | } |
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 | 27.8M | size_t ROWSp, size_t COLSp) { | 72 | 27.8M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 27.8M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 27.8M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 27.8M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 27.8M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 83.4M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 111M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 55.6M | const BlockDesc<8> d; | 80 | 55.6M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 55.6M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 55.6M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 55.6M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 55.6M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 55.6M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 55.6M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 55.6M | 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 | 55.6M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 55.6M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 55.6M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 55.6M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 55.6M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 55.6M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 55.6M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 55.6M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 55.6M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 55.6M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 55.6M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 55.6M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 55.6M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 55.6M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 55.6M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 55.6M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 55.6M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 55.6M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 55.6M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 55.6M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 55.6M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 55.6M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 55.6M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 55.6M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 55.6M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 55.6M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 55.6M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 55.6M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 55.6M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 55.6M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 55.6M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 55.6M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 55.6M | } | 125 | 55.6M | } | 126 | 27.8M | } |
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 | 27.8M | size_t ROWSp, size_t COLSp) { | 72 | 27.8M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 27.8M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 27.8M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 27.8M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 27.8M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 55.6M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 83.4M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 55.6M | const BlockDesc<8> d; | 80 | 55.6M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 55.6M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 55.6M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 55.6M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 55.6M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 55.6M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 55.6M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 55.6M | 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 | 55.6M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 55.6M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 55.6M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 55.6M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 55.6M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 55.6M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 55.6M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 55.6M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 55.6M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 55.6M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 55.6M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 55.6M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 55.6M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 55.6M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 55.6M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 55.6M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 55.6M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 55.6M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 55.6M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 55.6M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 55.6M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 55.6M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 55.6M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 55.6M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 55.6M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 55.6M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 55.6M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 55.6M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 55.6M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 55.6M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 55.6M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 55.6M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 55.6M | } | 125 | 27.8M | } | 126 | 27.8M | } |
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 | 15.3M | size_t ROWSp, size_t COLSp) { | 72 | 15.3M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 15.3M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 15.3M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 15.3M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 15.3M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 72.5M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 273M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 216M | const BlockDesc<8> d; | 80 | 216M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 216M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 216M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 216M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 216M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 216M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 216M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 216M | 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 | 216M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 216M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 216M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 216M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 216M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 216M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 216M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 216M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 216M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 216M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 216M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 216M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 216M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 216M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 216M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 216M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 216M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 216M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 216M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 216M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 216M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 216M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 216M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 216M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 216M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 216M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 216M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 216M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 216M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 216M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 216M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 216M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 216M | } | 125 | 57.1M | } | 126 | 15.3M | } |
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 | 22.1M | size_t ROWSp, size_t COLSp) { | 72 | 22.1M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 22.1M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 22.1M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 22.1M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 22.1M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 44.2M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 44.2M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 22.1M | const BlockDesc<8> d; | 80 | 22.1M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 22.1M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 22.1M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 22.1M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 22.1M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 22.1M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 22.1M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 22.1M | 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 | 22.1M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 22.1M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 22.1M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 22.1M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 22.1M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 22.1M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 22.1M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 22.1M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 22.1M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 22.1M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 22.1M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 22.1M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 22.1M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 22.1M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 22.1M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 22.1M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 22.1M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 22.1M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 22.1M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 22.1M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 22.1M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 22.1M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 22.1M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 22.1M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 22.1M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 22.1M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 22.1M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 22.1M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 22.1M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 22.1M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 22.1M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 22.1M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 22.1M | } | 125 | 22.1M | } | 126 | 22.1M | } |
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 | 485k | size_t ROWSp, size_t COLSp) { | 72 | 485k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 485k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 485k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 485k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 485k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 1.45M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 2.91M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 1.94M | const BlockDesc<8> d; | 80 | 1.94M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 1.94M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 1.94M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 1.94M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 1.94M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 1.94M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 1.94M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 1.94M | 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.94M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 1.94M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 1.94M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 1.94M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 1.94M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 1.94M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 1.94M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 1.94M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 1.94M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 1.94M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 1.94M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 1.94M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 1.94M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 1.94M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 1.94M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 1.94M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 1.94M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 1.94M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 1.94M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 1.94M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 1.94M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 1.94M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 1.94M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 1.94M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 1.94M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 1.94M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 1.94M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 1.94M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 1.94M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 1.94M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 1.94M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 1.94M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 1.94M | } | 125 | 971k | } | 126 | 485k | } |
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 | 1.37M | size_t ROWSp, size_t COLSp) { | 72 | 1.37M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 1.37M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 1.37M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 1.37M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 1.37M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 2.75M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 4.13M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 2.75M | const BlockDesc<8> d; | 80 | 2.75M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 2.75M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 2.75M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 2.75M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 2.75M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 2.75M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 2.75M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 2.75M | 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.75M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 2.75M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 2.75M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 2.75M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 2.75M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 2.75M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 2.75M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 2.75M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 2.75M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 2.75M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 2.75M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 2.75M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 2.75M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 2.75M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 2.75M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 2.75M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 2.75M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 2.75M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 2.75M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 2.75M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 2.75M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 2.75M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 2.75M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 2.75M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 2.75M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 2.75M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 2.75M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 2.75M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 2.75M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 2.75M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 2.75M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 2.75M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 2.75M | } | 125 | 1.37M | } | 126 | 1.37M | } |
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 | 726k | size_t ROWSp, size_t COLSp) { | 72 | 726k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 726k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 726k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 726k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 726k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 2.18M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 2.90M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 1.45M | const BlockDesc<8> d; | 80 | 1.45M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 1.45M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 1.45M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 1.45M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 1.45M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 1.45M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 1.45M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 1.45M | 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.45M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 1.45M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 1.45M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 1.45M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 1.45M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 1.45M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 1.45M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 1.45M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 1.45M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 1.45M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 1.45M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 1.45M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 1.45M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 1.45M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 1.45M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 1.45M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 1.45M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 1.45M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 1.45M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 1.45M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 1.45M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 1.45M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 1.45M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 1.45M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 1.45M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 1.45M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 1.45M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 1.45M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 1.45M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 1.45M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 1.45M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 1.45M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 1.45M | } | 125 | 1.45M | } | 126 | 726k | } |
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) Line | Count | Source | 71 | 789 | size_t ROWSp, size_t COLSp) { | 72 | 789 | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 789 | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 789 | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 789 | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 789 | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 1.57k | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 3.94k | for (size_t m = 0; m < COLS; m += 8) { | 79 | 3.15k | const BlockDesc<8> d; | 80 | 3.15k | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 3.15k | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 3.15k | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 3.15k | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 3.15k | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 3.15k | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 3.15k | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 3.15k | 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.15k | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 3.15k | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 3.15k | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 3.15k | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 3.15k | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 3.15k | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 3.15k | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 3.15k | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 3.15k | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 3.15k | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 3.15k | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 3.15k | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 3.15k | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 3.15k | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 3.15k | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 3.15k | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 3.15k | i0 = ConcatLowerLower(d, r4, r0); | 109 | 3.15k | i1 = ConcatLowerLower(d, r5, r1); | 110 | 3.15k | i2 = ConcatLowerLower(d, r6, r2); | 111 | 3.15k | i3 = ConcatLowerLower(d, r7, r3); | 112 | 3.15k | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 3.15k | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 3.15k | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 3.15k | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 3.15k | to.StorePart(d, i0, m + 0, n + 0); | 117 | 3.15k | to.StorePart(d, i1, m + 1, n + 0); | 118 | 3.15k | to.StorePart(d, i2, m + 2, n + 0); | 119 | 3.15k | to.StorePart(d, i3, m + 3, n + 0); | 120 | 3.15k | to.StorePart(d, i4, m + 4, n + 0); | 121 | 3.15k | to.StorePart(d, i5, m + 5, n + 0); | 122 | 3.15k | to.StorePart(d, i6, m + 6, n + 0); | 123 | 3.15k | to.StorePart(d, i7, m + 7, n + 0); | 124 | 3.15k | } | 125 | 789 | } | 126 | 789 | } |
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) Line | Count | Source | 71 | 96 | size_t ROWSp, size_t COLSp) { | 72 | 96 | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 96 | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 96 | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 96 | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 96 | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 480 | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 768 | for (size_t m = 0; m < COLS; m += 8) { | 79 | 384 | const BlockDesc<8> d; | 80 | 384 | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 384 | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 384 | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 384 | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 384 | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 384 | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 384 | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 384 | 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 | 384 | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 384 | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 384 | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 384 | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 384 | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 384 | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 384 | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 384 | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 384 | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 384 | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 384 | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 384 | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 384 | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 384 | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 384 | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 384 | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 384 | i0 = ConcatLowerLower(d, r4, r0); | 109 | 384 | i1 = ConcatLowerLower(d, r5, r1); | 110 | 384 | i2 = ConcatLowerLower(d, r6, r2); | 111 | 384 | i3 = ConcatLowerLower(d, r7, r3); | 112 | 384 | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 384 | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 384 | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 384 | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 384 | to.StorePart(d, i0, m + 0, n + 0); | 117 | 384 | to.StorePart(d, i1, m + 1, n + 0); | 118 | 384 | to.StorePart(d, i2, m + 2, n + 0); | 119 | 384 | to.StorePart(d, i3, m + 3, n + 0); | 120 | 384 | to.StorePart(d, i4, m + 4, n + 0); | 121 | 384 | to.StorePart(d, i5, m + 5, n + 0); | 122 | 384 | to.StorePart(d, i6, m + 6, n + 0); | 123 | 384 | to.StorePart(d, i7, m + 7, n + 0); | 124 | 384 | } | 125 | 384 | } | 126 | 96 | } |
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 | 849k | size_t ROWSp, size_t COLSp) { | 72 | 849k | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 849k | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 849k | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 849k | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 849k | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 4.13M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 19.2M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 15.9M | const BlockDesc<8> d; | 80 | 15.9M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 15.9M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 15.9M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 15.9M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 15.9M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 15.9M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 15.9M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 15.9M | 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 | 15.9M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 15.9M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 15.9M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 15.9M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 15.9M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 15.9M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 15.9M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 15.9M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 15.9M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 15.9M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 15.9M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 15.9M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 15.9M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 15.9M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 15.9M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 15.9M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 15.9M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 15.9M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 15.9M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 15.9M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 15.9M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 15.9M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 15.9M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 15.9M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 15.9M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 15.9M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 15.9M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 15.9M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 15.9M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 15.9M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 15.9M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 15.9M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 15.9M | } | 125 | 3.28M | } | 126 | 849k | } |
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 | 5.03M | size_t ROWSp, size_t COLSp) { | 72 | 5.03M | size_t ROWS = ROWS_or_0 == 0 ? ROWSp : ROWS_or_0; | 73 | 5.03M | size_t COLS = COLS_or_0 == 0 ? COLSp : COLS_or_0; | 74 | 5.03M | JXL_DASSERT(Lanes(BlockDesc<8>()) == 8); | 75 | 5.03M | static_assert(ROWS_or_0 % 8 == 0, "Invalid number of rows"); | 76 | 5.03M | static_assert(COLS_or_0 % 8 == 0, "Invalid number of columns"); | 77 | 10.0M | for (size_t n = 0; n < ROWS; n += 8) { | 78 | 10.0M | for (size_t m = 0; m < COLS; m += 8) { | 79 | 5.03M | const BlockDesc<8> d; | 80 | 5.03M | auto i0 = from.LoadPart(d, n + 0, m + 0); | 81 | 5.03M | auto i1 = from.LoadPart(d, n + 1, m + 0); | 82 | 5.03M | auto i2 = from.LoadPart(d, n + 2, m + 0); | 83 | 5.03M | auto i3 = from.LoadPart(d, n + 3, m + 0); | 84 | 5.03M | auto i4 = from.LoadPart(d, n + 4, m + 0); | 85 | 5.03M | auto i5 = from.LoadPart(d, n + 5, m + 0); | 86 | 5.03M | auto i6 = from.LoadPart(d, n + 6, m + 0); | 87 | 5.03M | 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 | 5.03M | const auto q0 = InterleaveLower(d, i0, i2); | 91 | 5.03M | const auto q1 = InterleaveLower(d, i1, i3); | 92 | 5.03M | const auto q2 = InterleaveUpper(d, i0, i2); | 93 | 5.03M | const auto q3 = InterleaveUpper(d, i1, i3); | 94 | 5.03M | const auto q4 = InterleaveLower(d, i4, i6); | 95 | 5.03M | const auto q5 = InterleaveLower(d, i5, i7); | 96 | 5.03M | const auto q6 = InterleaveUpper(d, i4, i6); | 97 | 5.03M | const auto q7 = InterleaveUpper(d, i5, i7); | 98 | | | 99 | 5.03M | const auto r0 = InterleaveLower(d, q0, q1); | 100 | 5.03M | const auto r1 = InterleaveUpper(d, q0, q1); | 101 | 5.03M | const auto r2 = InterleaveLower(d, q2, q3); | 102 | 5.03M | const auto r3 = InterleaveUpper(d, q2, q3); | 103 | 5.03M | const auto r4 = InterleaveLower(d, q4, q5); | 104 | 5.03M | const auto r5 = InterleaveUpper(d, q4, q5); | 105 | 5.03M | const auto r6 = InterleaveLower(d, q6, q7); | 106 | 5.03M | const auto r7 = InterleaveUpper(d, q6, q7); | 107 | | | 108 | 5.03M | i0 = ConcatLowerLower(d, r4, r0); | 109 | 5.03M | i1 = ConcatLowerLower(d, r5, r1); | 110 | 5.03M | i2 = ConcatLowerLower(d, r6, r2); | 111 | 5.03M | i3 = ConcatLowerLower(d, r7, r3); | 112 | 5.03M | i4 = ConcatUpperUpper(d, r4, r0); | 113 | 5.03M | i5 = ConcatUpperUpper(d, r5, r1); | 114 | 5.03M | i6 = ConcatUpperUpper(d, r6, r2); | 115 | 5.03M | i7 = ConcatUpperUpper(d, r7, r3); | 116 | 5.03M | to.StorePart(d, i0, m + 0, n + 0); | 117 | 5.03M | to.StorePart(d, i1, m + 1, n + 0); | 118 | 5.03M | to.StorePart(d, i2, m + 2, n + 0); | 119 | 5.03M | to.StorePart(d, i3, m + 3, n + 0); | 120 | 5.03M | to.StorePart(d, i4, m + 4, n + 0); | 121 | 5.03M | to.StorePart(d, i5, m + 5, n + 0); | 122 | 5.03M | to.StorePart(d, i6, m + 6, n + 0); | 123 | 5.03M | to.StorePart(d, i7, m + 7, n + 0); | 124 | 5.03M | } | 125 | 5.03M | } | 126 | 5.03M | } |
|
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 | 610M | static void Run(const From& from, const To& to) { |
174 | | // This does not guarantee anything, just saves from the most stupid |
175 | | // mistakes. |
176 | 610M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); |
177 | 610M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; |
178 | 610M | GenericTransposeBlock<N, M>(tag, from, to, N, M); |
179 | 610M | } 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 | 726k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 726k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 726k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 726k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 726k | } |
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 | 442k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 442k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 442k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 442k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 442k | } |
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 | 384k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 384k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 384k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 384k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 384k | } |
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 | 161k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 161k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 161k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 161k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 161k | } |
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 | 455k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 455k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 455k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 455k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 455k | } |
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 | 239k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 239k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 239k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 239k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 239k | } |
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 | 1.55M | 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.55M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 1.55M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 1.55M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 1.55M | } |
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 | 455k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 455k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 455k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 455k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 455k | } |
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 | 239k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 239k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 239k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 239k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 239k | } |
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 | 161k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 161k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 161k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 161k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 161k | } |
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 | 95.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 | 95.2k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 95.2k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 95.2k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 95.2k | } |
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 | 48.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 | 48.3k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 48.3k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 48.3k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 48.3k | } |
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 | 726k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 726k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 726k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 726k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 726k | } |
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 | 442k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 442k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 442k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 442k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 442k | } |
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 | 384k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 384k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 384k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 384k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 384k | } |
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 | 161k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 161k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 161k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 161k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 161k | } |
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 | 455k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 455k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 455k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 455k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 455k | } |
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 | 239k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 239k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 239k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 239k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 239k | } |
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 | 12.6M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 12.6M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 12.6M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 12.6M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 12.6M | } |
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 | 455k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 455k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 455k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 455k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 455k | } |
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 | 239k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 239k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 239k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 239k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 239k | } |
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 | 161k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 161k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 161k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 161k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 161k | } |
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 | 95.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 | 95.2k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 95.2k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 95.2k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 95.2k | } |
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 | 48.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 | 48.3k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 48.3k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 48.3k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 48.3k | } |
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 | 154M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 154M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 154M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 154M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 154M | } |
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 | 154M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 154M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 154M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 154M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 154M | } |
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 | 177M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 177M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 177M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 177M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 177M | } |
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 | 9.43M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 9.43M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 9.43M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 9.43M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 9.43M | } |
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 | 27.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 | 27.8M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 27.8M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 27.8M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 27.8M | } |
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 | 27.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 | 27.8M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 27.8M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 27.8M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 27.8M | } |
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 | 22.1M | 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.1M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 22.1M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 22.1M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 22.1M | } |
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 | 2.18M | 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.18M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 2.18M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 2.18M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 2.18M | } |
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 | 1.34M | 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.34M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 1.34M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 1.34M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 1.34M | } |
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 | 1.16M | 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.16M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 1.16M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 1.16M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 1.16M | } |
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 | 485k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 485k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 485k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 485k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 485k | } |
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 | 1.37M | 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.37M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 1.37M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 1.37M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 1.37M | } |
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 | 726k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 726k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 726k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 726k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 726k | } |
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&) Line | Count | Source | 173 | 789 | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 789 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 789 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 789 | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 789 | } |
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&) Line | Count | Source | 173 | 96 | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 96 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 96 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 96 | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 96 | } |
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 | 5.03M | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 5.03M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 5.03M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 5.03M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 5.03M | } |
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 | 1.37M | 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.37M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 1.37M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 1.37M | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 1.37M | } |
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 | 726k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 726k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 726k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 726k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 726k | } |
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 | 485k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 485k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 485k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 485k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 485k | } |
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&) Line | Count | Source | 173 | 789 | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 789 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 789 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 789 | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 789 | } |
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&) Line | Count | Source | 173 | 96 | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 96 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 96 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 96 | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 96 | } |
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 | 285k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 285k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 285k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 285k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 285k | } |
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 | 145k | static void Run(const From& from, const To& to) { | 174 | | // This does not guarantee anything, just saves from the most stupid | 175 | | // mistakes. | 176 | 145k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 177 | 145k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 178 | 145k | GenericTransposeBlock<N, M>(tag, from, to, N, M); | 179 | 145k | } |
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 | 16.8M | static void Run(const From& from, const To& to) { |
188 | | // This does not guarantee anything, just saves from the most stupid |
189 | | // mistakes. |
190 | 16.8M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); |
191 | 16.8M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; |
192 | 16.8M | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, |
193 | 16.8M | const From&, const To&, size_t, size_t) = |
194 | 16.8M | GenericTransposeBlock<0, 0, From, To>; |
195 | 16.8M | NoInlineWrapper(transpose, tag, from, to, N, M); |
196 | 16.8M | } 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 | 95.2k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 95.2k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 95.2k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 95.2k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 95.2k | const From&, const To&, size_t, size_t) = | 194 | 95.2k | GenericTransposeBlock<0, 0, From, To>; | 195 | 95.2k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 95.2k | } |
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 | 48.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 | 48.3k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 48.3k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 48.3k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 48.3k | const From&, const To&, size_t, size_t) = | 194 | 48.3k | GenericTransposeBlock<0, 0, From, To>; | 195 | 48.3k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 48.3k | } |
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 | 84.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 | 84.0k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 84.0k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 84.0k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 84.0k | const From&, const To&, size_t, size_t) = | 194 | 84.0k | GenericTransposeBlock<0, 0, From, To>; | 195 | 84.0k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 84.0k | } |
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 | 32.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 | 32.8k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 32.8k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 32.8k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 32.8k | const From&, const To&, size_t, size_t) = | 194 | 32.8k | GenericTransposeBlock<0, 0, From, To>; | 195 | 32.8k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 32.8k | } |
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 | 17.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 | 17.8k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 17.8k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 17.8k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 17.8k | const From&, const To&, size_t, size_t) = | 194 | 17.8k | GenericTransposeBlock<0, 0, From, To>; | 195 | 17.8k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 17.8k | } |
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 | 4.88k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 4.88k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 4.88k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 4.88k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 4.88k | const From&, const To&, size_t, size_t) = | 194 | 4.88k | GenericTransposeBlock<0, 0, From, To>; | 195 | 4.88k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 4.88k | } |
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 | 95.2k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 95.2k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 95.2k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 95.2k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 95.2k | const From&, const To&, size_t, size_t) = | 194 | 95.2k | GenericTransposeBlock<0, 0, From, To>; | 195 | 95.2k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 95.2k | } |
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 | 48.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 | 48.3k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 48.3k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 48.3k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 48.3k | const From&, const To&, size_t, size_t) = | 194 | 48.3k | GenericTransposeBlock<0, 0, From, To>; | 195 | 48.3k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 48.3k | } |
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 | 84.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 | 84.0k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 84.0k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 84.0k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 84.0k | const From&, const To&, size_t, size_t) = | 194 | 84.0k | GenericTransposeBlock<0, 0, From, To>; | 195 | 84.0k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 84.0k | } |
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 | 32.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 | 32.8k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 32.8k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 32.8k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 32.8k | const From&, const To&, size_t, size_t) = | 194 | 32.8k | GenericTransposeBlock<0, 0, From, To>; | 195 | 32.8k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 32.8k | } |
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 | 17.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 | 17.8k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 17.8k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 17.8k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 17.8k | const From&, const To&, size_t, size_t) = | 194 | 17.8k | GenericTransposeBlock<0, 0, From, To>; | 195 | 17.8k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 17.8k | } |
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 | 4.88k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 4.88k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 4.88k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 4.88k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 4.88k | const From&, const To&, size_t, size_t) = | 194 | 4.88k | GenericTransposeBlock<0, 0, From, To>; | 195 | 4.88k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 4.88k | } |
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 | 5.35M | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 5.35M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 5.35M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 5.35M | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 5.35M | const From&, const To&, size_t, size_t) = | 194 | 5.35M | GenericTransposeBlock<0, 0, From, To>; | 195 | 5.35M | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 5.35M | } |
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 | 5.35M | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 5.35M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 5.35M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 5.35M | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 5.35M | const From&, const To&, size_t, size_t) = | 194 | 5.35M | GenericTransposeBlock<0, 0, From, To>; | 195 | 5.35M | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 5.35M | } |
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 | 1.82M | 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.82M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 1.82M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 1.82M | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 1.82M | const From&, const To&, size_t, size_t) = | 194 | 1.82M | GenericTransposeBlock<0, 0, From, To>; | 195 | 1.82M | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 1.82M | } |
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 | 306k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 306k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 306k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 306k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 306k | const From&, const To&, size_t, size_t) = | 194 | 306k | GenericTransposeBlock<0, 0, From, To>; | 195 | 306k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 306k | } |
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 | 1.27M | 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.27M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 1.27M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 1.27M | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 1.27M | const From&, const To&, size_t, size_t) = | 194 | 1.27M | GenericTransposeBlock<0, 0, From, To>; | 195 | 1.27M | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 1.27M | } |
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 | 1.27M | 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.27M | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 1.27M | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 1.27M | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 1.27M | const From&, const To&, size_t, size_t) = | 194 | 1.27M | GenericTransposeBlock<0, 0, From, To>; | 195 | 1.27M | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 1.27M | } |
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 | 285k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 285k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 285k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 285k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 285k | const From&, const To&, size_t, size_t) = | 194 | 285k | GenericTransposeBlock<0, 0, From, To>; | 195 | 285k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 285k | } |
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 | 145k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 145k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 145k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 145k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 145k | const From&, const To&, size_t, size_t) = | 194 | 145k | GenericTransposeBlock<0, 0, From, To>; | 195 | 145k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 145k | } |
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 | 252k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 252k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 252k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 252k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 252k | const From&, const To&, size_t, size_t) = | 194 | 252k | GenericTransposeBlock<0, 0, From, To>; | 195 | 252k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 252k | } |
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 | 53.5k | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 53.5k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 53.5k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 53.5k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 53.5k | const From&, const To&, size_t, size_t) = | 194 | 53.5k | GenericTransposeBlock<0, 0, From, To>; | 195 | 53.5k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 53.5k | } |
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 | 14.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 | 14.6k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 14.6k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 14.6k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 14.6k | const From&, const To&, size_t, size_t) = | 194 | 14.6k | GenericTransposeBlock<0, 0, From, To>; | 195 | 14.6k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 14.6k | } |
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 | 98.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 | 98.6k | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 98.6k | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 98.6k | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 98.6k | const From&, const To&, size_t, size_t) = | 194 | 98.6k | GenericTransposeBlock<0, 0, From, To>; | 195 | 98.6k | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 98.6k | } |
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&) Line | Count | Source | 187 | 12 | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 12 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 12 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 12 | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 12 | const From&, const To&, size_t, size_t) = | 194 | 12 | GenericTransposeBlock<0, 0, From, To>; | 195 | 12 | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 12 | } |
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&) Line | Count | Source | 187 | 9 | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 9 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 9 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 9 | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 9 | const From&, const To&, size_t, size_t) = | 194 | 9 | GenericTransposeBlock<0, 0, From, To>; | 195 | 9 | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 9 | } |
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&) Line | Count | Source | 187 | 6 | static void Run(const From& from, const To& to) { | 188 | | // This does not guarantee anything, just saves from the most stupid | 189 | | // mistakes. | 190 | 6 | JXL_DASSERT(from.Address(0, 0) != to.Address(0, 0)); | 191 | 6 | TransposeSimdTag<TransposeUseSimd(N, M)> tag; | 192 | 6 | constexpr void (*transpose)(TransposeSimdTag<TransposeUseSimd(N, M)>, | 193 | 6 | const From&, const To&, size_t, size_t) = | 194 | 6 | GenericTransposeBlock<0, 0, From, To>; | 195 | 6 | NoInlineWrapper(transpose, tag, from, to, N, M); | 196 | 6 | } |
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_ |