Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Q&A

Post History

75%
+4 −0
Q&A When do I need to put anti-aliasing filter in front of SAR ADC?

Since your noise has "unknown characteristics", you should do low pass filtering in analog before the discrete sampling of the A/D. The two parameters that matter are the frequency content of the ...

posted 3y ago by Olin Lathrop‭

Answer
#1: Initial revision by user avatar Olin Lathrop‭ · 2022-04-01T20:31:52Z (almost 3 years ago)
Since your noise has "unknown characteristics", you should do low pass filtering in analog before the discrete sampling of the A/D.

The two parameters that matter are the frequency content of the signal, and the sampling rate.  In theory, nothing is lost as long as the sample rate is more than twice the highest frequency of the signal being sampled.  However, since you don't know what that highest frequency is, it's a good idea to attenuate any such high frequencies before sampling.

Over-sampling, then doing filtering in firmware is a legitimate strategy.  However, you still have to avoid aliasing at whatever rate you actually sample at.

Fortunately, the maximum signal frequency of 100 Hz is "low" for a modern microcontroller.  You have a lot of headroom to do over-sampling.  Since you have a lot of room, the analog filter doesn't need to be accurate or tight.  A single pole at 200 Hz should be good enough.  That leaves some room to not cut into the desired signal much, while still heavily attenuating frequencies that cause aliasing at doable sampling rates.

You didn't give specifics, but you can probably sample every 20 &micro;s at least, which means a rate of 50 kHz.  That in turn means only frequencies above 25 kHz will cause artifacts that you can't squash with the firmware filter.  Due to the 200 Hz analog low pass filter, such frequencies will be attenuated by (25 kHz)/(200 Hz) = 125 times, or 7 bits.  In addition, the noise amplitude at 25 kHz is probably already much smaller than the signal, but you haven't specified that.  Most likely 200 Hz analog low pass filter, followed by 50 kHz sampling, followed by firmware low pass filtering and decimation, will yield much better than 7 bits signal to noise ratio.

Since you mentioned sampling time, let's look at that too.  This has nothing directly to do with the above calculations, but does dictate a lower limit on the sampling period.

Overall there is a 7 pF cap driven by 10.7 k&Omega; resitance.  The time constant is therefore (7 pF)(10.7 k&Omega;) = 75 ns.  The 1/2 of full scale settling time (the "half life") is 0.693 of that, or 52 ns.  That's a useful number because it tells you how long you need to wait for each additional bit of accuracy.  If you want 10-bit accuracy, for example, then you need to sample for 519 ns, and 623 ns to get 12 bits.  This sample time is added to the A/D conversion time to get the minimum overall period you can sample the signal with.