mirror of
https://github.com/Fishwaldo/bl_mcu_sdk.git
synced 2025-07-14 08:48:51 +00:00
65 lines
1.6 KiB
C
65 lines
1.6 KiB
C
#include "ref.h"
|
|
|
|
riscv_status ref_mat_trans_f64(const riscv_matrix_instance_f64 *pSrc,
|
|
riscv_matrix_instance_f64 *pDst)
|
|
{
|
|
uint64_t r, c;
|
|
uint64_t numR = pSrc->numRows;
|
|
uint64_t numC = pSrc->numCols;
|
|
|
|
for (r = 0; r < numR; r++) {
|
|
for (c = 0; c < numC; c++) {
|
|
pDst->pData[c * numR + r] = pSrc->pData[r * numC + c];
|
|
}
|
|
}
|
|
|
|
return RISCV_MATH_SUCCESS;
|
|
}
|
|
|
|
riscv_status ref_mat_trans_f32(const riscv_matrix_instance_f32 *pSrc,
|
|
riscv_matrix_instance_f32 *pDst)
|
|
{
|
|
uint32_t r, c;
|
|
uint32_t numR = pSrc->numRows;
|
|
uint32_t numC = pSrc->numCols;
|
|
|
|
for (r = 0; r < numR; r++) {
|
|
for (c = 0; c < numC; c++) {
|
|
pDst->pData[c * numR + r] = pSrc->pData[r * numC + c];
|
|
}
|
|
}
|
|
|
|
return RISCV_MATH_SUCCESS;
|
|
}
|
|
|
|
riscv_status ref_mat_trans_q31(const riscv_matrix_instance_q31 *pSrc,
|
|
riscv_matrix_instance_q31 *pDst)
|
|
{
|
|
uint32_t r, c;
|
|
uint32_t numR = pSrc->numRows;
|
|
uint32_t numC = pSrc->numCols;
|
|
|
|
for (r = 0; r < numR; r++) {
|
|
for (c = 0; c < numC; c++) {
|
|
pDst->pData[c * numR + r] = pSrc->pData[r * numC + c];
|
|
}
|
|
}
|
|
|
|
return RISCV_MATH_SUCCESS;
|
|
}
|
|
|
|
riscv_status ref_mat_trans_q15(const riscv_matrix_instance_q15 *pSrc,
|
|
riscv_matrix_instance_q15 *pDst)
|
|
{
|
|
uint32_t r, c;
|
|
uint32_t numR = pSrc->numRows;
|
|
uint32_t numC = pSrc->numCols;
|
|
|
|
for (r = 0; r < numR; r++) {
|
|
for (c = 0; c < numC; c++) {
|
|
pDst->pData[c * numR + r] = pSrc->pData[r * numC + c];
|
|
}
|
|
}
|
|
|
|
return RISCV_MATH_SUCCESS;
|
|
}
|