当lossless == 1时,调用Inverse WHT 过程。该过程的输入是指定预缩放量的可变移位。该过程通过以下有序步骤对阵列T(长度为4)进行原位变换: a = T[ 0 ] >> shift c = T[ 1 ] >> shift d = T[ 2 ] >> shift b = T[ 3 ] >> shift a += c d -= b e = (a - d) >> 1 b = e - b c = e - c a -= b d += c T[ 0 ] = a T[ 1 ] = b T[ 2 ] = c T[ 3 ] = d
时间: 2023-12-29 22:04:33 浏览: 119
这段代码实现了Inverse WHT(逆 Walsh–Hadamard 变换)过程。逆变换的输入是一个长度为4的数组T,以及一个指定的预缩放量shift。以下是该过程的有序步骤:
1. 将T[0]右移shift位并赋值给变量a。
2. 将T[1]右移shift位并赋值给变量c。
3. 将T[2]右移shift位并赋值给变量d。
4. 将T[3]右移shift位并赋值给变量b。
5. 将变量a与变量c相加,并将结果赋值给变量a。
6. 将变量d与变量b相减,并将结果赋值给变量d。
7. 将变量a与变量d的差值右移一位,并将结果赋值给变量e。
8. 将变量e与变量b相减,并将结果赋值给变量b。
9. 将变量e与变量c相减,并将结果赋值给变量c。
10. 将变量a与变量b的差值赋值给变量a。
11. 将变量d与变量c的和赋值给变量d。
12. 将变量a赋值给T[0]。
13. 将变量b赋值给T[1]。
14. 将变量c赋值给T[2]。
15. 将变量d赋值给T[3]。
这个过程实际上是对输入数组T进行逆 Walsh–Hadamard 变换的原位变换操作。
相关问题
if (lossless == 1) { shift = 2; inverse_walsh_hadamard_transform(shift); } else { uint8_t n = log2w; uint8_t r = row_clamp_range; if (tx_type == DCT_DCT || tx_type == ADST_DCT || tx_type == FLIPADST_DCT || tx_type == H_DCT) { inverse_dct(n, r); } else if (tx_type == DCT_ADST || tx_type == ADST_ADST || tx_type == DCT_FLIPADST || tx_type == FLIPADST_FLIPADST || tx_type == ADST_FLIPADST || tx_type == FLIPADST_ADST || tx_type == H_ADST || tx_type == H_FLIPADST) { inverse_adst(n, r); } else { inverse_identity_transform(n); } wait(); }
这段代码是一个条件语句块,根据`lossless`变量的值进行分支处理。
如果`lossless`等于1,则执行以下操作:
1. 将`shift`赋值为2。
2. 调用`inverse_walsh_hadamard_transform()`函数,并将`shift`作为参数传递给该函数。
否则,执行以下操作:
1. 声明并初始化两个`uint8_t`类型的变量`n`和`r`,分别赋值为`log2w`和`row_clamp_range`。
2. 根据`tx_type`的值进行条件判断:
- 如果`tx_type`等于DCT_DCT、ADST_DCT、FLIPADST_DCT或H_DCT,则调用`inverse_dct()`函数,并将`n`和`r`作为参数传递给该函数。
- 如果`tx_type`等于DCT_ADST、ADST_ADST、DCT_FLIPADST、FLIPADST_FLIPADST、ADST_FLIPADST、FLIPADST_ADST、H_ADST或H_FLIPADST,则调用`inverse_adst()`函数,并将`n`和`r`作为参数传递给该函数。
- 否则,调用`inverse_identity_transform()`函数,并将`n`作为参数传递给该函数。
3. 调用`wait()`函数进行等待操作。
以上是根据代码逻辑理解的执行流程,具体函数的功能和实现细节可能需要查看函数的定义部分来确定。
if (lossless == 1) { shift = 2; inverse_walsh_hadamard_transform(shift); //7.13.2.10 } else { uint8_t n = log2w; uint8_t r = row_clamp_range; if (tx_type == DCT_DCT || tx_type == ADST_DCT || tx_type == FLIPADST_DCT || tx_type == H_DCT) { //invoke the inverse DCT process as specified in section 7.13.2.3 inverse_dct(n, r); //7.13.2.3 } else if (tx_type == DCT_ADST || tx_type == ADST_ADST || tx_type == DCT_FLIPADST || tx_type == FLIPADST_FLIPADST || tx_type == ADST_FLIPADST || tx_type == FLIPADST_ADST || tx_type == H_ADST || tx_type == H_FLIPADST) { // invoke the inverse ADST process as specified in section 7.13.2.9 inverse_adst(n, r); //7.13.2.9 } else { //7.13.2.15 inverse_identity_transform(n); } wait(); }
这段代码是一个条件语句,根据`lossless`变量的值进行分支处理。如果`lossless`等于1,则执行位移操作,并调用`inverse_walsh_hadamard_transform()`函数。否则,根据`tx_type`的值来确定执行不同的逆变换过程。
如果`tx_type`等于DCT_DCT、ADST_DCT、FLIPADST_DCT或H_DCT,则调用`inverse_dct()`函数执行逆离散余弦变换(inverse DCT)操作。
如果`tx_type`等于DCT_ADST、ADST_ADST、DCT_FLIPADST、FLIPADST_FLIPADST、ADST_FLIPADST、FLIPADST_ADST、H_ADST或H_FLIPADST,则调用`inverse_adst()`函数执行逆正弦变换(inverse ADST)操作。
否则,调用`inverse_identity_transform()`函数执行逆恒等变换操作。
最后,调用`wait()`函数进行等待。
阅读全文