Skip to content
회로도전자부품
2014.01.20 18:39

Arduino Frequency Counter Library

조회 수 31361 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

Arduino Frequency Counter Library

참고 : http://interface.khm.de/index.php/lab/experiments/arduino-frequency-counter-library/

 

Download  >FreqCounter Library

Example Programm


#include <FreqCounter.h>

void setup() {
  Serial.begin(57600);                    // connect to the serial port
  Serial.println("Frequency Counter");
}

long int frq;
Void loop() {

 FreqCounter::f_comp= 8;             // Set compensation to 12
 FreqCounter::start(100);            // Start counting with gatetime of 100ms
 while (FreqCounter::f_ready == 0)         // wait until counter ready
 
 frq=FreqCounter::f_freq;            // read result
 Serial.println(frq);                // print result
 delay(20);
}


Preamplifier schematics


<br />



Source Codes

Updated 10/2010 ; works with atmega328; removed some glitches

Updated 1/2012 ; Arduino 1.0

Download  >FreqCounter Library


Forum

further questions to this topic can be discussed here:

http://arduino.cc/forum/index.php/topic,64219.0.html

http://www.arduino.cc/cgi-bin/yabb2/YaBB.pl?num=1231326297

 

 참고 : http://www.electronicsblog.net/arduino-frequency-counterduty-cycle-meter/

 

This meter gives the best results at 0 – 1000 Hz  range. It works by measuring square wave total and high period duration using 16 bit hardware counter.

음,, 1Khz까지 밖에 안되나?

 

attachInterrupt()

Description

Specifies a named Interrupt Service Routine (ISR) to call when an interrupt occurs. Replaces any previous function that was attached to the interrupt. Most Arduino boards have two external interrupts: numbers 0 (on digital pin 2) and 1 (on digital pin 3). The table below shows the available interrupt pins on various boards.

Board int.0 int.1 int.2 int.3 int.4 int.5
Uno, Ethernet 2 3        
Mega2560 2 3 21 20 19 18
Leonardo 3 2 0 1 7  
Due (see below)

 

 

As you may know frequency = 1/Period and  Duty Cycle = High period duration/total period duration.

Square wave signal is connected to Arduino Mega 21 pin, because this pin is input for external interrupt.

External interrupt from rising edge is enabled.

 

 

 

void setup()   { 

  lcd.begin(16, 2);

  pinMode(Button, INPUT);
  digitalWrite(Button, HIGH); //pull up resistor

  TIMSK1=0x01; // enabled global and timer overflow interrupt;
  TCCR1A = 0x00; // normal operation page 148 (mode0);
  attachInterrupt(2, interrupt, RISING);

}

x=0) Signal period’s beginning – rising edge triggers external interrupt. Counter value is saved to variable “count”, it contains measurement of signal total period.  16 bit counter is started (again from zero), but now external interrupt is set to be triggered by falling edge.

x=1) When falling edge occurs counter value is saved to variable “middle” , it contains measurement of signal high period. External interrupt is set to be triggered by rising edge.

void interrupt()
{
  if (!x) {
    count=TCNT1;
    TCNT1=0x000;  
    TCCR1B=prescaler;
    attachInterrupt(2, interrupt, FALLING);

  }

  else {
    middle=TCNT1;
    attachInterrupt(2, interrupt, RISING);

  }

  x=~x; 
}

Frequency counter for better accuracy have automatic 16 bit counter clock prescaler. Prescaler sets counter’s speed.

  • If speed is to high counter may overflow till signal period is ended
  • If speed is to low only small part of counter range’s(0-65536) is used, it cause reduced measurement accuracy.

Program increase prescaler(clock frequency divider) if counter overflow appears.

int divider[6] ={
  0,1,8,64,256,1024};

int prescaler=5;
ISR(TIMER1_OVF_vect) {

  if (prescaler<4) {
    prescaler++;
  }

}

In case only small smart part of counter range is used prescaler is reduced if it’s possible.

  if (prescaler>1) {

    if (usage<0.15) {
      prescaler--; 
      delay(200);
    } 

  }

Meter in action:

You can see that accuracy is decreasing when frequency increases, because counter speed is to low. DSO Nano v2 oscilloscope was used as signal source.

Full program:

//Arduino frequency counter/duty cycle meter
//www.electronicsblog.net/
#include <LiquidCrystal.h>

LiquidCrystal lcd(12, 11, 5, 4, 3, 2);

#define Button 52

int divider[6] ={
  0,1,8,64,256,1024};

int prescaler=5;

int b=0;

int screen =0;

double count =0;
double middle =0;
double usage =0;
char x=0;

ISR(TIMER1_OVF_vect) {

  if (prescaler<4) {
    prescaler++;
  }

}
void interrupt()
{
  if (!x) {
    count=TCNT1;
    TCNT1=0x000;  
    TCCR1B=prescaler;
    attachInterrupt(2, interrupt, FALLING);

  }

  else {
    middle=TCNT1;
    attachInterrupt(2, interrupt, RISING);

  }

  x=~x; 
}

void setup()   { 

  lcd.begin(16, 2);

  pinMode(Button, INPUT);
  digitalWrite(Button, HIGH); //pull up resistor

  TIMSK1=0x01; // enabled global and timer overflow interrupt;
  TCCR1A = 0x00; // normal operation page 148 (mode0);
  attachInterrupt(2, interrupt, RISING);

}

void loop()
{ 
/// screen modes
  switch (screen) {

  case 0: 

    lcd.setCursor(0, 0);
    lcd.print("                ");
    lcd.setCursor(0, 0);
    lcd.print("Freq ");
    lcd.print(16000000.0/divider[prescaler]/count);
    lcd.print(" Hz");
    lcd.setCursor(0, 1); 
    lcd.print("Duty ");  
    lcd.print(middle/count*100); 
    lcd.print(" % ");
    lcd.print("    "); 
    break;

  case 1:
    lcd.setCursor(0, 0);
    lcd.print("Period: ");
    lcd.setCursor(0, 1);
    lcd.print(0.0000625*divider[prescaler]*count);
    lcd.print(" ms     ");
    break;   

  case 2:
    lcd.setCursor(0, 0);
    lcd.print("H ");
    lcd.print(0.0000625*divider[prescaler]*middle);
    lcd.print(" ms    ");
    lcd.setCursor(0, 1);
    lcd.print("L ");
    lcd.print(0.0000625*divider[prescaler]*(count-middle));
    lcd.print(" ms    ");
    break;   

  case 3:
    lcd.setCursor(0, 0);
    lcd.print("Prescaler /");
    lcd.print(divider[prescaler]);
    lcd.setCursor(0, 1);
    lcd.print("Count.use ");
    usage=count/65536*100;
    lcd.print(usage);
    lcd.print("%  ");
    break; 

  }

  delay(250);

  if (prescaler>1) {

    if (usage<0.15) {
      prescaler--; 
      delay(200);
    } 

  }    

  ///button /////////

  if (!digitalRead(Button)&&!b) {

    screen++;
    if (screen==4) {
      screen=0 ;   
    }
    lcd.clear();

    b=3;

  };

  if (!b==0) b--;

}
 
로그인 후 댓글쓰기가 가능합니다.

?

List of Articles
번호 분류 제목 날짜 조회 수
173 회로도전자부품 신기하고도 무서운 자기장 1 2013.10.07 21528
172 회로도전자부품 Joule thief 회로(저전압 승압회로) 실험 결과 3 file 2013.10.10 34888
171 회로도전자부품 1.5V to 5V/12V DC/DC Converter with LT1073 2013.10.12 24725
170 회로도전자부품 BOOST LIST file 2013.10.12 16326
169 회로도전자부품 555 Timer Led 교차하여 깜빡이기 2013.10.15 18168
168 AVR 아두이노 전압측정(오실레이터가 없을때 활용) file 2013.10.18 27492
167 회로도전자부품 DC to DC 승압이론 file 2013.10.20 21331
166 회로도전자부품 주문한 부품 리스트 file 2013.10.26 20769
165 회로도전자부품 역기전력은 왜 입력전압보다 높게 나오는 이유(Volt Boost 원리) 2013.10.26 20212
164 회로도전자부품 555타이머의 Duty-Cycle을 55%이하로 사용시 회로도 file 2013.10.29 14627
163 회로도전자부품 LCD1602 사양 및 아두이노 연결방법 file 2013.10.31 20368
162 회로도전자부품 아두이노와 1602 LCD 연결 file 2013.11.06 15483
161 회로도전자부품 [아두이노와 PC의 시리얼통신] Serial Monitor로 LED 제어하기 file 2013.11.08 12742
160 회로도전자부품 음계와 주파수 2013.11.08 15537
159 회로도전자부품 트랜지스터 file 2013.11.14 11520
158 회로도전자부품 라디오 회로 file 2013.11.14 14919
157 회로도전자부품 옴의 법칙(Ohm's Law) 2013.11.14 13777
156 회로도전자부품 전자회로 계산기 1 2013.11.15 11114
155 회로도전자부품 안테나 길이 계산법 / 이론 2013.11.18 16936
154 회로도전자부품 청력테스트 프로그램(가청주파수) file 2013.11.18 13696
Board Pagination Prev 1 ... 3 4 5 6 7 ... 13 Next
/ 13

http://urin79.com

우린친구블로그

sketchbook5, 스케치북5

sketchbook5, 스케치북5

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

설치 취소