⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cfft.c

📁 tcpmp.src.0.72RC1 优秀的多媒体播放器TCPMP的源代码
💻 C
📖 第 1 页 / 共 3 页
字号:
        for (k = 0; k < l1; k++)        {            ac = 4*k*ido;            ah = k*ido;            for (i = 0; i < ido; i++)            {                complex_t c2, c3, c4, t1, t2, t3, t4;                RE(t2) = RE(cc[ac+i]) + RE(cc[ac+i+2*ido]);                RE(t1) = RE(cc[ac+i]) - RE(cc[ac+i+2*ido]);                IM(t2) = IM(cc[ac+i]) + IM(cc[ac+i+2*ido]);                IM(t1) = IM(cc[ac+i]) - IM(cc[ac+i+2*ido]);                RE(t3) = RE(cc[ac+i+ido]) + RE(cc[ac+i+3*ido]);                IM(t4) = RE(cc[ac+i+ido]) - RE(cc[ac+i+3*ido]);                IM(t3) = IM(cc[ac+i+3*ido]) + IM(cc[ac+i+ido]);                RE(t4) = IM(cc[ac+i+3*ido]) - IM(cc[ac+i+ido]);                RE(c2) = RE(t1) + RE(t4);                RE(c4) = RE(t1) - RE(t4);                IM(c2) = IM(t1) + IM(t4);                IM(c4) = IM(t1) - IM(t4);                RE(ch[ah+i]) = RE(t2) + RE(t3);                RE(c3)       = RE(t2) - RE(t3);                IM(ch[ah+i]) = IM(t2) + IM(t3);                IM(c3)       = IM(t2) - IM(t3);#if 1                ComplexMult(&IM(ch[ah+i+l1*ido]), &RE(ch[ah+i+l1*ido]),                    IM(c2), RE(c2), RE(wa1[i]), IM(wa1[i]));                ComplexMult(&IM(ch[ah+i+2*l1*ido]), &RE(ch[ah+i+2*l1*ido]),                    IM(c3), RE(c3), RE(wa2[i]), IM(wa2[i]));                ComplexMult(&IM(ch[ah+i+3*l1*ido]), &RE(ch[ah+i+3*l1*ido]),                    IM(c4), RE(c4), RE(wa3[i]), IM(wa3[i]));#else                ComplexMult(&RE(ch[ah+i+l1*ido]), &IM(ch[ah+i+l1*ido]),                    RE(c2), IM(c2), RE(wa1[i]), IM(wa1[i]));                ComplexMult(&RE(ch[ah+i+2*l1*ido]), &IM(ch[ah+i+2*l1*ido]),                    RE(c3), IM(c3), RE(wa2[i]), IM(wa2[i]));                ComplexMult(&RE(ch[ah+i+3*l1*ido]), &IM(ch[ah+i+3*l1*ido]),                    RE(c4), IM(c4), RE(wa3[i]), IM(wa3[i]));#endif            }        }    }}static void passf4neg(const uint16_t ido, const uint16_t l1, const complex_t *cc,                      complex_t *ch, const complex_t *wa1, const complex_t *wa2,                      const complex_t *wa3){    uint16_t i, k, ac, ah;    if (ido == 1)    {        for (k = 0; k < l1; k++)        {            complex_t t1, t2, t3, t4;            ac = 4*k;            ah = k;            RE(t2) = RE(cc[ac])   + RE(cc[ac+2]);            RE(t1) = RE(cc[ac])   - RE(cc[ac+2]);            IM(t2) = IM(cc[ac])   + IM(cc[ac+2]);            IM(t1) = IM(cc[ac])   - IM(cc[ac+2]);            RE(t3) = RE(cc[ac+1]) + RE(cc[ac+3]);            IM(t4) = RE(cc[ac+1]) - RE(cc[ac+3]);            IM(t3) = IM(cc[ac+3]) + IM(cc[ac+1]);            RE(t4) = IM(cc[ac+3]) - IM(cc[ac+1]);            RE(ch[ah])      = RE(t2) + RE(t3);            RE(ch[ah+2*l1]) = RE(t2) - RE(t3);            IM(ch[ah])      = IM(t2) + IM(t3);            IM(ch[ah+2*l1]) = IM(t2) - IM(t3);            RE(ch[ah+l1])   = RE(t1) - RE(t4);            RE(ch[ah+3*l1]) = RE(t1) + RE(t4);            IM(ch[ah+l1])   = IM(t1) - IM(t4);            IM(ch[ah+3*l1]) = IM(t1) + IM(t4);        }    } else {        for (k = 0; k < l1; k++)        {            ac = 4*k*ido;            ah = k*ido;            for (i = 0; i < ido; i++)            {                complex_t c2, c3, c4, t1, t2, t3, t4;                RE(t2) = RE(cc[ac+i]) + RE(cc[ac+i+2*ido]);                RE(t1) = RE(cc[ac+i]) - RE(cc[ac+i+2*ido]);                IM(t2) = IM(cc[ac+i]) + IM(cc[ac+i+2*ido]);                IM(t1) = IM(cc[ac+i]) - IM(cc[ac+i+2*ido]);                RE(t3) = RE(cc[ac+i+ido]) + RE(cc[ac+i+3*ido]);                IM(t4) = RE(cc[ac+i+ido]) - RE(cc[ac+i+3*ido]);                IM(t3) = IM(cc[ac+i+3*ido]) + IM(cc[ac+i+ido]);                RE(t4) = IM(cc[ac+i+3*ido]) - IM(cc[ac+i+ido]);                RE(c2) = RE(t1) - RE(t4);                RE(c4) = RE(t1) + RE(t4);                IM(c2) = IM(t1) - IM(t4);                IM(c4) = IM(t1) + IM(t4);                RE(ch[ah+i]) = RE(t2) + RE(t3);                RE(c3)       = RE(t2) - RE(t3);                IM(ch[ah+i]) = IM(t2) + IM(t3);                IM(c3)       = IM(t2) - IM(t3);#if 1                ComplexMult(&RE(ch[ah+i+l1*ido]), &IM(ch[ah+i+l1*ido]),                    RE(c2), IM(c2), RE(wa1[i]), IM(wa1[i]));                ComplexMult(&RE(ch[ah+i+2*l1*ido]), &IM(ch[ah+i+2*l1*ido]),                    RE(c3), IM(c3), RE(wa2[i]), IM(wa2[i]));                ComplexMult(&RE(ch[ah+i+3*l1*ido]), &IM(ch[ah+i+3*l1*ido]),                    RE(c4), IM(c4), RE(wa3[i]), IM(wa3[i]));#else                ComplexMult(&IM(ch[ah+i+l1*ido]), &RE(ch[ah+i+l1*ido]),                    IM(c2), RE(c2), RE(wa1[i]), IM(wa1[i]));                ComplexMult(&IM(ch[ah+i+2*l1*ido]), &RE(ch[ah+i+2*l1*ido]),                    IM(c3), RE(c3), RE(wa2[i]), IM(wa2[i]));                ComplexMult(&IM(ch[ah+i+3*l1*ido]), &RE(ch[ah+i+3*l1*ido]),                    IM(c4), RE(c4), RE(wa3[i]), IM(wa3[i]));#endif            }        }    }}static void passf5(const uint16_t ido, const uint16_t l1, const complex_t *cc,                   complex_t *ch, const complex_t *wa1, const complex_t *wa2, const complex_t *wa3,                   const complex_t *wa4, const int8_t isign){    static const real_t tr11 = FRAC_CONST(0.309016994374947);    static const real_t ti11 = FRAC_CONST(0.951056516295154);    static const real_t tr12 = FRAC_CONST(-0.809016994374947);    static const real_t ti12 = FRAC_CONST(0.587785252292473);    uint16_t i, k, ac, ah;    complex_t c2, c3, c4, c5, d3, d4, d5, d2, t2, t3, t4, t5;    if (ido == 1)    {        if (isign == 1)        {            for (k = 0; k < l1; k++)            {                ac = 5*k + 1;                ah = k;                RE(t2) = RE(cc[ac]) + RE(cc[ac+3]);                IM(t2) = IM(cc[ac]) + IM(cc[ac+3]);                RE(t3) = RE(cc[ac+1]) + RE(cc[ac+2]);                IM(t3) = IM(cc[ac+1]) + IM(cc[ac+2]);                RE(t4) = RE(cc[ac+1]) - RE(cc[ac+2]);                IM(t4) = IM(cc[ac+1]) - IM(cc[ac+2]);                RE(t5) = RE(cc[ac]) - RE(cc[ac+3]);                IM(t5) = IM(cc[ac]) - IM(cc[ac+3]);                RE(ch[ah]) = RE(cc[ac-1]) + RE(t2) + RE(t3);                IM(ch[ah]) = IM(cc[ac-1]) + IM(t2) + IM(t3);                RE(c2) = RE(cc[ac-1]) + MUL_F(RE(t2),tr11) + MUL_F(RE(t3),tr12);                IM(c2) = IM(cc[ac-1]) + MUL_F(IM(t2),tr11) + MUL_F(IM(t3),tr12);                RE(c3) = RE(cc[ac-1]) + MUL_F(RE(t2),tr12) + MUL_F(RE(t3),tr11);                IM(c3) = IM(cc[ac-1]) + MUL_F(IM(t2),tr12) + MUL_F(IM(t3),tr11);                ComplexMult(&RE(c5), &RE(c4),                    ti11, ti12, RE(t5), RE(t4));                ComplexMult(&IM(c5), &IM(c4),                    ti11, ti12, IM(t5), IM(t4));                RE(ch[ah+l1]) = RE(c2) - IM(c5);                IM(ch[ah+l1]) = IM(c2) + RE(c5);                RE(ch[ah+2*l1]) = RE(c3) - IM(c4);                IM(ch[ah+2*l1]) = IM(c3) + RE(c4);                RE(ch[ah+3*l1]) = RE(c3) + IM(c4);                IM(ch[ah+3*l1]) = IM(c3) - RE(c4);                RE(ch[ah+4*l1]) = RE(c2) + IM(c5);                IM(ch[ah+4*l1]) = IM(c2) - RE(c5);            }        } else {            for (k = 0; k < l1; k++)            {                ac = 5*k + 1;                ah = k;                RE(t2) = RE(cc[ac]) + RE(cc[ac+3]);                IM(t2) = IM(cc[ac]) + IM(cc[ac+3]);                RE(t3) = RE(cc[ac+1]) + RE(cc[ac+2]);                IM(t3) = IM(cc[ac+1]) + IM(cc[ac+2]);                RE(t4) = RE(cc[ac+1]) - RE(cc[ac+2]);                IM(t4) = IM(cc[ac+1]) - IM(cc[ac+2]);                RE(t5) = RE(cc[ac]) - RE(cc[ac+3]);                IM(t5) = IM(cc[ac]) - IM(cc[ac+3]);                RE(ch[ah]) = RE(cc[ac-1]) + RE(t2) + RE(t3);                IM(ch[ah]) = IM(cc[ac-1]) + IM(t2) + IM(t3);                RE(c2) = RE(cc[ac-1]) + MUL_F(RE(t2),tr11) + MUL_F(RE(t3),tr12);                IM(c2) = IM(cc[ac-1]) + MUL_F(IM(t2),tr11) + MUL_F(IM(t3),tr12);                RE(c3) = RE(cc[ac-1]) + MUL_F(RE(t2),tr12) + MUL_F(RE(t3),tr11);                IM(c3) = IM(cc[ac-1]) + MUL_F(IM(t2),tr12) + MUL_F(IM(t3),tr11);                ComplexMult(&RE(c4), &RE(c5),                    ti12, ti11, RE(t5), RE(t4));                ComplexMult(&IM(c4), &IM(c5),                    ti12, ti12, IM(t5), IM(t4));                RE(ch[ah+l1]) = RE(c2) + IM(c5);                IM(ch[ah+l1]) = IM(c2) - RE(c5);                RE(ch[ah+2*l1]) = RE(c3) + IM(c4);                IM(ch[ah+2*l1]) = IM(c3) - RE(c4);                RE(ch[ah+3*l1]) = RE(c3) - IM(c4);                IM(ch[ah+3*l1]) = IM(c3) + RE(c4);                RE(ch[ah+4*l1]) = RE(c2) - IM(c5);                IM(ch[ah+4*l1]) = IM(c2) + RE(c5);            }        }    } else {        if (isign == 1)        {            for (k = 0; k < l1; k++)            {                for (i = 0; i < ido; i++)                {                    ac = i + (k*5 + 1) * ido;                    ah = i + k * ido;                    RE(t2) = RE(cc[ac]) + RE(cc[ac+3*ido]);                    IM(t2) = IM(cc[ac]) + IM(cc[ac+3*ido]);                    RE(t3) = RE(cc[ac+ido]) + RE(cc[ac+2*ido]);                    IM(t3) = IM(cc[ac+ido]) + IM(cc[ac+2*ido]);                    RE(t4) = RE(cc[ac+ido]) - RE(cc[ac+2*ido]);                    IM(t4) = IM(cc[ac+ido]) - IM(cc[ac+2*ido]);                    RE(t5) = RE(cc[ac]) - RE(cc[ac+3*ido]);                    IM(t5) = IM(cc[ac]) - IM(cc[ac+3*ido]);                    RE(ch[ah]) = RE(cc[ac-ido]) + RE(t2) + RE(t3);                    IM(ch[ah]) = IM(cc[ac-ido]) + IM(t2) + IM(t3);                    RE(c2) = RE(cc[ac-ido]) + MUL_F(RE(t2),tr11) + MUL_F(RE(t3),tr12);                    IM(c2) = IM(cc[ac-ido]) + MUL_F(IM(t2),tr11) + MUL_F(IM(t3),tr12);                    RE(c3) = RE(cc[ac-ido]) + MUL_F(RE(t2),tr12) + MUL_F(RE(t3),tr11);                    IM(c3) = IM(cc[ac-ido]) + MUL_F(IM(t2),tr12) + MUL_F(IM(t3),tr11);                    ComplexMult(&RE(c5), &RE(c4),                        ti11, ti12, RE(t5), RE(t4));                    ComplexMult(&IM(c5), &IM(c4),                        ti11, ti12, IM(t5), IM(t4));                    IM(d2) = IM(c2) + RE(c5);                    IM(d3) = IM(c3) + RE(c4);                    RE(d4) = RE(c3) + IM(c4);                    RE(d5) = RE(c2) + IM(c5);                    RE(d2) = RE(c2) - IM(c5);                    IM(d5) = IM(c2) - RE(c5);                    RE(d3) = RE(c3) - IM(c4);                    IM(d4) = IM(c3) - RE(c4);#if 1                    ComplexMult(&IM(ch[ah+l1*ido]), &RE(ch[ah+l1*ido]),                        IM(d2), RE(d2), RE(wa1[i]), IM(wa1[i]));                    ComplexMult(&IM(ch[ah+2*l1*ido]), &RE(ch[ah+2*l1*ido]),                        IM(d3), RE(d3), RE(wa2[i]), IM(wa2[i]));                    ComplexMult(&IM(ch[ah+3*l1*ido]), &RE(ch[ah+3*l1*ido]),                        IM(d4), RE(d4), RE(wa3[i]), IM(wa3[i]));                    ComplexMult(&IM(ch[ah+4*l1*ido]), &RE(ch[ah+4*l1*ido]),                        IM(d5), RE(d5), RE(wa4[i]), IM(wa4[i]));#else                    ComplexMult(&RE(ch[ah+l1*ido]), &IM(ch[ah+l1*ido]),                        RE(d2), IM(d2), RE(wa1[i]), IM(wa1[i]));                    ComplexMult(&RE(ch[ah+2*l1*ido]), &IM(ch[ah+2*l1*ido]),                        RE(d3), IM(d3), RE(wa2[i]), IM(wa2[i]));                    ComplexMult(&RE(ch[ah+3*l1*ido]), &IM(ch[ah+3*l1*ido]),                        RE(d4), IM(d4), RE(wa3[i]), IM(wa3[i]));                    ComplexMult(&RE(ch[ah+4*l1*ido]), &IM(ch[ah+4*l1*ido]),                        RE(d5), IM(d5), RE(wa4[i]), IM(wa4[i]));#endif                }            }        } else {            for (k = 0; k < l1; k++)            {                for (i = 0; i < ido; i++)                {                    ac = i + (k*5 + 1) * ido;                    ah = i + k * ido;                    RE(t2) = RE(cc[ac]) + RE(cc[ac+3*ido]);                    IM(t2) = IM(cc[ac]) + IM(cc[ac+3*ido]);                    RE(t3) = RE(cc[ac+ido]) + RE(cc[ac+2*ido]);                    IM(t3) = IM(cc[ac+ido]) + IM(cc[ac+2*ido]);                    RE(t4) = RE(cc[ac+ido]) - RE(cc[ac+2*ido]);                    IM(t4) = IM(cc[ac+ido]) - IM(cc[ac+2*ido]);                    RE(t5) = RE(cc[ac]) - RE(cc[ac+3*ido]);                    IM(t5) = IM(cc[ac]) - IM(cc[ac+3*ido]);                    RE(ch[ah]) = RE(cc[ac-ido]) + RE(t2) + RE(t3);                    IM(ch[ah]) = IM(cc[ac-ido]) + IM(t2) + IM(t3);                    RE(c2) = RE(cc[ac-ido]) + MUL_F(RE(t2),tr11) + MUL_F(RE(t3),tr12);                    IM(c2) = IM(cc[ac-ido]) + MUL_F(IM(t2),tr11) + MUL_F(IM(t3),tr12);                    RE(c3) = RE(cc[ac-ido]) + MUL_F(RE(t2),tr12) + MUL_F(RE(t3),tr11);                    IM(c3) = IM(cc[ac-ido]) + MUL_F(IM(t2),tr12) + MUL_F(IM(t3),tr11);                    ComplexMult(&RE(c4), &RE(c5),                        ti12, ti11, RE(t5), RE(t4));                    ComplexMult(&IM(c4), &IM(c5),                        ti12, ti12, IM(t5), IM(t4));                    IM(d2) = IM(c2) - RE(c5);                    IM(d3) = IM(c3) - RE(c4);                    RE(d4) = RE(c3) - IM(c4);                    RE(d5) = RE(c2) - IM(c5);                    RE(d2) = RE(c2) + IM(c5);                    IM(d5) = IM(c2) + RE(c5);                    RE(d3) = RE(c3) + IM(c4);                    IM(d4) = IM(c3) + RE(c4);#if 1                    ComplexMult(&RE(ch[ah+l1*ido]), &IM(ch[ah+l1*ido]),                        RE(d2), IM(d2), RE(wa1[i]), IM(wa1[i]));                    ComplexMult(&RE(ch[ah+2*l1*ido]), &IM(ch[ah+2*l1*ido]),                        RE(d3), IM(d3), RE(wa2[i]), IM(wa2[i]));                    ComplexMult(&RE(ch[ah+3*l1*ido]), &IM(ch[ah+3*l1*ido]),                        RE(d4), IM(d4), RE(wa3[i]), IM(wa3[i]));                    ComplexMult(&RE(ch[ah+4*l1*ido]), &IM(ch[ah+4*l1*ido]),                        RE(d5), IM(d5), RE(wa4[i]), IM(wa4[i]));

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -