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

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

?? rms.c

?? TDK 6521 SOC 芯片 DEMO程序
?? C
字號:
/***************************************************************************
 * This code and information is provided "as is" without warranty of any   *
 * kind, either expressed or implied, including but not limited to the     *
 * implied warranties of merchantability and/or fitness for a particular   *
 * purpose.                                                                *
 *                                                                         *
 * Copyright (C) 2005 Teridian Semiconductor Corp. All Rights Reserved.    *
 ***************************************************************************/
//**************************************************************************
//  DESCRIPTION: 71M65xx POWER METER - root-mean-square.
// 
//  AUTHOR:  MTF
//
//  HISTORY: See end of file
//**************************************************************************
// File: RMS.C 
//
#include "options.h"
#if RMS_VALUES
#include "ce.h"
#include "defaults.h"
#include "lcd.h"
#include <math.h>
#include "mmath.h"
#include "meter.h"

// Decimals points: Vrms/Irms have an LSB of 0.1, the display is 1000
// A production meter might roll all the constants into these.
// 
#if M6520 || TRACE11
#define IRMSSCALE  4.90945E-03    // (1000/10)*sqrt(6.6952e-13*3600)
#define VRMSSCALE  4.90945E-03    // (1000/10)*sqrt(6.6952e-13*3600)
#elif TRACE13
#define IRMSSCALE  5.81861E-03     // (1000/10)*sqrt(9.4045e-13*3600)
#define VRMSSCALE  5.81861E-03     // (1000/10)*sqrt(9.4045e-13*3600)
#else
#error Unknown device
#endif

/*** Public variables declared within this module ***/
// None.

/*** Private functions declared within this module ***/
static void display_vrms (int32_t xdata *d);
static uint32_t Vrms (int32_t xdata *w);
static void display_irms (int32_t xdata *d);
static uint32_t Irms (int32_t xdata *w);
static int32_t sqrt_rms (int32_t x);

/*** Private variables declared within this module ***/
int32x_t dummy;

//===========================================================================//
void Compute_RMS (void)
{
   Irms_A = sqrt_rms (i0sqsum);
   Vrms_A = sqrt_rms (v0sqsum);
   Irms_B = sqrt_rms (i1sqsum);
   #if EQUATION != _1ELEMENT_2WIRE
   Vrms_B = sqrt_rms (v1sqsum);                          
   #else
   Vrms_B = 0;                          
   #endif
   #if EQUATION == _2ELEMENT_4WIRE_DELTA || EQUATION == _2ELEMENT_4WIRE_WYE || EQUATION == _3ELEMENT_4WIRE_WYE
   Irms_C = sqrt_rms (i2sqsum);
   #else
   Irms_C = 0;
   #endif
   #if EQUATION == _2ELEMENT_4WIRE_DELTA || EQUATION == _3ELEMENT_4WIRE_WYE
   Vrms_C = sqrt_rms (v2sqsum);
   #else
   Vrms_C = 0;
   #endif
   dummy = 0;
}
                                  
static int32_t sqrt_rms (int32_t x)
{
    if (x < 0)
        return (0);
    else
        return (lroundf(65536.0 * sqrt (x)));
}

static uint32_t Irms (int32_t xdata *w)   // Sqrt (sumsq) * Imax * scale.
{
    float f;
    // A production meter, with an unchangeable accumulation interval,
    // could roll the constants, Imax and sqrt() into a single constant.
    f = ((float)(*w))/65536.0;  // convert LSB to sqrt(i0sqsum)
    // samples is from ce.c, the number of samples per accumulation interval
    f *= IRMSSCALE * sqrt ( (32768. / 13.) / (float)(samples) );
    f *= (float)Imax;
    return lroundf(f);
}

static void display_irms (int32_t xdata *pf)
{
   LCD_Number (Irms (pf), 6, 3);	// Display upto six digits.
   LCD_3DP ();						// Three (3) Decimal Points.
   LCD_Amps ();
}                                            

// display Irms
void rms_i_lcd (uint8_t select_phase)
{
   int32_t xdata *pf;

   switch (select_phase)
   {
   default: // unused phase
      pf = &dummy;
      break;

   case 1:
      pf = &Irms_A;
      break;

   case 2:
      pf = &Irms_B;
      break;

   #if EQUATION == _2ELEMENT_4WIRE_DELTA || EQUATION == _2ELEMENT_4WIRE_WYE || EQUATION == _3ELEMENT_4WIRE_WYE
   case 3:
      pf = &Irms_C;
      break;
   #endif
   }
   display_irms (pf);
}

static uint32_t Vrms (int32_t xdata *w)   // sqrt (sumsq) * Vmax * scale.
{
    float f;
    // A production meter, with an unchangeable accumulation interval,
    // could roll the constants, Vmax and sqrt() into a single constant.
    f = ((float)(*w))/65536.0; // convert LSB to sqrt(v0sqsum)
    // samples is from ce.c, the number of samples per accumulation interval
    f *= VRMSSCALE * sqrt ( (32768. / 13.) / (float)(samples) );
    f *= (float)Vmax;
    return lroundf(f);
}

static void display_vrms (int32_t xdata *pf)
{
   LCD_Number (Vrms (pf), 6, 3);    // Display upto six digits.
   LCD_3DP ();						// Three (3) Decimal Points.
   LCD_Volts ();	
}                                             

// display Vrms
void rms_v_lcd (uint8_t select_phase)
{
   int32_t xdata * pv;

   switch (select_phase)
   {
   case 1:
      pv = &Vrms_A;
      break;

   // The 6521 is an exception, because it implements these
   // by running a wire to VB
   #if EQUATION == _2ELEMENT_3WIRE_DELTA || EQUATION == _2ELEMENT_4WIRE_WYE || EQUATION == _3ELEMENT_4WIRE_WYE
   case 2:
      pv = &Vrms_B;
      break;
   #endif

   #if EQUATION == _2ELEMENT_4WIRE_DELTA || EQUATION == _3ELEMENT_4WIRE_WYE
   case 3:
      pv = &Vrms_C;  // arrange to display zero for defaults
      break;
   #endif

   default: // unused phase
      pv = &dummy;
      break;
   }
   display_vrms (pv);
}


/***************************************************************************
 * History:
 * $Log: rms.c,v $
 * Revision 1.26  2006/10/13 00:51:11  tvander
 * Removed compile options for 6530, 6515;
 * renamed 6511 and 6513 to trace11 and trace13;
 * Binary verified unchanged from previous version.
 *
 * Revision 1.25  2006/09/29 08:58:25  tvander
 * Fixed display routine.
 *
 * Revision 1.24  2006/09/12 02:45:11  gmikef
 * *** empty log message ***
 *
 * Revision 1.23  2006/09/09 01:14:51  gmikef
 * *** empty log message ***
 *
 * Revision 1.22  2006/09/08 07:37:22  Michael T. Fischer
 * *** empty log message ***
 *
 * Revision 1.21  2006/06/14 02:46:38  tvander
 * Faster LCD display.
 *
 * Revision 1.20  2006/06/09 22:41:29  tvander
 * Now makes the voltage from element B available in the 6520
 *
 * Revision 1.19  2006/05/25 03:31:46  tvander
 * Renamed variables so nonvolatile variables can be switched to other definitions
 * of watt-hours (e.g. from absolute value to volt-amps or imports)
 * (meter.c, meter.h, pulse_src.c)
 * FIxed power factors so they zero correctly.
 * Fixed RMS to work with different accumulation interval.
 *
 * Revision 1.18  2006/05/18 23:18:53  tvander
 * 16K and 32K
 * First cut at new requirements.
 * 32K 6521 is grossly tested.
 * All others have a clean compile with C51 8.02
 *
 * Revision 1.17  2006/04/12 00:27:50  tvander
 * Debugged compilation with equations 3 and 4, on 6513
 *
 * Revision 1.16  2006/03/03 11:30:55  Michael T. Fischer
 * Prep for 6530 LCD, etc.
 *
 * Revision 1.15  2006/02/10 01:56:03  tvander
 * Was truncating fractional part of rms values.
 *
 * Revision 1.14  2006/01/27 01:12:21  gmikef
 * Handle "negative" squares.
 *
 * Revision 1.13  2006/01/20 21:28:19  gmikef
 * Moved "CE_Constants" to "ce.c" to get around linker bug.
 *
 * Revision 1.11  2006/01/10 04:07:51  gmikef
 * Added PDATA support for CE Outputs.
 *
 * Revision 1.10  2006/01/04 04:47:54  gmikef
 * Switched RMS and VA calculations to use floating point. (and Calibration).
 *
 * Revision 1.10  2005/12/31 00:13:36  gmikef
 * Switched to floating point arithmetic. Decided it is high even precision.
 * It is faster and no more code space.
 *
 * Revision 1.8  2005/09/22 23:45:20  tvander
 * Clean build all models and unit tests, updated copyright to be fore Teridian
 *
 * Revision 1.7  2005/09/13 19:26:56  tvander
 * Release 6521 CLI version for early customers.
 * RMS works.
 * Accumulation interval to 1 second.
 * Wrate slowed to 3.2 Kh/pulse for new accumulation interval.
 * Pulse outputs inverted, so they start dark.
 * LCD density increased from 1/3 bias to 1/2 bias, for demo PCB.
 * VAh code is included, but untested.
 *
 * Revision 1.6  2005/08/30 18:20:38  gmikef
 * *** empty log message ***
 *
 * Revision 1.5  2005/05/13 00:34:46  tvander
 * 6511/32k works
 * Integrated and debugged self-calibration.
 * The build has one unused segment, and no other errors or warnings.
 * default LCD and pulse displays appear OK.
 * EEPROM, software timers and hardware timers are all integrated.
 *
 * Revision 1.4  2005/05/04 00:57:40  gmikef
 * *** empty log message ***
 *
 * Revision 1.7  2005/05/03 02:18:53  gmikef
 * *** empty log message ***
 *
 * Revision 1.6  2005/05/02 18:03:09  gmikef
 * *** empty log message ***
 *
 * Revision 1.3  2005/04/30 02:15:27  gmikef
 * *** empty log message ***
 *
 * Revision 1.5  2005/04/27 21:38:10  gmikef
 * *** empty log message ***
 *
 * Copyright (C) 2005 Teridian Semiconductor Corp. All Rights Reserved.    *
 * this program is fully protected by the United States copyright          *
 * laws and is the property of Teridian Semiconductor Corporation.         *
 ***************************************************************************/
#endif // RMS_VALUES.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产91精品精华液一区二区三区| 国产亚洲欧洲997久久综合| 亚洲视频 欧洲视频| 99re亚洲国产精品| 一区二区在线观看免费视频播放| 欧美私人免费视频| 日本欧美久久久久免费播放网| 日韩免费看的电影| 国产成都精品91一区二区三 | 欧美精品久久天天躁| 日本aⅴ亚洲精品中文乱码| 日韩欧美一级片| 成人看片黄a免费看在线| 一区二区三区四区激情| 欧美大片国产精品| 成人免费视频caoporn| 亚洲国产日韩精品| 欧美成人国产一区二区| 成人av影院在线| 午夜不卡在线视频| 国产午夜精品理论片a级大结局 | 国产欧美一二三区| 91社区在线播放| 青青草国产成人99久久| 久久夜色精品国产噜噜av| 色久综合一二码| 国产呦萝稀缺另类资源| 亚洲精品乱码久久久久久日本蜜臀| 欧美情侣在线播放| 成人免费视频一区| 日韩精品1区2区3区| 综合亚洲深深色噜噜狠狠网站| 欧美一区二区私人影院日本| av电影在线观看完整版一区二区| 天天操天天综合网| 国产精品美女久久久久久久 | 久久网这里都是精品| 在线观看视频欧美| 成人一区二区在线观看| 视频一区中文字幕| 亚洲视频一二三区| 久久久久久久电影| 日韩欧美久久久| 欧美日韩第一区日日骚| 91女厕偷拍女厕偷拍高清| 国产精品一区二区无线| 日本成人在线看| 亚洲成人中文在线| 亚洲人成在线播放网站岛国| 久久精品免费在线观看| 日韩欧美国产wwwww| 91麻豆成人久久精品二区三区| 国产精品白丝av| 久久97超碰国产精品超碰| 婷婷综合另类小说色区| 亚洲三级久久久| 中文字幕一区二区不卡| 国产欧美日产一区| 久久久久久久综合日本| 精品久久久久久综合日本欧美| 91精品国产综合久久国产大片| 欧美亚洲综合久久| 99精品1区2区| 不卡一区中文字幕| 成人晚上爱看视频| 国产成人自拍高清视频在线免费播放| 欧美a级理论片| 日韩成人av影视| 亚洲成人精品一区| 亚洲成人激情综合网| 综合av第一页| 成人免费一区二区三区视频| 国产精品久久久久aaaa| 中文字幕精品—区二区四季| 中文乱码免费一区二区| 日本一区二区综合亚洲| 国产精品久久看| 中文字幕制服丝袜一区二区三区| 国产精品美女久久久久久| 国产精品久久久久aaaa| 亚洲欧洲制服丝袜| 一区二区三区在线播放| 亚洲宅男天堂在线观看无病毒| 伊人色综合久久天天人手人婷| 亚洲一区二区在线免费观看视频| 亚洲午夜精品久久久久久久久| 亚洲午夜久久久久中文字幕久| 一区二区视频在线| 亚洲人123区| 性欧美大战久久久久久久久| 日韩二区三区在线观看| 国内国产精品久久| 99久久免费精品| 在线观看日韩国产| 欧美一区二区日韩一区二区| 欧美mv和日韩mv国产网站| 国产亚洲视频系列| 亚洲欧美一区二区三区极速播放 | 日产欧产美韩系列久久99| 裸体健美xxxx欧美裸体表演| 激情久久五月天| eeuss鲁一区二区三区| 色综合久久天天综合网| 在线播放亚洲一区| 久久综合色播五月| 亚洲免费看黄网站| 蜜桃一区二区三区在线| 暴力调教一区二区三区| 欧美日韩一区二区三区四区 | 欧美日韩视频专区在线播放| 精品国产乱码久久久久久夜甘婷婷| 久久久电影一区二区三区| 综合久久久久久久| 另类欧美日韩国产在线| 99re视频精品| 精品久久久久久久久久久久久久久久久 | 欧美成人三级电影在线| 国产精品成人网| 免费成人性网站| 91麻豆免费看片| 欧美精品一区二区三区高清aⅴ | 中文字幕中文乱码欧美一区二区| 亚洲大片在线观看| 国产999精品久久久久久绿帽| 欧美视频一二三区| 中文字幕不卡在线观看| 日本网站在线观看一区二区三区| 国产一区二区三区美女| 色婷婷av一区二区| 国产亚洲一区二区三区在线观看| 亚洲一区二区三区中文字幕| 国产一区二区三区观看| 欧美日韩在线精品一区二区三区激情| 久久久久久久一区| 午夜视频在线观看一区二区| jizz一区二区| 久久嫩草精品久久久精品| 亚洲成av人在线观看| 成人免费毛片片v| 精品av久久707| 三级久久三级久久| 在线精品亚洲一区二区不卡| 国产蜜臀97一区二区三区| 久久国产精品99精品国产 | 国产精品黄色在线观看| 亚洲va欧美va人人爽| 99精品欧美一区二区蜜桃免费 | 99精品偷自拍| 国产欧美一区二区精品婷婷 | 日韩精品久久理论片| 欧美性欧美巨大黑白大战| 中文字幕亚洲电影| 国产91在线看| 国产女人18毛片水真多成人如厕 | 国产91精品一区二区麻豆网站| 欧美一级精品大片| 偷窥少妇高潮呻吟av久久免费| 欧美性生交片4| 亚洲激情图片小说视频| 色综合久久综合网欧美综合网| 亚洲欧洲性图库| 色综合天天综合网天天看片| 国产精品情趣视频| 国产999精品久久久久久绿帽| 精品久久久网站| 国产一区二区三区观看| 国产日韩欧美不卡在线| 国产成人在线视频免费播放| 欧美国产一区视频在线观看| 成人性视频免费网站| 亚洲欧洲精品一区二区三区| 91在线看国产| 一区二区三区在线播| 欧美精品一卡两卡| 蜜臀a∨国产成人精品| 日韩美女主播在线视频一区二区三区| 六月婷婷色综合| 久久久www成人免费毛片麻豆 | 亚洲黄色录像片| 欧美日韩一区不卡| 青青国产91久久久久久| 欧美一区二区国产| 国产盗摄一区二区三区| 国产精品第13页| 欧美日韩国产经典色站一区二区三区 | 国产成人av一区| 亚洲图片欧美激情| 777午夜精品视频在线播放| 美女诱惑一区二区| 国产亚洲精久久久久久| www.欧美.com| 亚洲高清免费在线| 26uuu另类欧美| 成人av电影在线观看| 亚洲不卡一区二区三区| 欧美va亚洲va香蕉在线| 97aⅴ精品视频一二三区| 五月天国产精品| 国产日韩精品一区二区三区在线| 91麻豆精品视频|