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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 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;
        }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本在线不卡视频| 日韩一级精品视频在线观看| 成人午夜视频在线观看| 国产精品一卡二卡在线观看| 激情综合色综合久久综合| 麻豆成人综合网| 秋霞午夜av一区二区三区| 青椒成人免费视频| 久久99国产乱子伦精品免费| 精品一区二区三区久久久| 免费观看日韩av| 韩国在线一区二区| 国产福利精品一区二区| 大美女一区二区三区| www.亚洲在线| 91久久奴性调教| 精品视频资源站| 日韩一区二区在线看片| 精品88久久久久88久久久| 精品国产电影一区二区| 欧美高清在线精品一区| 综合激情成人伊人| 亚洲成人av资源| 精品一二三四区| 国产91对白在线观看九色| 91猫先生在线| 制服丝袜激情欧洲亚洲| 欧美精品一区二区三区四区 | 在线观看国产精品网站| 欧美精品少妇一区二区三区| 日韩欧美一区二区久久婷婷| 亚洲国产激情av| 亚洲视频精选在线| 日产欧产美韩系列久久99| 国内不卡的二区三区中文字幕| 成人在线视频首页| 欧美日韩国产经典色站一区二区三区| 91精品国产欧美一区二区| 日本一区二区三级电影在线观看 | 亚洲美女屁股眼交| 日韩av电影免费观看高清完整版| 精品亚洲aⅴ乱码一区二区三区| 菠萝蜜视频在线观看一区| 在线观看国产日韩| 久久久激情视频| 亚洲韩国精品一区| 国产精品一区二区x88av| 欧洲国内综合视频| 久久女同互慰一区二区三区| 伊人开心综合网| 国模一区二区三区白浆| 在线观看av不卡| 国产人妖乱国产精品人妖| 亚洲国产视频一区| 成人高清伦理免费影院在线观看| 这里是久久伊人| 成人欧美一区二区三区小说| 麻豆中文一区二区| 欧美伊人久久久久久久久影院| 2023国产精华国产精品| 亚洲成人在线网站| 不卡一区二区三区四区| 欧美大尺度电影在线| 一区二区三区四区精品在线视频 | 欧美在线制服丝袜| 国产精品丝袜在线| 国产自产v一区二区三区c| 欧美日韩久久久一区| 国产精品久久久久永久免费观看 | 欧美日韩精品一区二区| 国产精品久久国产精麻豆99网站 | 欧美变态凌虐bdsm| 五月婷婷激情综合| 日本韩国欧美国产| 中文字幕第一区第二区| 韩国视频一区二区| 日韩一区二区视频在线观看| 一区二区三区中文字幕在线观看| 高清shemale亚洲人妖| 精品国精品自拍自在线| 视频一区欧美精品| 欧美性三三影院| 亚洲免费av高清| 97精品视频在线观看自产线路二| 国产日韩影视精品| 国产精品一区专区| 久久综合久久鬼色中文字| 青青草97国产精品免费观看| 欧美精品123区| 午夜激情综合网| 911国产精品| 午夜精品久久久久久久蜜桃app| 91福利在线观看| 亚洲在线视频网站| 欧美在线高清视频| 中文字幕一区二区三区四区| 成人av集中营| 亚洲品质自拍视频| 色天天综合久久久久综合片| 曰韩精品一区二区| 欧洲精品视频在线观看| 亚洲最大的成人av| 欧美专区亚洲专区| 亚洲一区二区3| 欧美性大战xxxxx久久久| 亚洲国产成人精品视频| 欧美日韩国产一级| 美女尤物国产一区| 欧美精品一区在线观看| 国产乱理伦片在线观看夜一区| www国产精品av| 高清国产一区二区三区| 亚洲天堂2014| 精品视频色一区| 美美哒免费高清在线观看视频一区二区| 91精品婷婷国产综合久久性色| 日本91福利区| 久久久99精品免费观看| 成人黄色在线网站| 一区二区三区**美女毛片| 欧美写真视频网站| 青青草97国产精品免费观看 | 欧美国产精品劲爆| 色综合天天在线| 亚洲h在线观看| 欧美电视剧免费全集观看| 国产毛片精品视频| 亚洲欧洲日韩在线| 在线免费观看日韩欧美| 石原莉奈在线亚洲三区| 精品久久久久久久一区二区蜜臀| 成人精品国产福利| 夜色激情一区二区| 欧美电视剧在线看免费| jizz一区二区| 首页国产丝袜综合| 国产无一区二区| 欧美三片在线视频观看| 九一九一国产精品| 亚洲女同ⅹxx女同tv| 欧美一卡在线观看| 成人av免费网站| 日本欧美大码aⅴ在线播放| 久久久国产一区二区三区四区小说 | 中文字幕在线不卡| 91精品国产欧美一区二区18 | 日韩欧美国产三级电影视频| 懂色av一区二区在线播放| 亚洲国产成人高清精品| 久久精品亚洲国产奇米99| 色婷婷久久99综合精品jk白丝 | 欧美年轻男男videosbes| 国产九色精品成人porny| 亚洲一区二区视频在线| 久久久亚洲精品石原莉奈| 欧美自拍偷拍午夜视频| 国产精品一区二区三区网站| 夜夜爽夜夜爽精品视频| www国产成人免费观看视频 深夜成人网| 色综合久久中文综合久久牛| 国产一区在线看| 午夜精品爽啪视频| 日韩一区在线看| 久久久亚洲精华液精华液精华液| 在线亚洲+欧美+日本专区| 国产一区二区三区蝌蚪| 日日夜夜免费精品视频| 日韩美女精品在线| 久久精品男人的天堂| 7777精品久久久大香线蕉| 91麻豆免费看片| 国产精品一品二品| 另类的小说在线视频另类成人小视频在线 | 国产精品福利影院| 精品国产免费一区二区三区四区| 色偷偷久久人人79超碰人人澡| 国产一区二区美女诱惑| 日韩不卡一区二区| 亚洲一区av在线| 亚洲猫色日本管| 国产精品久久久久精k8| 久久久久久久久99精品| 91精品国产综合久久久久 | 国产精品久久777777| xf在线a精品一区二区视频网站| 正在播放亚洲一区| 欧美日韩一卡二卡三卡| 91视视频在线观看入口直接观看www| 激情综合色综合久久| 久久精品国产999大香线蕉| 亚洲成人动漫精品| 亚洲福利视频导航| 亚洲综合清纯丝袜自拍| 亚洲天堂2014| 成人欧美一区二区三区白人 | 亚洲一级在线观看| 一区二区三区不卡视频在线观看| 国产精品二三区| 国产精品久久久久久户外露出| 国产欧美精品在线观看|