Реализация электронного счетчика электроэнергии на микроконтроллере серии MSP430FE42x
Резюме
В данном примере применения описывается, как реализовать электронный счетчик электроэнергии на микроконтроллере серии MSP430FE42x. Документ содержит описание некоторых основополагающих принципов и рекомендации по использованию микроконтроллеров серии MSP430FE42x, а также рисунки печатных плат и демонстрационные версии программ.
1 Введение
В данном примере применения описаны схема электрическая принципиальная и программное обеспечение электронного счетчика электроэнергии на микроконтроллере семейства MSP430FE42x. В качестве дополнения предполагается использовать руководство пользователя модуля ESP430CE1.
Микроконтроллеры семейства MSP430FE42x со встроенным сигнальным процессором ESP430CE1 для однофазного счетчика электроэнергии со встроенным аналоговым входным терминалом и температурным датчиком были разработаны специально для использования в устройствах измерения потребляемой мощности. ESP430CE1 выполняет большинство действий по измерению потребления электроэнергии автоматически, не используя ресурсы вычислительного ядра. Это позволяет сохранить ресурсы вычислительного ядра для использования их в других задачах, например для осуществления связи с другими устройствами. ESP430CE1 может работать с различными токовыми датчиками. В качестве токового датчика он может использовать Роговского без дополнительных внешних компонентов шунт, токовые трансформаторы (СТ), включая трансформаторы со связью по постоянному току и большим фазовым сдвигом, или катушки индуктивности. Все параметры могут быть настроены программно, а калибровочные константы могут быть сохранены во Flash памяти микроконтроллера MSP430 и переданы ESP430CE1 при инициации системы.
2 Аппаратная часть
Схема монтажной платы и блок-схема устройства приведены в приложении А и описываются в нижеследующих разделах данного примера применения. Монтажная плата может использоваться с токовыми трансформаторами или шунтами и может быть перестроена. Такая монтажная плата выпускается компанией Softbaugh и имеет серийный номер для заказа DE427. Заказать ее можно на сайте компании Softbaugh, адрес которого в интерненте www.softbaugh.com.
Подключение каналов V1, I1 и I2 показаны на схеме, приведенной в приложении А.
2.1 Использование шунта в качестве преобразователя тока
Рисунок 1. Блок-схема подключения шунта к двухпроводной однофазной сети
2.2 Использование CT в качестве преобразователя тока
Рисунок 2. Блок-схема подключения CT к двухпроводной однофазной сети
2.3 Подключение CT и шунта в качестве преобразователя тока, позволяющее обнаруживать несанкционированного подключения
Рисунок 3. Блок-схема подключения шунта и CT к двухпроводной однофазной сети, позволяющее обнаруживать несанкционированное подключение
2.4 Подключение CT для подключения к трехпроводным однофазным сетям, применяемым в США
Рисунок 4. Блок-схема ANSI электросчетчика, использующегося в трехпроводных однофазных сетях
2.5 Подключение входов датчиков напряжения
Печатная плата оснащена делителем напряжения, рассчитанным на работу в сетях со среднеквадратическим значением напряжения 230 В. Также она содержит схему защиты, рассчитанную на это напряжение.
Емкостной источник питания способен обеспечивать ток потребления до 4 мА. Необходимо обеспечить, чтобы ток потребления не превысил это допустимое значение. Для этого в демонстрационной схеме был использован светодиод с низким током свечения.
2.6 Подключение входов датчиков тока
На печатной плате имеется место для монтажа SMD резистора, используемого в качестве нагрузки для токового трансформатора, но этот резистор не установлен в поставляемой плате.
Замечание: нагрузочный резистор для СТ не установлен, но при подключении СТ его необходимо установить, иначе MSP430 будет поврежден.
2.7 Сглаживающий фильтр
В качестве сглаживающего фильтра рекомендуется использовать резистор номиналом 1 кОм, подключенный последовательно ко входу АЦП, и конденсатор номиналом 33 нФ, подключенный между входом преобразователя и землей. Для исключения влияния синфазных помех рекомендуется использовать сглаживающие фильтры в обоих каналах токового преобразователя.
2.8 Неиспользуемые каналы АЦП
Неиспользуемые каналы АЦП не должны быть ни к чему подключены.
3 Расчет констант для измерителя ESP430CE1
Измерителю необходимы константы, соответствующие примененным трансформаторам и/или шунтам. В данном разделе показан расчет констант для измерителя ESP430CE1.
3.1 Коэффициент преобразования по напряжению
Коэффициент преобразования по напряжению, в соответствии с которым пересчитывается реальное входное напряжение во входное напряжение модуля ESP430CE1 рассчитывается по приведенным ниже формулам:
V(inp.max) = VoltageGain x V (Line, Nom.) x sqrt(2) x R2 /(R1 + R2)
kV1 = Voltage (Line, nominal) x 2 x sqrt(2) / (215 x (1- (Vref – V(inp.max) x 2)/Vref) )
3.2 Коэффициент преобразования по току для шунта
Коэффициент преобразования по току для шунта, в соответствии с которым пересчитывается реальный входной ток в ток модуля ESP430CE1 рассчитывается по приведенным ниже формулам:
V(I, inp.max) = CurrentGain x Imax x R(Shunt) x sqrt(2)
kI1 = Current (Line, nominal) x 2 x sqrt(2) / (215 x (1- (Vref – V(I, inp.max) x 2)/Vref) )
3.3 Коэффициент преобразования по току для трансформатора тока
Коэффициент преобразования по току для трансформатора тока, в соответствии с которым пересчитывается реальный входной ток в ток модуля ESP430CE1 рассчитывается по приведенным ниже формулам:
V(I, inp.max) = CurrentGain x Imax / CTRatio x R(Burden) x sqrt(2)
kI1 = Current (Line, nominal) x 2 x sqrt(2) / (215 x (1- (Vref – V(I, inp.max) x 2)/Vref) )
3.4 Уровень прерывания по мощности
Уровень прерывания по мощности ESP430CE1 рассчитывается по следующей формуле:
InterruptLevel = Pulses/kWh x (1000 / 3600) x fADC / (kV1 x kI1 x 4096)
Pulses/kWh определяет сколько прерываний на каждый кВт*ч будет сформировано.
4 Калибровка измерителя
Калибровка электронного счетчика электроэнергии на базе микроконтроллера семейства MSP430 при помощи обычной калибровочной аппаратуры, используемой для калибровки обычных электросчетчиков, возможна, но неэффективна. Вычислительная мощность MSP430 позволяет делать это другими методами, которые приведены ниже.
Основная калибровка может быть инициализирована при помощи команды с0, переданной через UART. Для выполнения этой команды необходимо в файле parameter.h определить входные значения следующих параметров:
- calVoltage
- calCurrent
- calPhi
- calCosPhi
- calFreq
Калибровка фазового сдвига между током и напряжением должна быть выполнена с точностью 0.5 градуса, так как ошибка фазового сдвига, возникающая в датчиках, превышает это значение, поэтому более высокая точность не может быть достигнута.
Для калибровки счетчика электроэнергии необходимо разделить тракты измерения тока и напряжения. Это позволяет выполнить калибровку с малыми потерями энергии и определить величины напряжения, тока и фазового сдвига. На рисунке 5 показана схема включения электросчетчика при калибровке.
Рисунок 5. Электронный счетчик электроэнергии на MSP430 с внешними терминалами
4.1 Калибровка при непрерывном измерении
Нормальный рабочий режим ESP430CE1 устанавливается путем посылки вычислительным ядром команды SetMode. Величина измеренной мощности, записанная после каждого измерения в регистр ActEnSPer1 (и в регистр ActEnSPer2 для систем с двумя датчиками), преобразуется вычислительным ядром в сигнал с постоянной частотой, пропорциональный измеренной мощности. Для формирования сигнала с постоянной частотой может быть использован модуль таймера Timer_A.
При калибровке выполняются следующие действия:
- Вычислительное ядро устанавливает в нулевом контрольном регистре ESP430CE1 флаги Curr_I1, Curr_I2, соответствующие режиму измерения.
- Регистры параметров инициализируются для измерения мощности в нагрузке. Выполняется это при помощи команды SET_PARAM.
- После получения команды mSet_Mode ESP430CE1 переходит в режим измерения электроэнергии.
- Первый результат измерения, находящийся ActEnSPer1 (и ActEnSPer2 в системах с двумя датчиками), не используется, так как неизвестна точка начала.
- Следующие результаты измерений, находящиеся в ActEnSPer1 (и ActEnSPer2 в системах с двумя датчиками) являются правильными и используются для вычислений.
- Флаг St_ZCld в нулевом регистре состояния указывает, что при следующей доступной выборке (флаг St_NEVal установлен), новые результаты измерения за прошлый период доступны в регистрах ActEnSPer1 и ActEnSPer2.
- Вычислительное ядро сбрасывает флаг St_NEVal при помощи команды mCLR_EVENT и выполняет считывание данных (см. описание алгоритма считывания ниже).
- Если необходимо, например, для вычисления результата за больший период, последние четыре пункта повторяются.
Вышеупомянутые шаги повторяются и во второй калибровочной точке.
Калибровка обоих датчиков должна быть выполнена независимо. При калибровке одного датчика измерителя ток через второй датчик должен быть нулевым. И наоборот.
4.1.1 Формулы
Калибровка производится за один основной период (или за nper основных периодов) при двух токах нагрузки I1HI и I1LO. Номинальная вычисленная мощность для двух точек калибровки:
nHIcalc = Cz1 x I1HI x V1 x cos?1 x (nper / fmains) x (fADC / 4096) [шаги2]
nLOcalc = Cz1 x I1LO x V1 x cos?1 x (nper / fmains) x (fADC / 4096) [шаги2]
Результирующие значения для наклона и смещения:
Наклон: GainCorr1 = ((nHIcalc – nLOcalc) / (nHImeas – nLOmeas)) x 214
Смещение: Poffset = (((nHImeas x nLOcalc) – (nLOmes – nHIcalc)) / (nHImeas – nLOmeas)) x (fmains / nper) x (4096 / fADC),
где fmains – основная частота в Гц;
fADC – частота дискретизации АЦП в Гц (обычно 4096 Гц);
nper – количество основных периодов, использованных при калибровке;
nHIclac – вычисленная мощность в точке калибровки с высоким током в шагах в квадрате;
nHImaes – измеренная мощность в точке калибровки с высоким током в шагах в квадрате;
nLOclac – вычисленная мощность в точке калибровки с низким током в шагах в квадрате;
nLOmaes – измеренная мощность в точке калибровки с низким током в шагах в квадрате;
4.1.2 Пример калибровки
Для схемы, показанной на рисунке 1, калибровка производится при следующих условиях:
V1 = 230 В, I1HI= 20 A, I1LO = 1 A, cos?1 = 1, nper = 1, fADC = 2048 Гц, fmains = 50 Гц.
Тогда
nHIcalc = Cz1 x I1HI x V1 x cos?1 x (nper / fmains) x (fADC / 4096) = 29,322.80806 x 20 х 230 х 1 х (1 / 50) х (2048 / 4096) = 1,348,849.171 = 14,94F1h [шагов2]
nLOcalc = Cz1 x I1LO x V1 x cos?1 x (nper / fmains) x (fADC / 4096) = 29,322.80806 x 1 х 230 х 1 х (1 / 50) х (2048 / 4096) = 67,422.458 = 1,0772h [шагов2]
Результат измерения в обеих точках:
n1Himeas = 14,6040h (ошибка -1 % по сравнению с n1Hicalc = 14,94F1h)
n1Lomeas = 1,0CB7h (ошибка +2 % по сравнению с n1Localc = 1,0772h)
GainCorr1 = ((nHIcalc – nLOcalc) / (nHImeas – nLOmeas)) x 214 = ((14,94F1h – 1,0772h) / (14,6040h – 1,0CB7h)) x 214 = 40С0h
Poffset = (((nHImeas x nLOcalc) – (nLOmes – nHIcalc)) / (nHImeas – nLOmeas)) x (fmeins / nper) x (4096 / fADC) = (((14,6040h x 1,0772h) – (1,0CB7h – 14,94F1h)) / (14,6040h – 1,0CB7h)) x (50 / 1) x (4096 / 2048) = -215,489 = FFFC,B63Fh
Если точки калибровки исправить с учетом наклона и смещения, тогда:
ncorr = (nmeas x GainCorr1)) x 2-14 + (Poffset1) x (nper / fmains) x (fADC / 4096)
nHIcorr = 14,6040h x 40C0h x 2-14 +FFFC,B63Fh x ((1 x 2048) / (50 x 4096)) = 1,348,890 = 14,951Ah
nLOcorr = 1,0CB7h x 40C0h x 2-14 +FFFC,B63Fh x ((1 x 2048) / (50 x 4096)) = 67,441 = 1,0771h
Результирующая ошибка при обеих коррекциях равняется +3.1 Е-5, т.е. 31 ppm.
4.2 Калибровка при помощи ПК
На рисунке 6 показан один из возможных вариантов установки для калибровки электронных счетчиков электроэнергии. Электросчетчики подключены к последовательному порту ПК через последовательный порт USART0, работающий в режиме UART или SPI. Все необходимые для калибровки вычисления выполняются ПК, а MSP430 каждого электросчетчика только запоминает полученные корректировочные величины во встроенной памяти данных или внешней EEPROM памяти.
ПК управляет калибровочной установкой, состоящим из генератора напряжения, генератора тока и фазовращателя, через коммуникационный интерфейс. ПК считывает результаты умножения напряжения и тока, вычисленные встроенными АЦП (или количество импульсов Ws на выходе каждого электросчетчика) и сравнивает это значение со значением, полученным эталонным электросчетчиком, который является частью калибровочной аппаратуры. ПК вычисляет ошибку электросчетчика в одной (например, при номинальном токе) или двух (например, при максимальном и номинальном токе потребления) точках калибровки. По результатам этих ошибок вычисляются индивидуальные корректировочные коэффициенты для наклона и угла смещения и передаются в конкретный электросчетчик, в котором микроконтроллер MSP430 сохраняет эти значения.
Рисунок 6. Калибровка электронных электросчетчиков при помощи ПК
Формулы для вычисления значений калибровочных констант приведены в руководстве пользователя модуля ESP430CE1.
4.3 Самокалибровка
Другой метод калибровки использует способность MSP430 выполнять сложные вычисления. Основное преимущество этого метода калибровки - это простота: Для передачи данных при этом методе не требуется никаких проводных соединений (см. рисунок 7). Уравнения исправления ошибок, используемые измерителем во время теста, такие же, как и приведенные в приведенном выше разделе "Калибровка при непрерывном измерении".
- Измеритеи, которые будут калиброваться, переводятся в режим калибровки при помощи скрытого переключателя, UART, ключа, входного импульса и т.д.
- ПК включает калибровочную аппаратуру, которая отдает определенное количество энергии, измеряемое при помощи эталонного измерителя, калибруемым электросчетчикам..
- Электросчетчики измеряют выданное количество энергии и вычисляют значение электропотребления WEM1 для 100 % номинального тока Inom.
- После этого калибровочная аппаратура отключается (I = 0, U = 0). Это позволяет при необходимости вычислить и измерить смещение самого АЦП.
- ПК включает калибровочную аппаратуру, которая снова отдает электросчетчикам определенное количество электроэнергии (например 5 % Inom, 100 % Vnom, cos?=1). После этого аппаратура снова отключается (i = 0, U = 0).
- Счетчики снова измеряют электроэнергию и вычисляют значение WEM0 для 5 % номинального тока Inom.
- По двум значениям WEM1 и WEM0, найденным для 100 % и 5 % номинального тока Inom, электросчетчики вычисляют индивидуальные величины смещения и наклона.
- После калибровки можно провести простой визуальный тест:
- для обнуления индикаторов электросчетчики сбрасываются
- калибровочная аппаратура выдает точно определенное количество энергии (при различных значениях тока, напряжения и cos?)
- Визуально проверяется, чтобы на всех электросчетчиках отображалось одинаковая величина измеренного значения потребленной энергии
- По показаниям ЖКИ можно определить, что рассчитанные коэффициент наклона и смещения выходят за допустимые пределы.
Пример: если провести калибровку при следующих параметра:
- 10 000 Ws (100 % Inom, 100 % Vnom, cos? = 1)
- 5 000 Ws (100 % Inom, 100 % Vnom, cos? = 0.5)
калибруемые электросчетчики должны показать значение Ws, равное 15 900 ± допустимая точность. Если вычисленное значение выходит за допустимые пределы, то электросчетчик признается не прошедшим калибровку.
Рисунок 7. Самокалибровка электросчетчиков
5 Емкостной источник питания
На рисунке 8 показан емкостной источник питания, формирующий одно напряжение Vcc = +3 В. Если его выходного тока недостаточно, то можно использовать выходной буфер на базе NPN транзистора.
Уравнения для разработки приведенных ниже источников питания приводятся в разделе 3.8.3.2 "Емкостной источник питания" примера применения SLAA024. В данной главе описываются другие источники питания и уравнения для их расчета.
Рисунок 8. Емкостной источник питания
5.1 Детектор обнаружения отключения/включения линейного напряжения
Так как детектор падения напряжения ESP430CE1 объединен со счетчиком циклов линейного напряжения, то при пропадании линейного напряжения он не работает. Для обнаружения этого можно отслеживать нахождение VRMS в течение определенного интервала времени ниже заданного порога или использовать внешнюю цепь для детектирования отключения линейного питания. При использовании внешней цепи для снижения потребления можно отключать модуль ESP430CE1.
Рисунок 9. Детектирование наличия линейного напряжения
6 Рекомендации по трассировке печатной платы
6.1 Заземление
Правильная трассировка печатной платы очень важна для систем, использующих АЦП с высоким разрешением. Ниже приведены основные рекомендации по трассировке плат.
1. Использование, по возможности, отдельных шин аналоговой и цифровой "земли".
2. Максимально толстые дорожки от источника питания до выводов DVSS, AVSS, DVCC, и AVCC.
3. Установка конденсатора в точке схождения всех линий аналоговой "земли". Установка конденсатора в точке схождения всех цифровых "земель".
4. Конденсатор Cb следует расположить в точке схождения всех шин питания. Это необходимо для обеспечения низкого полного сопротивлению этого конденсатора.
5. AVSS и DVSS терминалы должны быть внешне соединены вместе.
6. AVCC и DVCC терминалы должны быть внешне соединены вместе.
7. Источник питания и накопительный конденсатор Cb должны быть расположен максимально близко друг к другу. Между выводами, подключенным к шинам аналогового и цифрового питания, должны быть установлены конденсаторы Ca и Cb.
8. Для развязки шин аналогового и цифрового питания необходимо использовать катушку индуктивности L. Также можно использовать и резистор, но при использовании катушки индуктивности обеспечивается лучшая фильтрация высоких частот.
9. Если по периметру печатной платы проходит дорожка, то она должна быть подключена к заземляющей шине платы.
Рисунок 10. Заземление аналого-цифрового преобразователя
6.2 Чувствительность к ЭМИ
На рисунке 11 упрощенно показана не оптимальная трассировка: серым выделены участки, способные принимать внешние наводки от внешних источников ЭМИ. Для снижения влияния внешних источников ЭМИ эти участи по площади должны быть минимальными.
Рисунок 11. Трассировка платы, чувствительной к внешним ЭМИ
На рисунке 12 показана печатная плата, имеющая оптимальную трассировку. Участки, являющиеся приемниками ЭМИ, имеют минимальную площадь.
Рисунок 12. Трассировка печатной платы, имеющей минимальную чувствительность к ЭМИ
7 Демонстрационная программа
7.1 Инициализация аналогового терминала
При отключенном модуле ESP430CE1, Вычислительное ядро MSP430 имеет доступ к модулю SD16 модулю. Сначала вычислительное ядро MSP430 должно сделать инициацию входного аналогового терминала. При этом производится установка коэффициента усиления, частоты дискретизации и частоты генератора синхроимпульсов для SD16:
//====================================================================
/**
* Подпрограмма инициализации аналогового терминала.
*
* Настройка модуля сигма-дельта АЦП в качестве аналогового терминала для
* резистивного счетчика, определяющего несанкционированное подключение,
* использующего токовый трансформатор и шунт в качестве токового датчика
* (см. настройку каналов 0 и 1).
*/
void init_analog_front_end(void)
{
/**
* Сначала проверяется, что встроенный сигнальный процессор отключен,
* в противном случае будет невозможно изменить данные в регистре SD16.
*
*/
ESPCTL &= ~ESPEN;
/**
* После этого выполняются основные настройки аналогового терминала,
* которые относятся ко всем каналам: выбор синхроимпульсов (SMCLK),
* параметров делителя (в зависимости от частоты SMCLK) и опорного
* напряжения.
*/
SD16CTL= SD16SSEL_1 // Выбор синхроимпульсов: SMCLK
// SD16CTL = 0x800 + SD16SSEL_1 // Clock Выбор синхроимпульсов: SMCLK + (Amp: )
#if (MCLK_FREQ == 2)
| SD16DIV_1 // деление на 2 => Частота синхроимпульсов АЦП: 1.094 МГц
#endif
#if (MCLK_FREQ == 4)
| SD16DIV_2 // деление на 4 => Частота синхроимпульсов АЦП: 1.094 МГц
#endif
#if (MCLK_FREQ == 8)
| SD16DIV_3 // деление на 8 => Частота синхроимпульсов АЦП: 1.094 МГц
#endif
| SD16REFON; // Использование встроенного ИОН
SD16CCTL0 = SD16INCH_0; // I1
SD16CCTL1 = SD16INCH_0; // I2
SD16CCTL2 = SD16INCH_0; // V
SD16CONF0 |= 0x70; //
SD16CONF1 |= 0x68; // Задержка синхроимпульсов АЦП 40 нс
// ===================================================================
/**
* - Выбор коэффициента усиления АЦП:
* - VIN,MAX(GAIN = 1) = 0.5V > VCT(пиковое)
* - VIN,MAX(GAIN = 2) = 0.25V < VCT(пиковое)
* - VIN,MAX(GAIN = 16) = 0.031V > VShunt(пиковое)
* - VIN,MAX(GAIN = 32) = 0.015V < VShunt(пиковое)
*/
// ===================================================================
// Настройка нулевого канала аналогового терминала - Ток 1
SD16INCTL0= I1_Gain; // Установка коэффициента усиления для нулевого канала (I1)
SD16CCTL0 |= SD16OSR_256; // Установка коэффициента дискретизации = 256 (по умолчанию)
// ===================================================================
// Настройка первого канала - Ток 2
SD16INCTL1= I2_Gain; // Установка коэффициента усиления первого канала (I2)
SD16CCTL1 |= SD16OSR_256; // Установка коэффициента дискретизации = 256 (по умолчанию)
// ===================================================================
// Настройка второго канала - Напряжение
SD16INCTL2= V_Gain; // Установка коэффициента (V)
SD16CCTL2 |= SD16OSR_256; // Установка коэффициента дискретизации = 256 (по умолчанию)
/**
* \Замечание
* Пожалуйста запомните, что коэффициент дискретизации для всех каналов должен
* быть идентичным. По умолчанию он равен 256.
*/
} // Конец init_analog_front_end()
7.2 Инициализация электросчетчика
Перед использованием ESP430CE1 надо настроить. Пример подпрограммы настройки модуля:
//====================================================================
/**
* Инициализация ESP430CE1.
*
*/
void init_esp_parameter(unsigned char flashvars)
{
volatile unsigned int timeout;
// /\ Предотвращение "оптимизации" переменных.
// Копирование значений инициализации в ОЗУ
if (flashvars) s_parameters = s_parameters_flash;
/**
* Проверяем, что встроенный сигнальный процессор
* активизирован,
*/
ESPCTL |= ESPEN;
MBCTL = 0;
/**
* и не находится в режиме измерения или калибровки,
*/
if ((RET0 & 0x8000) != 0)
{
// Перевод встроенного сигнального процессора в режим ”Idle”
MBOUT1= modeIDLE; // ESP_IDLE;
MBOUT0= mSET_MODE;
timeout= 0xffff;
while (((RET0 & 0x8000) != 0) && (timeout?? > 0)) ;
}
/**
* и готов принять сообщение, запрашивающее
* версию программного обеспечения.
*/
MBOUT0= mSWVERSION;
timeout= 0xffff;
do
{
while (((MBCTL & IN0IFG) == 0) && (timeout?? > 0)) ;
if (timeout == 0) { display_error(); return; }
} while (MBIN0 != mSWRDY);
firmware_version= MBIN1; // Запись версии программы.
/**
* После этого производится инициализация параметров.
*
* Control 0: выполняется установка для:
* - Канал измерения тока I2 ? детектирования несанкционированного подключения
* - Расчет абсолютного значения активной энергии
* (отрицательная энергия расценивается как несанкционированное подключение)
* - Переключение алгоритма для удаления постоянной составляющей тока I1
* - Переключение алгоритма для удаления постоянной составляющей тока I2
*/
set_parameter(mSET_CTRL0, defSET_CTRL0);
/**
* \установка номера измерения:
* т.е. 4096 * 50Hz. => прерывание раз в секунду
*/
set_parameter(mSET_INTRPTLEVL_LO, s_parameters.pSET_INTRPTLEVL.w[0]);
set_parameter(mSET_INTRPTLEVL_HI, s_parameters.pSET_INTRPTLEVL.w[1]);
/**
* Номинальная основная частота:
* т.е. 50 Гц.
*/
set_parameter(mSET_NOMFREQ, defSET_NOMFREQ);
/**
* Коррекция фазовой ошибки:
* Установка фазовой ошибки для тока 1/2 от номинальной основной частоты для
* токового трансформатора по его техническим характеристикам
* Фазовая ошибка шунта равна нулю.
*/
set_parameter(mSET_PHASECORR1, (int)s_parameters.pSET_PHASECORR1);
set_parameter(mSET_PHASECORR2, (int)s_parameters.pSET_PHASECORR2);
/** Настройка параметров для двух токов:
* Токовый трансформатор:
*
* Имеется две возможности настройки значений двух
* токов:
*/
set_parameter(mSET_ADAPTI1, defSET_ADAPTI1); // = 1 * POW_2_14 = 16384
set_parameter(mSET_ADAPTI2, defSET_ADAPTI2); // = 1 * POW_2_14 = 16384
/** Установка настроенного коэффициента усиления:
*/
set_parameter(mSET_GAINCORR1, s_parameters.pSET_GAINCORR1);
set_parameter(mSET_GAINCORR2, s_parameters.pSET_GAINCORR2);
/** Установка настроенного смещения:
*/
set_parameter(mSET_V1OFFSET, s_parameters.pSET_V1OFFSET);
set_parameter(mSET_I1OFFSET, s_parameters.pSET_I1OFFSET);
set_parameter(mSET_I2OFFSET, s_parameters.pSET_I2OFFSET);
// set_parameter(mSET_POFFSET1_LO, s_parameters.pSET_POFFSET1_LO);
// set_parameter(mSET_POFFSET1_HI, s_parameters.pSET_POFFSET1_LO);
/** Настроенные параметры становятся текущими: */
#if withStartCurrent == 1
set_parameter(mSET_STARTCURR_INT, s_parameters.pSET_STARTCURR_INT);
set_parameter(mSET_STARTCURR_FRAC, s_parameters.pSET_STARTCURR_FRAC);
#else
set_parameter(mSET_STARTCURR_INT, 0);
set_parameter(mSET_STARTCURR_FRAC, 0);
#endif
/** Параметры регулировки для периода удаления постоянной составляющей: */
set_parameter(mSET_DCREMPER, defSET_DCREMPER);
} // End of init_esp_parameter()} // Конец подпрограммы init_esp_parameter()
7.3 Программа Demo 1
Demo 1 – простая демонстрационная программа, которая инициализирует ESP430CE1 для измерения электрической энергии и вывода результата на индикатор. При этом происходит мигание светодиода. Эта программа может работать с отладочным комплектом Kickstart производства компании IAR.
Ниже приведены файлы демонстрационной программы их назначение:
Файл |
Назначение и функции |
Main.c |
Управляет инициализаций системы и вызывает функции для индикации обновленного значения, запрашиваемого подпрограммами обработки прерывания:
- Init FLL and System Clock
- Init Basic Timer and Real time Clock
- Init LCD
- Init analog front end
- Init ESP430CE1 Parameters
- Start Measurement
|
FET4xx_RTCwLCD.s43 |
Основная подпрограмма для обслуживания ЖКИ и RTC |
Display.c |
Подпрограмма высокого уровня для ЖКИ |
FLL.c |
Подпрограмма установки ФАПЧ и системы синхронизации |
PortFunc.c |
Подпрограмма обработки прерывания по порту Port1 |
TimerA.c |
Подпрограмма инициализации и обслуживания таймера Timer_A. Timer_A используется для формирования импульсов |
EMeter.c EMeter.c |
Содержит подпрограмму инициализации и подпрограмму обслуживания аналогового терминала, ESP430CE1 и прерывания от ESP430CE1 |
FE427_Measure_v3.ewp FE427_Measure_v3.eww |
Файлы проектов для программы Workbench версии 3 производства компании IAR |
FE427_Measure.ewp FE427_Measure.eww |
Файлы проектов для программы Workbench версии 2 производства компании IAR |
FE427_Measure.hzp FE427_Measure.hzs |
Файлы проектов для программы CrossStudio производства компании Rowley |
Блок – схема демонстрационной программы приведена на рисунке 13.
Рисунок 13. Блок – схема демонстрационной программы
7.4 Генерация импульса электропотребления
Этот импульс может быть использован для индикации определенного уровня потребленной энергии. Для формирования этого выходного сигнала может использоваться три метода.
7.4.1 Непосредственное использование выхода сигнала прерывания по уровню
В первом методе непосредственно используется выход источника прерывания модуля ESP430 по заданному уровню. Реализация этого метода весьма проста и не требует задействования дополнительных аппаратных или программных ресурсов. Но ввиду того, что измеряется энергия синусоидальных колебаний, этот сигнал может иметь некоторые переходные колебания.
Активизируется этого метода:
// *define TIMERA_PULSE_OUTPUT
// *define WITH_AVERAGING
7.4.2 Использование выхода модуля таймера Timer_A
Во втором методе для удаления переходных колебаний используется модуль таймера Timer_A. Этот метод приемлем для формирования импульсов с частотой до 30 Гц. Перед использованием этого метода в файле parameter.h необходимо сделать следующие установки.
*define TimerAClock TASSEL_1/* ACLK = 32 кГц
*define TACLOCK 32768ul
*define CLOCKSPERPERIOD (TACLOCK/defSET_NOMFREQ)
Активизация метода производится следующим образом:
*define TIMERA_PULSE_OUTPUT
// *define WITH_AVERAGING
7.4.3 Использование выхода модуля таймера Timer_A при усреднении
В третьем методе используется только модуль таймера Timer_A для усреднения по времени и формирования импульсов несущей частоты.
Активизация этого метода производится следующим образом:
*define TIMERA_PULSE_OUTPUT
*define WITH_AVERAGING
7.5 Управление
Имеется две кнопки, которые используются для выполнения следующих функций:
- S_A: Выключение модуля ESP430CE1 и перевод MSP430 в режим пониженного потребления. Часы реального времени при этом продолжают работать.
- S_B: Переключение между режимами индикации.
7.5.1 Файл Parameter.h
Все конфигурационные настройки выполняются в файле parameter.h. К ним относятся:
- Уровень выходного импульса.
- Коэффициенты передачи по напряжению и току
- Конфигурационные параметры для модуля ESP430CE1
#define для withDisplay позволяет масштабировать код для различных функций и размеров. Код использует функции с плавающей точкой для выхода UART и калибровки. Включение одной из этих двух частей увеличит размер кода.
Определение шунта, *define shunt, позволяет выбрать к чему будет подключен вход I1 - к шунту или трансформатору тока.
Для упрощения расчета основных параметров, используемых в файле parameter.h, можно использовать файл для Excel FE427_Settings.xls. После ввода требуемой информации в белые поля все параметры будут рассчитаны и отображены. По нажатию кнопки "Save Parameter to File" все параметры будут сохранены в файл ‘Test_Parameter.h’.
Этот файл с рассчитанными параметрами будет включен в исходный код вместо заданных по умолчанию в файле ‘Parameter.h’ параметров если снять ремаркирование со строки ‘#define Test’ в самом файле ‘Parameter.h’.
7.6 Демонстрационная программа Demo 2
Демонстрационная программа Demo 2 устанавливается как комплексное приложение, включающее в себя UART и некоторые подпрограммы автокалибровки, которые сохраняют параметры во flash память. Для вычисления электропотребления вместо функции формирования потребления по превышению заданного уровня используются возвращаемые модулем ESP430CE1 значения. Программа Demo 1 выполняет инициализацию модуля ESP430CE1, вывод данных на индикатор и осуществляет управление светодиодом индикации включения. Эта демонстрационная программа слишком большая, чтобы использоваться при помощи комплекта Kickstart компании IAR.
Демонстрационная программа Demo 2 включает в себя все файлы, содержащиеся в программе Demo 1, и файлы, приведенные в нижеследующей таблице:
Файл |
Содержание и функции |
UART.c |
Программа обслуживания прерываний приемника UART |
Comms_UART.c |
Подпрограммы обеспечения связи по UART:
- инициализация UART
- передача по UART
- прием по UART: Process_UART (эта подпрограмма обрабатывает полученную команду UART).
|
SendData.c |
Подпрограмма преобразования данных, предназначенных для передачи по UART |
Calibration.c |
Некоторые простые функции, которые могут использоваться для выполнения калибровки. Эти функции вызываются командами, передаваемыми по UART. |
7.6.1 Связь по UART
Формат передаваемых данных: 57600 / 8 N 1
Каждая команда должна заканчиваться символом 'CR'.
Команда ’h’ выводит в окне терминала приведенный ниже текст помощи:
Версия программного обеспечения MSP430FE427: 0114
Команды UART:
SHxx: Установка часов
SMxx: Установка минут
SSxx: Установка секунд
SDxx: Установка дня
SOxx: Установка месяца
SYxx: Установка года
Dx: Установка режима индикатора
D1: Отключение
D2: Время
D3: Дата
D4: Напряжение (В)
D5: Ток (A)
D6: Пиковое напряжение (В)
D7: Пиковое значение тока (A)
D8: Частота (Гц)
D9: CosPhi
DA: Температура
DB: Мощность (кВт)
DC: Электропотребление (кВт * ч)
H: показать текст помощи
Tx: установка тестового режима
R: сброс системы
Mx: Выполнение тестовых измерений в течение x*50 циклов
I: Инициализация
C0: Автокалибровка U / I / P / фазового сдвига
C1: Калибровка уровня прерывания
C2: Калибровка фазовой коррекции 1
C3: Калибровка фазовой коррекции 2
C4: Калибровка смещения V1
C5: Калибровка смещения I1
C6: Калибровка смещения I2
C9: Сохранение параметров во flash памяти
СА: Калибровка коэффициента передачи по напряжению
СВ: Калибровка коэффициента передачи по току
СС: Калибровка коэффициента передачи по мощности
+: Увеличение калибровочного значения
-: Уменьшение калибровочного значения
7.6.2 Калибровка
Основная часть процесса калибровки может быть выполнена при помощи UART команды 'C0'.
Для выполнения этой команды в файле parameter.h должны быть определены входные параметры:
- calVoltage
- calCurrent
- calPhi
- calCosPhi
- calFreq
По UART команде 'C9' рассчитанные значения могут быть сохранены во flash памяти.
7.6.3 Файл Parameter.h
Все конфигурационные настройки выполняются в файле parameter.h:
- Установка уровня выходного импульса
- Коэффициенты по напряжению и току
- Параметры настройки модуля ESP430CE1
#defines для withUARTComm, withCalibration, withDisplay позволяют изменять код для различных функций и размеров. Включение одной из этих двух частей увеличит размер кода.
Комментирование или разкомментирование соответствующих строк в файле parameter.h настраивает программу на работу с использованием шунта или трансформатора тока на входе I1:
Для предварительного расчета параметров можно использовать следующие формулы:
- defVRatio = kV1 / 1000 (расчет kV1 см. раздел в разделе "Коэффициент преобразования по напряжению")
- defIRatio = kI1 / 1000 (расчет kI1 см. в разделе "Коэффициент преобразования по току для шунта")
- defEnergieRatio = (defVRatio x defIRatio)
Подробнее см. в прилагаемом с исходном текстом программы файле Excel.
Приложение А. Печатная плата со стороны монтажа компонентов.
Рисунок А-1. Печатная плата со стороны монтажа компонентов.
Рисунок А-2. Схема электрическая принципиальная.
Рисунок А-3. Расположение компонентов на верхней стороне платы.
Рисунок А-4. Расположение компонентов на нижней стороне платы.
Таблица А-1. Перечень элементов.
Кол. |
Позиция |
Номинал |
Прибор |
Производитель |
4 |
C1, C3, C19, C21 |
100 nF |
CSMD0805 |
|
1 |
C13 |
10 мкФ |
ELKO |
|
3 |
C14, C15, C29 |
100 нФ |
|
|
1 |
С17 |
220 мкФ х 10 В |
ELKO |
|
1 |
C18 |
470 нФ х 200 В |
C-EU225-062X268 |
Phicomp |
4 |
C2, C4, C12, C16 |
10 мкФ |
ELKO |
|
6 |
C20, C22, C23, C24, C25, C26 |
33 нФ |
C-EUC4532 |
AVX |
1 |
C27 |
22 мкФ х 25 В |
CPOL-EUD/7343-31R |
AVX Typ: TAJ |
4 |
C5, C6, C7, C8 |
10 нФ |
CSMD0805 |
|
1 |
C9 |
10 нФ |
CSMD0805 |
|
2 |
D2, D3 |
LL103A |
BAS32 |
|
2 |
D7, D10 |
LL103A |
D |
|
2 |
DV1, DV2 |
5 В |
D_SUPPRESS |
|
1 |
G1 |
CR2032V |
CR2032V |
Varta |
2 |
IC2, IC3 |
TPS77030 |
TPS77001 |
Texas Instruments |
1 |
J1 |
SUP_CON |
SUP_CON |
|
6 |
L1, L2, L3, L4, L5, L6 |
1 мкГн |
L-US08050805 |
|
1 |
LCD |
SBLCDA2_DISPLAY |
SBLCDA2_DISPLAY |
Softbaugh |
2 |
LED1, LED2 |
Красный 3 мм светодиод |
LED3MM |
|
1 |
LED3 |
SFH486 |
LED5MM |
Infinion |
1 |
MSP1 |
|
FE427_CHIP |
Texas Instruments |
1 |
Q1 |
32 кГц |
QUARZ32K |
|
1 |
Q3 |
BC807-16SMD |
BC807-16SMD |
Philips (5Ap) |
1 |
R1 |
47 кОм |
R_0805 |
|
1 |
R16 |
569 Ом х 5 Вт |
R-EU_0817/7V |
|
2 |
R19, R20 |
820 Ом |
R_0805 |
|
3 |
R2, R3, R4 |
820 кОм |
R_0805 |
|
2 |
R21, R22 |
100 кОм |
R_0805 |
|
1 |
R23 |
0 Ом |
R_0805 |
|
6 |
R24, R25, R26, R42, R45, R47 |
1 кОм |
R_0805 |
|
2 |
R28, R37 |
275 В |
VARISTOR-2,5 |
EPCOS |
1 |
R29 |
10 Ом |
R_0805 |
|
1 |
R30 |
подбирается при настройке |
R_0805 |
|
1 |
R31 |
82 Ом |
R_0805 |
|
3 |
R38, R39, R40 |
330 кОм |
R_0805 |
|
1 |
R43 |
1,5 кОм |
R_0805 |
|
2 |
R44, R48 |
-- |
R_0805 |
|
1 |
R5 |
0 |
R_0805 |
|
1 |
R6 |
10 кОм |
R_0805 |
|
1 |
R7 |
470 кОм |
R_0805 |
|
1 |
RS232 |
ML10 |
ML10 |
|
5 |
S_A, S_A1, S_B, S_B1, S_B2 |
Переключатель |
Переключатель |
|
1 |
SV1 |
JTAG |
ML14 |
|
1 |
SV2 |
|
MA08-1 |
|
1 |
SV3 |
Переключатель выбора напряжения питания |
MA03-1@2 |
|
3 |
TP1, TP2, TP3 |
|
JP1E |
Connector row |
6 |
X1, X2, X3, X4, X5, X6 |
W236-1 |
W236-1 |
Wago 256 |
1 |
ZD1 |
рекоменд. 3.3 В |
D |
|
1 |
ZD2 |
3.9 В |
D |
|
Пример программы:
|
|
573Kb Исходный фаил реализации электронного счетчика электроэнергии |
|
|
748Kb Фаилы программ и другие необходимяе фаиля для реализации электронного счетчика электроэнергии |
|