Averaging AtoD samples


Closed Thread
Results 1 to 40 of 40

Hybrid View

  1. #1
    Join Date
    Nov 2003
    Location
    Greece
    Posts
    4,170


    Did you find this post helpful? Yes | No

    Default

    Have you tried Darrel's routine with values set high enough?

    Ioannis

  2. #2
    Join Date
    Mar 2009
    Posts
    653


    Did you find this post helpful? Yes | No

    Default

    Quote Originally Posted by Ioannis View Post
    Have you tried Darrel's routine with values set high enough?

    Ioannis
    I tried Darrel's averaging when I wanted to smooth out rapidly changing AtoD values (the output of a peak detect - whose level is proprtional to ac signal amplitude...and moves about a lot) - it worked very well in that situation.

    But for this situation - I really don't want the spurious compartor counts to be handled at all - I want them rejected...so no, I haven't used it in this instance....unless I've missed the point, I don't think it's what I need here?

  3. #3
    Join Date
    Nov 2003
    Location
    Greece
    Posts
    4,170


    Did you find this post helpful? Yes | No

    Default

    As long as the values don't hit the edges your are fine.

    Give it a chance.

    Ioannis

  4. #4
    Join Date
    Jul 2003
    Location
    Colorado Springs
    Posts
    4,959


    Did you find this post helpful? Yes | No

    Default

    I think the Fast Average section might be modified so that instead of jumping to the spurious noise point, it will reject the sample entirely.

    That should only take commenting 1 line from the original code.
    DT

  5. #5
    Join Date
    Mar 2009
    Posts
    653


    Did you find this post helpful? Yes | No

    Default

    Quote Originally Posted by Darrel Taylor View Post
    I think the Fast Average section might be modified so that instead of jumping to the spurious noise point, it will reject the sample entirely.

    That should only take commenting 1 line from the original code.
    I've broke the breadboard circuit up ....so can't test right yet. But this sounds cool.

    How does the averging code decide whether what's coming in is spurious...or in fact the beginning of a new stream of samples (eg a new frequency arriving, which will generate a different comparator count - with it's own spurious counts).

    I guess what I really need issome form of 'trigger' (or 'change' threshold) so that my program then knows that a new frequency is coming in (& is not just a spurious reading)...

    For example, red test below is spurious count, blue is new frequency arriving (therefore count changes and starts coming in at around that new level)

    5000,4999,5000,5001, 3956,5000,5001,5000,4999,5000,3789, 2570,2571,2569,2570,2571,18912569,2571....
    Last edited by HankMcSpank; - 21st October 2010 at 00:00.

  6. #6
    Join Date
    Aug 2010
    Location
    Maryland, USA
    Posts
    869


    Did you find this post helpful? Yes | No

    Default

    Hank, It seems to me you need to set some rules, or rather conditions. something like this:

    1) samples must be +- 10 of a target number to be included in the average
    2) numbers outside the +- 10 will need to have 2 more samples within the new samples range to be considered a good sample.

    That seems like it would weed out the rouge numbers. Now of course I have chosen random numbers. The 10 and 3. I don't really know what the numbers represent (I assume gutiar notes). Nor do I have a feel for how long a note will last. thats what drives the 10 number.
    -Bert

    The glass is not half full or half empty, Its twice as big as needed for the job!

    http://foamcasualty.com/ - Warbird R/C scratch building with foam!

  7. #7
    Join Date
    Jul 2003
    Location
    Colorado Springs
    Posts
    4,959


    Did you find this post helpful? Yes | No

    Default

    We choose to go to the moon. We choose to go to the moon in this decade and do the other things, not because they are easy, but because they are hard, because that goal will serve to organize and measure the best of our energies and skills, because that challenge is one that we are willing to accept, one we are unwilling to postpone, and one which we intend to win, and the others, too.
                John F. Kennedy
    Name:  AvgReject.JPG
Views: 2933
Size:  196.7 KB

    Notice in the image that all spurious samples were rejected.
    And where the samples changed from 6798 to 3899, the average caught up after 2 samples (adjustable with a constant).
    Code:
    DEFINE OSC 20
    
    DEFINE LCD_DREG PORTB 'LCD data port 
    DEFINE LCD_DBIT 0 'LCD data starting bit 0 or 4 
    DEFINE LCD_RSREG PORTB 'LCD register select port 
    DEFINE LCD_RSBIT 4 'LCD register select bit 
    DEFINE LCD_EREG PORTB 'LCD enable port 
    DEFINE LCD_EBIT 5 'LCD enable bit 
    DEFINE LCD_BITS 4 'LCD bus size 4 or 8 
    DEFINE LCD_LINES 2 'Number lines on LCD 
    DEFINE LCD_COMMANDUS 2000 'Command delay time in us 
    DEFINE LCD_DATAUS 50 'Data delay time in us 
    
    DEFINE HSER_RCSTA 90h ' Enable serial port & continuous receive
    DEFINE HSER_TXSTA 24h ' Enable transmit, BRGH = 1
    DEFINE HSER_SPBRG 129 ' 9600 Baud @ 20MHz, 0.16%
    DEFINE HSER_CLROERR 1 ' Clear overflow automatically
    
    '----[Averaging Options]------------------------------------------------------------------
    AvgCount	CON  16		' Number of samples to average
    FAspread	CON  50 	' Fast Average threshold +/-
    Reject          CON  2          ' Spurious Rejection level
    
    ;----[Variables]--------------------------------------------------------------------------
    Value		VAR  WORD
    RejCount        VAR  BYTE
    ADavg		VAR  WORD
    
    ;----[Initialize]-------------------------------------------------------------------------
    RejCount = 0
    ADavg = 0
    
    ;----[Main Program Loop]------------------------------------------------------------------
    Main:
        HSERIN [wait($FF),DEC Value]                                   ; get a sample
        HSEROUT ["Smpl= ",DEC Value]
        LCDOUT $FE,$80,"Smpl= ",DEC Value,"    "
        GOSUB Average                                                  ; average it
        HSEROUT ["  Avg= ",DEC ADavg] ;   ,"  Avg2= ",DEC ADavg2,13,10]
        IF RejCount > 0 THEN HSEROUT ["  Rejected"]                    ; indicate if rejected
        HSEROUT [13,10]
        LCDOUT $FE,$C0,"Avg = ",DEC Value,"    "
        LCDOUT $FE,$94,"FC  = ",DEC RejCount,"    "
    GOTO Main
    
    ' -=-=-=-=-=-=  Average Sample values -=-=-=-=-=-=-=-=-=-=
    Average:
        IF Value = ADavg Then RejCount = 0 : RETURN  ; NoChange
        IF ABS (Value - ADavg) > FAspread OR Value < AvgCount Then FastAvg
        IF ABS (Value - ADavg) < AvgCount Then RealClose
        ADavg = ADavg - (ADavg/AvgCount)
        ADavg = ADavg + (Value/AvgCount)
        RejCount = 0
        GoTo AVGok
      FastAvg:
        RejCount = RejCount + 1
        IF RejCount = Reject + 1 THEN 
            ADavg = Value
            RejCount = 0
        ENDIF
        GoTo AVGok
      RealClose:
        RejCount = 0
        ADavg = ADavg - (ADavg/(AvgCount/4))
        ADavg = ADavg + (Value/(AvgCount/4))
      AVGok:
        Value = ADavg			' Put Average back into Value
      NoChange:
    Return
    DT

Similar Threads

  1. Darrel's latest 16 bit averaging routine?
    By jellis00 in forum mel PIC BASIC Pro
    Replies: 9
    Last Post: - 17th October 2009, 02:57
  2. ADC Averaging
    By Sach_1979 in forum mel PIC BASIC Pro
    Replies: 4
    Last Post: - 21st September 2009, 07:53
  3. Atod Digital Filter
    By GeoJoe in forum mel PIC BASIC Pro
    Replies: 3
    Last Post: - 2nd April 2008, 18:04
  4. Microchip free samples in UK?
    By zoki008 in forum Off Topic
    Replies: 1
    Last Post: - 21st March 2006, 17:06
  5. Averaging & 16 maths
    By paul.mcallister in forum mel PIC BASIC Pro
    Replies: 2
    Last Post: - 22nd May 2005, 19:17

Members who have read this thread : 0

You do not have permission to view the list of names.

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts