亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? tfr16.c

?? 基于56F8346的異步電機VVVF控制程序。
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* File: tfr16.c */
/*--------------------------------------------------------------
*
*        (C) 2000 (c) Freescale Semiconductor
*-------------------------------------------------------------*/
/*--------------------------------------------------------------
* Revision History:
*
* VERSION    CREATED BY    MODIFIED BY      DATE       COMMENTS
* -------    ----------    -----------      -----      --------
*   1.0      Meera S. P.        -          17-02-2000   Reviewed.
*
*-------------------------------------------------------------*/

/*---------------------------------------------------------------
* 16 bit Fractional Trignometric Functions
*----------------------------------------------------------------*/

#include "port.h"
#include "tfr16.h"
#include "stdio.h"
#include "MFR1.h"
#include "prototype.h"
#include "mem.h"

#define CFF(x) (Frac16)(x * 32767.0)

#define SWG_90_DEGREES     8192
#define SWG_180_DEGREES    16384
#define SWG_270_DEGREES    24576
#define SWG_360_DEGREES    32767
#define SWG_SIGN_POSITIVE  1
#define SWG_SIGN_NEGATIVE -1
#define SWG_ONEHALF        16384
#define PI_PLUS            32768
#define PI_MINUS          -32767
#define SWG_NEG_MAX       -32768
#define PI_HALF_PLUS       16384
#define PI_HALF_MINUS     -16384


void   tfr16SineWaveGenIDTLC  (tfr16_tSineWaveGenIDTL   *, Frac16 *, UInt16);
void   tfr16SineWaveGenRDTLC  (tfr16_tSineWaveGenRDTL   *, Frac16 *, UInt16);
void   tfr16SineWaveGenRDITLC (tfr16_tSineWaveGenRDITL  *, Frac16 *, UInt16);
void   tfr16SineWaveGenRDITLQC(tfr16_tSineWaveGenRDITLQ *, Frac16 *, UInt16);
void   tfr16SineWaveGenPAMC   (tfr16_tSineWaveGenPAM    *, Frac16 *, UInt16);
void   tfr16SineWaveGenDOMC   (tfr16_tSineWaveGenDOM    *, Frac16 *, UInt16);
Frac16 tfr16WaveGenRDITLQC    (tfr16_tWaveGenRDITLQ     *, Frac16);
Frac16 tfr16SinPIxLUTC        (tfr16_tSinPIxLUT         *, Frac16);

void tfr16CosPIxLUTInitC      (tfr16_tCosPIxLUT * pSWG,
        Frac16          * pSineTable,
        UInt16            SineTableLength);
Frac16 tfr16CosPIxLUTC        (tfr16_tCosPIxLUT * pSWG, Frac16);

/***************************************************************************************
* The Scale Factor is calculated using matlab.                                         *
*                                                                                      *
* ex :                                                                                 *
* For Sine Coefs.                                                                      *
* c = [pi -pi^3/3! pi^5/5! -pi^7/7! pi^9/9! -pi^11/11! pi^13/13! -pi^15/15! pi^17/17!] *
* cmax = max(abs(c))                                                                   *
* m = ceil(log2(cmax))                                                                 *
* SCALE_FACT = 2^m                                                                     *
*                                                                                      *
* SineCoefs(I) = c(I)/8                                                                *
***************************************************************************************/
#define SCALE_FACT      8

const Frac16 SineCoefs[] =  {
                             CFF(0.39269908169872),
                             CFF(-0.64596409750625),
                             CFF(0.31877050498467),
                             CFF(-0.07446482317004),
                             CFF(0.01026823582639),
                             CFF(-0.00092130386821),
                             CFF(0.00005828785072)
                            };
const Frac16 AsineCoefs[] = {
                             CFF(0.31830988618379),
                             CFF(0.05305164769730),
                             CFF(0.02387324146378),
                             CFF(0.01421026277606),
           CFF(0.00967087327815),
           CFF(0.00712127941391),
           CFF(0.00552355646848),
           CFF(0.00444514782464)
          };

const Frac16 Inv_Threshold = CFF(0.70710678118655);

/*******************************************************
* Trigonometric Functions for 16-bit Fractional
*******************************************************/

/********************************************************************************
* File Name : tfr16.c                                                           *
*                                                                               *
* Function : Frac16 tfr16SinPIx      (Frac16 x)                                 *
*                                                                               *
* Description:                                                                  *
* This routine computes sine(pi*x)                                              *
*                                                                               *
* Inputs :                                                                      *
*          1) x - input data value                                              *
*                                                                               *
* Outputs :                                                                     *
*          1) z - sine(pi*x)                                                    *
*                                                                               *
* Algorithm :                                                                   *
* if(x > 0.5)                                                                   *
*    sin(pi*x) = sin(pi*(1-x))                                                  *
*                                                                               *
*                                                                               *
* z = x(SineCoefs(0)+x^2(SineCoefs(1)+x^2(SineCoefs(2)+x^2(SineCoefs(3)+        *
*     x^2(SineCoefs(4)+x^2(SineCoefs(5)+SineCoefs(6)x^2))))))                   *
********************************************************************************/


Frac16 tfr16SinPIx      (Frac16 x)
{
    Frac16 z, temp16, sign_flag = 0, i;
    Frac32 Acc = 0,temp32;
    word Tmp;

    asm(move.w  Y1,Tmp);

    if(x < 0)
    {
        sign_flag = 1;
        x = negate(x);
    }

    if(x > CFF(0.5))
    {
       /* sin(pi*x) = sin(pi*(1-x)) */
        x = sub(CFF(1),x);
    }

    z = mult_r(x,x); /* z = x^2 */

    Acc = L_deposit_h(SineCoefs[5]);
    temp16 = mac_r(Acc,z,SineCoefs[6]); /* temp16 = c5 +c6*x^2 */

    /* temp16 = (c0+z(c1+z(c2+z(c3+z(c4+z(c5+c6z)))))) */
    for(i = 4; i >= 0; i--)
    {
      Acc = L_deposit_h(SineCoefs[i]);
      temp16 = mac_r(Acc,temp16,z);
    }


    temp32 = L_mult(temp16,x); /* z = x * temp16 */
    /* z = z*8 (as the coefs are scaled down by 8,
                           the o/p is scaled up by 8) */

    temp32 = L_shl(temp32,(Frac16)3);

    z = round(temp32);

    if (sign_flag == 1)
    {
        z = negate(z);
    }
    asm(move.w  Tmp,Y1);

  return z;
}

/********************************************************************************
* File Name : tfr16.c                                                           *
*                                                                               *
* Function : Frac16 tfr16CosPIx      (Frac16 x)                                 *
*                                                                               *
* Description:                                                                  *
* This routine computes cosine(pi*x)                                            *
*                                                                               *
* Inputs :                                                                      *
*          1) x - input data value                                              *
*                                                                               *
* Outputs :                                                                     *
*          1) z - cosine(pi*x)                                                  *
*                                                                               *
* Algorithm :                                                                   *
* if(x > 0.5)                                                                   *
*    cos(pi*x) = -cos(pi*(1-x))                                                 *
*                                                                               *
* cos(pi*x) = sin(pi*(0.5-x))                                                   *
*                                                                               *
********************************************************************************/

Frac16 tfr16CosPIx      (Frac16 x)
{
    Frac16 z, sign_flag = 0;
//    Frac16 temp16, i, temp1, temp 2;
    Frac32 Acc = 0;
//    Frac32 temp32;

    if(x < 0)
    {
      x = negate(x); //cos(x) = cos(-x)
    }

    if(x > CFF(0.5))
    {
        x = sub(CFF(1),x);
        sign_flag = 1;
    }

    x = sub(CFF(0.5),x);
    if(sign_flag ==1)
        x = add(x,1);               /* To gain the precision */
    z = tfr16SinPIx(x);

    if(sign_flag == 1)
    {
        z = negate(z);
    }

  return z;
}


/********************************************************************************
* File Name : tfr16.c                                                           *
*                                                                               *
* Function : Frac16 tfr16ASinOverPI     (Frac16 x)                              *
*                                                                               *
* Description:                                                                  *
* This routine computes the Arcsin function of fractional input value x, and    *
* divides that result by pi i.e. Arcsin(x)/pi.                                  *
*                                                                               *
* Inputs :                                                                      *
*          1) x - input data value                                              *
*                                                                               *
* Outputs :                                                                     *
*          1) z - Arcsin(x)/pi                                                  *
*                                                                               *
* Algorithm:                                                                    *
*           if(x >= 0.70710678118655)                                           *
*              z = 0.5 - ASinOverPI(sqrt(1-x^2))                                *
*           else                                                                *
*              z = ASinOverPI(x)                                                *
*                                                                               *
* Where :                                                                       *
* ASinOverPI(x) = x(AsineCoefs(0)+x^2(AsineCoefs(1)+x^2(AsineCoefs(2)+          *
*                 x^2(AsineCoefs(3)+x^2(AsineCoefs(4)+x^2(AsineCoefs(5)+        *
*                 x^2(AsineCoefs(6)+AsineCoefs(7)x^2)))))))                     *
*                                                                               *
********************************************************************************/

Frac16 tfr16AsinOverPI  (Frac16 x)
{
    Frac16   z, temp16, sign_flag = 0, i, thres_flag = 0;
    Frac32   Acc = 0;

    if (x < 0)
    {
        sign_flag = 1;
        x = negate(x);
    }

  z = mult_r(x,x);
    if (x > Inv_Threshold)
    {
        thres_flag = 1;
        x = mfr16Sqrt(sub(CFF(1),add(z,1)));
        z = mult_r(x,x);
    }

  temp16 = AsineCoefs[7];

    for(i = 6; i >= 0; i--)
    {
        Acc = L_deposit_h(AsineCoefs[i]);
      temp16 =  mac_r(Acc,temp16,z);
    }

    z = mult_r(temp16,x);

    if (thres_flag == 1)
    {
        z = sub(CFF(0.5),z);
    }

    if (sign_flag == 1)
    {
        z = negate(z);
    }

  return z;
}

/********************************************************************************
* File Name : tfr16.c                                                           *
*                                                                               *
* Function : Frac16 tfr16ACosOverPI     (Frac16 x)                              *
*                                                                               *
* Description:                                                                  *
* This routine computes the Arccos function of fractional input value x, and    *
* divides that result by pi i.e. Arccos(x)/pi.                                  *
*                                                                               *
* Inputs :                                                                      *
*          1) x - input data value                                              *
*                                                                               *
* Outputs :                                                                     *
*          1) z - Arccos(x)/pi                                                  *
*                                                                               *
* Algorithm:                                                                    *
* AtanOverPI(x) = 0.5 - AsinOverPI(x)                                           *
********************************************************************************/

Frac16 tfr16AcosOverPI  (Frac16 x)
{
  Frac16 z, sign_flag = 0;

    if(x < 0)
    {
        sign_flag = 1;
        x = negate(x);
    }

    z = tfr16AsinOverPI (x);

    if (sign_flag == 1)
    {
        z = negate(z);
    }

    z = sub(CFF(0.50000000000),z); /*acos(x) = 0.5 - AsinOverPI(x) */

    return z;
}

/********************************************************************************
* File Name : tfr16.c                                                           *
*                                                                               *
* Function : Frac16 tfr16AtanOverPI     (Frac16 x)                              *
*                                                                               *
* Description:                                                                  *
* This routine computes the Arctan function of fractional input value x, and    *
* divides that result by pi i.e. Arctan(x)/pi.                                  *
*                                                                               *
* Inputs :                                                                      *
*          1) x - input data value                                              *
*                                                                               *
* Outputs :                                                                     *
*          1) z - Arctan(x)/pi                                                  *
*                                                                               *
* Algorithm:                                                                    *
* AtanOverPI(x) = 0.5 - AsinOverPI(sqrt(1-x^2)/sqrt(1-x^4))                     *
********************************************************************************/

Frac16 tfr16AtanOverPI  (Frac16 x)
{
    Frac16 z, z1, z2, sign_flag = 0;


  if(x < 0)
    {
        sign_flag = 1;
        x = negate(x);
    }

    if ( x == CFF(1))
    {
        z = CFF(0.25000000000000);
    }
    else
    {
        z1 = mult_r(x,x);   /* z1 = x^2 */
    if (z1 > 0)
         z1 = add(z1,1); /* To compensate the precision lost while calculating square */

        z2 = mult_r(z1,z1);   /* z2 = x^4 */
        if (z2 > 0)
           z2 = add(z2,1); /* To compensate the precision lost while calculating square */


        z1 = mfr16Sqrt(sub(CFF(1),z1));  /* z1 = sqrt(1-x^2) */
        z2 = mfr16Sqrt(sub(CFF(1),z2));  /* z2 = sqrt(1-x^4) */
        x = div_s(z1,z2);                /* x = (sqrt(1-x^2)/sqrt(1-x^4)) */

        /* AtanOverPI(x) = 0.5 - AsinOverPI(sqrt(1-x^2)/sqrt(1-x^4)) */
        z = sub(CFF(0.5),tfr16AsinOverPI(x));
    }

   if (sign_flag == 1)
    {
        z = negate(z);
    }
  return z;
}

/********************************************************************************
* File Name : tfr16.c                                                           *
*                                                                               *
* Function : Frac16 tfr16Atan2OverPI (Frac16 y,Frac16 x)                        *
*                                                                               *
* Description:                                                                  *
* This routine computes the Arctan(y/x), and divides that result by pi i.e.     *
* Arctan(y/x)/pi.                                                               *
*                                                                               *
* Inputs :                                                                      *
*          1) y - first input data value                                        *
*          2) x - second input data value                                       *
*                                                                               *
* Outputs :                                                                     *
*          1) z - Arctan(y/x)/pi                                                *
*                                                                               *
* Algorithm :                                                                   *
*          if(y/x < 1)                                                          *
*             z = AtanOverPI(y/x);                                              *
*          else                                                                 *
*             z = (0.5 - AtanOverPI(x/y))                                       *
*********************************************************************************/

Frac16 tfr16Atan2OverPI (Frac16 y, Frac16 x)
{
    Frac16 temp16, div_flag = 0, z, sign_flag = 0;
    Frac16 ax, ay;  /* for CW bug workaround */

    if(y == 0 && x == 0)
    {
      temp16 = 0;          /* temp = y/x */
    }
    else
    {
        ax = abs_s(x);
        ay = abs_s(y);

        /* LS010419 - try to keep positive to satisfy ITU (basic_op) constraints */
        if ((x<0 && y>=0) || (x>=0 && y<0))
        {
         sign_flag = 1;
        }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
26uuu色噜噜精品一区| 日韩福利视频网| 国产精品丝袜91| 国产精品天干天干在线综合| 久久综合给合久久狠狠狠97色69| 日韩一区二区三区av| 欧美一区二区三区男人的天堂| 欧美久久久久久久久| 欧美一区三区二区| 欧美一区二区视频观看视频| 精品伦理精品一区| 久久久三级国产网站| 久久久久久久久97黄色工厂| 日本一区二区视频在线| 国产精品久久久久久久岛一牛影视 | 懂色av中文字幕一区二区三区| 国产91精品在线观看| 国产iv一区二区三区| 99久久99久久精品国产片果冻| 91丨九色丨蝌蚪富婆spa| av电影一区二区| 色婷婷精品久久二区二区蜜臀av| 欧美在线观看视频一区二区| 欧美久久久久久久久| 精品久久久久久久人人人人传媒| 久久久精品日韩欧美| 国产精品视频看| 亚洲一区二区av在线| 全国精品久久少妇| 粉嫩久久99精品久久久久久夜| 91视视频在线观看入口直接观看www| 91一区一区三区| 91精品福利在线一区二区三区 | 99久免费精品视频在线观看| 一本色道久久加勒比精品| 911精品国产一区二区在线| 欧美成人aa大片| **网站欧美大片在线观看| 亚洲一区自拍偷拍| 蜜桃精品在线观看| 国产91在线观看| 色综合夜色一区| 日韩一级黄色大片| 精品欧美一区二区久久| 综合av第一页| 美女精品一区二区| www.欧美日韩国产在线| 91精品国产全国免费观看| 国产欧美一区二区三区在线老狼| 亚洲一区二区偷拍精品| 欧美bbbbb| 色综合一个色综合| 精品国产乱码久久久久久免费| 亚洲色图都市小说| 狠狠色狠狠色综合系列| 欧美写真视频网站| 国产喷白浆一区二区三区| 日韩中文字幕91| 成人一级视频在线观看| 欧美丰满高潮xxxx喷水动漫| 国产精品久久久久天堂| 蜜臀99久久精品久久久久久软件| 97精品久久久午夜一区二区三区 | 国产精品对白交换视频| 日韩国产欧美三级| 99国产精品99久久久久久| 日韩欧美国产三级电影视频| 亚洲人成在线播放网站岛国| 另类调教123区 | 久久综合色婷婷| 亚洲午夜成aⅴ人片| 成人激情校园春色| 日韩一区国产二区欧美三区| 亚洲一区二区综合| 99精品欧美一区二区三区小说 | 国产一区二区0| 欧美日韩亚洲不卡| 亚洲男帅同性gay1069| 国产一二精品视频| 欧美第一区第二区| 日韩av网站免费在线| 欧美视频精品在线| 亚洲欧洲精品天堂一级| 国产91在线看| 国产亚洲综合色| 精品一区中文字幕| 欧美一区二区成人| 偷拍日韩校园综合在线| 欧美色图激情小说| 艳妇臀荡乳欲伦亚洲一区| 99久久久国产精品免费蜜臀| 国产精品色一区二区三区| 国产九色sp调教91| 久久精品视频一区二区三区| 开心九九激情九九欧美日韩精美视频电影 | 激情六月婷婷久久| 欧美岛国在线观看| 久久国产精品99久久久久久老狼| 777奇米成人网| 日本aⅴ精品一区二区三区| 欧美日高清视频| 日韩精品电影在线| 在线播放91灌醉迷j高跟美女 | 久久99国内精品| 欧美成人福利视频| 黄色日韩网站视频| 久久久久久久久久久黄色| 国内精品伊人久久久久av一坑| 精品欧美一区二区在线观看| 久久99国产精品成人| 精品国产免费一区二区三区香蕉| 蜜臀av一区二区| 精品免费日韩av| 国产精品538一区二区在线| 中文字幕欧美日本乱码一线二线| 成人h动漫精品一区二区 | 99久久99久久精品免费看蜜桃 | 精品制服美女久久| 久久只精品国产| 国产91富婆露脸刺激对白| 1区2区3区国产精品| 欧美中文字幕一区| 日韩国产一区二| 国产亚洲欧美在线| av网站一区二区三区| 一区二区在线免费| 宅男在线国产精品| 国产一区激情在线| 亚洲欧洲日韩一区二区三区| 欧美特级限制片免费在线观看| 丝瓜av网站精品一区二区| 久久亚洲捆绑美女| 99精品视频一区| 日韩av中文在线观看| 久久青草欧美一区二区三区| 波多野结衣精品在线| 亚洲国产精品欧美一二99| 精品卡一卡二卡三卡四在线| 白白色亚洲国产精品| 亚洲国产乱码最新视频| 欧美电影免费观看高清完整版在线| 国产.精品.日韩.另类.中文.在线.播放 | 国产午夜精品一区二区三区嫩草 | 成人va在线观看| 亚洲成人激情社区| 久久精品视频一区二区三区| 91福利国产成人精品照片| 麻豆一区二区三| 亚洲欧洲av一区二区三区久久| 7777精品伊人久久久大香线蕉超级流畅 | 精品一二三四区| 自拍av一区二区三区| 91精品国产综合久久久久久| 风间由美性色一区二区三区| 亚洲成人动漫av| 久久久久久影视| 欧美三级电影精品| 国产不卡免费视频| 日本成人在线看| 中文字幕欧美一| 精品国产乱码久久久久久老虎| 色综合久久88色综合天天免费| 久久不见久久见免费视频7| 亚洲欧美一区二区三区极速播放| 精品国产乱码久久| 欧美视频一区二区| 99国内精品久久| 国产乱码精品一区二区三区五月婷| 亚洲一区二区在线免费观看视频| 国产欧美一区二区精品性色| 欧美一区二区三区播放老司机| 成人黄色av电影| 国产在线国偷精品免费看| 亚洲成av人片在线| 专区另类欧美日韩| 久久综合国产精品| 日韩一区二区三区av| 在线观看视频欧美| 不卡的av在线播放| 国产一区二区毛片| 麻豆久久久久久久| 亚洲成在人线免费| 亚洲免费观看高清完整版在线观看 | 精品视频资源站| 99re成人精品视频| 国产美女主播视频一区| 麻豆久久久久久久| 丝袜诱惑制服诱惑色一区在线观看 | 国产精品麻豆99久久久久久| 日韩视频免费观看高清完整版 | 99国产精品国产精品久久| 国产乱色国产精品免费视频| 免费观看久久久4p| 日日夜夜精品免费视频| 一区二区三国产精华液| 综合av第一页| 亚洲乱码中文字幕综合| 日韩一区有码在线| 亚洲欧美在线aaa| 一区在线观看免费|