资料下载地址:STM32单片机智能电表交流电压电流程序设计(电流 电压互感器TV1005M+TA1005M)
1、摘要
5、基于STM32F103单片机智能电表交流电压电流设计 本设计由STM32单片机核心板电路+交流电压电流检测模块电路+WIFI模块电路+指示灯电路组成。 1、通过电压互感器TV1005M和电流互感器TA1005M分别检测交流电压和交流电流值, 2、手机APP和WiFi模块互联后,可以实时显示交流电压、交流电流、功率和电量实时显示在手机上。 3、当功率超过200W时,继电器自动断开。功率不超过200W时,可以手动控制继电器的开关。 4、手机和WiFi模块连接后,手机上显示计时时间。 |
名称:AUAISOUT000
IP及端口号:10.10.10.11:8080
接受内容:
V:123A:12345P:1234567Q:1234567.89T:123R:1
说明:(只增加R部分命令及发送内容,其他未变动)
V:123 表示123V交流电压 字符5个长度不变 如12V 表示V:012
A:12345 表示12.345A交流电流
P:1234567 表示1234.567W 瞬时功率 即缩小1000倍
Q:1234567.89 表示1.23456789 度 缩小1000000倍 因为度的单位比较大kwh
T:1234 表示1234S 单片机设备运行时间
R:1 表示继电器接通 供电中 0表示断开即过载
发送内容:*或者# #断开供电 *接通供电
元件清单:
极性电容 10uF
电阻 1K
STM32核心板 STM32_CORE
交流电压电流检测模块 交流电压电流检测
ESP8266/WIFI模块 WIFI_ESP8266
220V公头线 2芯公头
220V母头线 2芯母头
2.54单排座 3pin
2.54单排座 4pin
2.54单排座 5pin
2.54单排座 20pin
覆铜板或万用板 /
普通USB线_大头 /
导线(只万用板有) /
焊锡 /
2、代码
#include "led.h"
#include "delay.h"
#include "sys.h"
#include "usart.h"
#include "lcd.h"
#include "adc.h"
#include <stdio.h>
#include "timer.h"//char tabDataV[5];//打印电压数组
//char tabDataA[7];//打印电流数组
//char tabDataP[9];//打印功率数组
//char tabDataQ[12];//打印电量数组
//char tabDataT[6];//打印时间数组
char tabData[42];//打印时间数组unsigned int ACcurrent; //市电电流
unsigned int ACvolt; //市电电压
unsigned long PowerWt=0;//功率
float PowerQd=0;//功率
unsigned char relayFlag=1;
int main(void){ u16 adcx;float temp;delay_init(); //延时函数初始化 uart_init(9600); //串口初始化为115200TIM3_Int_Init(499,7199);//50ms LED_Init(); //初始化与LED连接的硬件接口LED0=0;Adc_Init(); //ADC初始化 RELAY=1; //继电器打开relayFlag=1; //继电器状态标识delay_ms(4000); printf("AT+CIPMUX=1\r\n"); //允许链接delay_ms(1000);printf("AT+CIPSERVER=1,8080\r\n"); //创建端口号8080delay_ms(1000); while(1){adcx=Get_Adc_Average(ADC_Channel_1,10);// PA1 交流电压检测口 ad转换10次求平均值temp=(float)adcx*(3.3/4096);ACvolt=(unsigned int)(temp*303);//*303 互感器计算获取 以及1K电阻 用示波器检测校准得到if(ACvolt<15) ACvolt=0;adcx=Get_Adc_Average(ADC_Channel_2,10); // PA2 求平均值temp=(float)adcx*(3.3/4096);if(temp>0.02){ACcurrent=(unsigned int)((temp-0.02)*3100);//*3950 互感器计算获取扩大1000倍 以及1K电阻 用示波器检测校准得到 0.02去除波动 防止误判断}else{ACcurrent=0;}if(ACcurrent<50)ACcurrent=0;//滤除电流PowerWt=ACvolt*ACcurrent; //功率if(dealFlag==1)//处理标志{dealFlag=0;PowerQd=(float)PowerWt*1/60.0/60.0+PowerQd; //累计电量 1表示1s 因为电流扩大了1000倍 因此该处也扩大了1000倍 且此处功率单位为W 除以1000为千瓦 结果为度 1度=1千瓦时}if(times>=9999){times=0;}if(PowerWt/1000>200){ RELAY=0; //关闭继电器relayFlag=0;} sprintf(tabData,"V:%03dA:%05dP:%07luQ:%010.2fT:%04dR:1",ACvolt,ACcurrent,PowerWt,PowerQd,times);
// sprintf(tabDataA,"A:%05d",ACcurrent);//电流
// sprintf(tabDataP,"P:%07lu",PowerWt);//功率
// sprintf(tabDataQ,"Q:%010.2f",PowerQd);//电量
// sprintf(tabDataT,"T:%04d",times);//时间if(relayFlag==1){sprintf(tabData,"V:%03dA:%05dP:%07luQ:%010.2fT:%04dR:1",ACvolt,ACcurrent,PowerWt,PowerQd,times); }//打印数据else {sprintf(tabData,"V:%03dA:%05dP:%07luQ:%010.2fT:%04dR:0",ACvolt,ACcurrent,PowerWt,PowerQd,times); }//打印数据printf("AT+CIPSEND=0,42\r\n"); //发送固定字节数据的at命令delay_ms(200);printf(tabData); //发送数据delay_ms(200);LED0=!LED0; //数据发送 delay_ms(200); //延时}
}