Announcement

Collapse
No announcement yet.

Simple digital-assisted BFO detector

Collapse
X
 
  • Filter
  • Time
  • Show
Clear All
new posts

  • Simple digital-assisted BFO detector

    Following the "simple" detectors that are popping up on the forums, here's a simple low power method of (yet another) BFO detector, with a bit of "twist" which I believe hasn't been shown previously. It uses a digital method of frequency difference multiplication to take advantage of a lower search oscillator frequency, a hint of discrimination, low power draw and tuning by a pushbutton. The last two features are necessary to reduce frustration as I designed it to be a kids toy

    From what I've measured, freq shift based discrimination works less well at higher frequencies (300-800kHz) where some conductive targets start to behave like ferrites and vice versa. Ground penetration is also horrible at 800..400kHz compared to 100..50kHz. The disadvantage of running a lower frequency is a lower frequency difference, but the digital gain will help restore that lost sensitivity. It's also non-motion, it would be relatively simple to make it a motion detector with some software changes.

    There are some discrete digital implementations of harmonic mixers for multiplying the frequency difference, but they usually result in a less "clicky" triangle wave output, lack self tuning, and modern programmable complex devices are already available for about the price of separate discretes and board area.

    It works in the following way:
    -A simple colpitts search oscillator is hooked to a comparator input of a 20MHz clocked AVR microcontroller. The comparator input gives the oscillator's cycle time in microcontroller clocks (ie. 20MHz xtal clock, 100kHz oscillator = 200 mcu clocks).
    -To tune the detector, 65536 cycle time samples are taken and summed together, then divided by the same number (shifted 16 bits toward lsb) to make a "fixed point" tuning value - effectively the fractional average of all 65536 samples. There will be a slight error due to fractional phase difference between the start and end of tuning measurement.
    -A 24 or 32 bit phase accu variable is then set up, fixed point - meaning the less significant 16 bits are the fractional part, and the more significant bits are the integer. For each following oscillator cycle, the cycle time is added into the phase accumulator at the integer point, and the tuning value is subtracted from the phase accumulator.
    -The phase accumulator will start growing an error that's either positive or negative depending on the frequency shift. If we sound a click whenever it grows as large as the tuning value, we will output the frequency difference in clicks. We can also get digital gain from the system by sounding a click at lower differences - we can get 16x the frequency difference if we sound a click every 1/16th of the difference value.
    -If we also make note of positive or negative frequency shift, we can give some crude target identification for conductive (rising freq) and ferrous (falling freq) targets.

    I imagine this method to be applicable to just about any simple cheap microcontroller. The micro could also give battery voltage indication, add a degree of continuous auto-tuning (currently experimenting with this one), and maybe even give an indication of the search osc frequency to help in setting up the search coil for those building the thing as a project with just a pre-programmed microcontroller.

    Here's a video from bench-testing. 8" kitchen foil shielded coil, 33 turns of blasting wire, 100kHz jfet colpitts-oscillator. Pardon the low volume and poor lighting, but the response should be noticeable and the distances possible to gauge by eye. Absolute detection distance is hard to gauge, since the output is a multiplied frequency shift, and it hasn't been ground tested yet because of frozen earth.
    http://www.youtube.com/watch?v=ymLzpCrZyuk
    First test object is a beer can (emptied), second is a key bundle, third is 1euro coin, and fourth is a key rotated to show changes in response compared to target angle.

    One good point is that the current draw for this apparatus is around 15..20mA using a piezo speaker and bicolor power-led/target-identification, and a 9V battery would last a long time. Further power reduction could be had by sleeping the microcontroller between calculations. I haven't had the chance to do ground testing since it's frozen, but I will once spring arrives over here.

    When I have the time, I will clean up and post my schematic and asm source over here. It would be interesting to hear if that principle has been used previously or if someone can make use of it. This would probably work as a pinpointer as well, like other simple low power detector projects.

  • #2
    Hello!

    I am certainly interested to hear more about your method. Wached your video, and this is very pleasant sound that your apparatus makes.
    Althoug I can not fully understand the explanation right now. It seems like something to do with the Reciprocal frequency counting, this is the tecnique for very accurately comparing the input frequency with the microcontroller clock frequency. Followed by digital filter can make accuracy even more better.
    But what you describe may be even better for the purpose. Sure waiting for the schematic and asm source.

    Teemo

    Comment


    • #3
      I made a couple BFO MDs back in the late 60's. Transistors and parts came from Japanese 5 or 6 transistor radios.

      The MDs were crap. Folks with more money than me bought BFO MDs. They were mostly crap.

      Now I'm prone to think that it was lack of knowledge that was the root of all the crap. But I think you are trying to over-complicate BFO MDs.

      Now can we design and build stable LC oscillators? Yes. Can we do this at say 100KHz? Sure. As a ham and a home-brewer, I know that a LC oscillator needs a stable voltage source, temperature and a stable load. The stable load is where we use digital technology and create a comb of square-wave harmonics. Oh, temperature? Just stable is all you need. Insulate the coil, perhaps spray foam?

      There is no reason to have the transmitter be variable in frequency. Tune the receiver instead. Best choice in my opinion is to VXO a ceramic resonator local oscillator. This is far more stable than an LC local oscillator yet offers far more tuning range than a traditional VXO. With wide enough tuning and the matrix conductivity is irrelevant.

      We will drag in a little more digital design for the receiver in the form of a variable band-reject audio filter. Yes, a simple notch filter. Tune the receiver to some heterodyne in the mid audio range and then notch it out. If you wish, a simple audio notch filter can be made using an IC as simple as a 741. The skirt won't be as steep, but that might be an advantage in actual usage.

      No tiresome whine to listen to, but a target induced frequency shift provides some idea of ferrous vs non-ferrous.

      Though I am no great fan of meters, one option is rectifying the output from the transmitter's digital buffer and feeding that to a meter. Remember, the eddy current that shifts the frequency also upsets the coil Q and oscillator output voltage will drop. Loaded loop detector stuff, eh?

      At least this is where I'm headed. I selected a BFO MD design as the most versatile under most all conditions. The usage is for gold prospecting, nuggets and lode.

      Oh well, just my thoughts. Subject to change as new data becomes available for analysis and possible integration.
      eric

      Comment


      • #4
        One of the reasons to step away from the two oscillator setup, and to use a digital rockbound reference (the method used is essentially the same as a DDS reference) was to have a detector tuneable with a single press of a button. When the tuning is done in the digital dds reference, there's no need for varicap etc. electronic tuning methods. The novelty of this circuit was in a single bjt oscillator, a handful of passives, and a small mcu to make an automatic tuned detector with added f shift sensitivity. There's probably plenty to be had by tweaking the search oscillator design, as demonstrated in other oscillator related threads. For the added complexity of additional parts and such, one could probably build one of the more advanced detector types.

        The prototype is currently resting in a piece of breadboard, and I'm working on a motion detector algorithm as well as a single tone output algorithm. The latter will probably be useful only together with the motion mode.

        Comment


        • #5
          I'm not trying to talk you out of experimenting with this idea at all. I'm just saying it is a bit overkill.

          Along the same lines, one could take the "Low Frequency Counter" concept out of the CMOS COOKBOOK and accomplish pretty much the same multiplier effect for a VLF xmtr oscillator. It is a lot easier to make a receiver vfo stable than a simple xmtr vfo with it's coil hanging out in the wind.

          Your idea did get me thinking back and I recalled a circuit in an old ARRL Ham Radio Handbook. So I went looking and in the 1977 Handbook was a circuit for a Phase Locked Oscillator for use as a xtal locked high frequency oscillator in receivers and transmitters. Basically it was a PLL circuit using 1 - 74H00 a couple MC1350 ICs and the rest was discretes. It used anywhere from a 200KHz to 1MHz xtal as the reference for HF outputs from 40-80MHz. Now here is where we start to play for big marbles. Make the reference clock the BFO transmitter LC oscillator.

          Like I said in my last post, I think BFO MDs got a bad rap due to a lot of bad engineering practices. I'm curious how yours turns out.
          eric

          Comment


          • #6
            With today's components, it's closer to being underkill. One-buck mcu, and a bjt? I bet any schematic from the CMOS cookbook has a handful of separate digital and analog ICs.

            The cpu alone saves another oscillator's worth of parts and a manual tuning capacitor/inductor/varicap. I wouldn't use bjt base capacitance (to reduce parts) for frequency control since it can sensitize oscillators to pulling. As it is, the system actually is a software DDS running at the search oscillator's frequency, with a handful of assembler lines for the search loop, and the only tuning component is a pushbutton. The only temperature sensitive part is the search oscillator.

            Comment

            Working...
            X