Announcement

Collapse
No announcement yet.

Digital PI redux

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

  • Digital PI redux

    Further to my comments under "Digital PI" below about the ADuC81x family and the limitations of the 805x core for DSP applications, I should perhaps expand on the subject for non-DSP types...

    There is a general issue with doing DSP-type operations efficiently on processors that do not have atomic instructions for key operations. In particular, the so-called bit-reversed indexing operations allow very efficient FFTs (Fast Fourier Transforms) to be carried out, and MAC instructions (Multiply-Accumulate) which are used by FIR and IIR digital filters. Other capabilities, such as doing multiple fetches and preloads are also important.

    Of course, any processor can implement FIR/FIR/FFT etc. algorithms, but the above mentioned instructions make a radical difference to the speed that they run at. PICs, AVRs, 805x etc. do not have these, and are consequentially relatively very slow on a cycle for cycle basis. Also, the instruction clock time for these processors tends to be low, e.g. a max of about 20MHz, which is simply not enought to do anything reasonable in DSP terms - a DSP-specific chip will do far far more per instruction than any generic device and anyway, they tend to run at very high clock speeds.

    So, lets look at the ADuC81x again. Its like an AD (Analog Devices) version of a PIC - it has ADCs as well as DACs, timers, EEPROM etc., but it has a 20MHz 8051 core rather than a PIC one... Essentially, then, it has the same problems - its not at all well suited to real-time DSP-style processing of data. Even if you drive the ADCs off interrupts in order to get more instruction cycles between samples, you will then have a non-deterministic core processing loop, making accurate timing very difficult for the sample/sample&hold gates.

    MicroChip has produced the dsPIC, which I haven't played with yet. These chips are really for low-speed DSP operations, such as motor control. To do significant DSP work (running FIRs etc.) you will require a faster and/or more specialised processor. The problem is that these tend to be power-hungry, and they are not really for amateur use as they tend to be fine-pitch LQFP or BGA packaged, typically requiring a minimum of 4-layer PCBs and 8mil (even 6mil)DRC clearance. Also, DSPs tend to be poor at driving slow-speed peripherals, such as displays - the ADuC81x gets away with this because it too is low speed (relatively) - but a real DSP chip will gag on trying to access a display as a memory or I/O mapped device - it will be hobbled.

    A compromise is to use a PIC or similar to drive the user interface, and the DSP to do the grunt work. This is a happy compromise - you can use any number of ways for the sub-systems to communicate, even serial interfaces, I2C, SPI etc.

    So, in summary, general purpose processors are good at just that - being general purpose. When it comes to very specialised applications, such as real-time signal processing, they fall down, and DSP-optimised processors are far, far better.

    HTH,

    Nicko

  • #2
    Re: Digital PI redux

    yes i like your coments and fully agree


    why not add a dsp core to the 4 metal design i have made

    and show us all how good your dsp skill can be with atmel cpu

    {better with a p2 household matchbox size cpu board}


    proteus has some nice skills for atmel stuff
    i dont realy like it too much and feal far happier with pic's and senix {ubicom now...}

    these run at 75 mhz and are optimised
    most compilers cross compile to senix stuff so it is very worthwhile esp as most pic come with a dsp core built in hareware > 16F87X eara .... but any pin can be anything anyway in a pic with most compilers
    however mobile phone cpu and dsp are more optimised for tasks requireing stuff that needs a good deal of brains

    pics and senix will suffice for common tasks
    and most mobile phones

    i will allow for data output to a master data processor that can be made to influence any part
    but ye if your up for it yourself
    cool

    Comment


    • #3
      Re: Digital PI redux

      Simeon,

      No disrespect, but I'm on a steep learning curve about metal detectors, and the way to learn is to do it yourself... The examples you posted are largely unintelligable - post simple GIFs/JPGs and you will get a much better response.

      The PICs have no DSP capability - they are risc cores that lack the key DSP-friendly instructions, and are far too slow for serious (or even semi-serious) DSP work... They are good enough to do the timing and UI control, but that's it. The Scenix etc. clones have strengths, but for me (and Robert) the AD devices look very promising...

      As mentioned elsewhere in this forum, the ADuC841 will be a very nice processor for PI use when its eventually released - its a usable physical package for amateurs, is fast enough even if it lacks the key instructions, it has a largely single-cycle core, it has the needed peripherals on-board, and is fairly low power.

      I really appreciate the information that others provide, and whenever I can, I try to contribute, but the established contributers here have a wealth of experience that takes a long time to accumulate. I don't expect too much from my first few PI detectors (in fact I assume I'll have a few completely no-hopers), though I am using unusual techniques...

      Nicko

      Comment


      • #4
        Re: Digital PI redux

        if you download proteus lite

        and install it
        you get access to the full diagram all functions of zoom and change sheet

        also you can add something and send it back if you like

        the url for the design

        http://homepage.ntlworld.com/vsm.libs/DESIGNS/4METAL_ENGINE.DSN


        the url for the 10 mb app

        is

        www.labcenter.co.uk/download/prolite.exe

        once you install it
        and it opens then open the design you have also downloaded

        then using the menu bar
        click design then choose a sheet

        to view each sheet {they are named in a list}

        use the mouse pointer and position where you want too zoom in and out
        click f5 f6 f7 f8 keys too zoom around the sheet {you get the hang in a few seconds}

        yes i would supply "a simple gif" but the schematic is complex
        and the principle is too

        so sorry but a simple gif is like no good

        as the design is changing by the day

        anyway the single sheet version {on another page} is easly saved too a folder and view by windows own internal viewer as a windows meta file {but the design is a book size getting bigger each day already 8 sheets

        so 8 gif's man is too much...

        sorry....



        after some email with carl

        i will prepair a pdf type ebook {does someone know some good freeware too do this ???easily from a meta file; dxf or etc multipage with colour}????


        also do any others have some time too spare for drawing diagrams in proteus {help the cause ......!!!}

        {the lite version of proteus is cheep for drawing and realy stable ... cheep stuff buy online}


        i dont realy see the issue with realy needing a gif.....

        gif's are restricted too 256 colours anyway....
        and distort the block size leading too pixelations if you use above very optimised a4 ??? my 8 sheets are a0 - a1


        dsp....s

        you simply supply a train of byte transitions and do what you want via a d/a like a digital pot
        or and you use the built in a/d
        this qualifies it as a hardware dsp also ....
        infact the center core of a hardware dsp
        then spill its info to a maths cpu set to dsp processor mode

        as it does all the work the unit you make using this as a board is then a dsp in strickt terms

        a pic is a dsp when used in dsp mode

        {put it this way..... dedicated...harware dsp cost 12 - 180 US$ factory direct pic and the three chips you need "to do the job" cost .... 12$ max }

        a dsp just simply uses known hardware wired lookups

        this is done in tables for a pic
        but take from ram or eeprom etc.....as the program runs



        take a look at the 4metal design

        yes
        i agree pics arent truly hardware core driven dsp

        infact they are better..... becouse they use far more instructions

        the fft and code units avalable for maths calc in a dsp are simply micro instructions
        and .......!!!!! can be added to most pic's anyway simply using different chips on a stamp type arrangement

        never close the door to the pic.....

        hehe nice too talk

        regards

        simeon




        Click Here

        Comment


        • #5
          Re: Digital PI redux

          i have just watched a german guy i know go down the whole single coil road using a dsp very similar too the Uc types your on about
          infact i have played around a little with these my self with audio
          instruments


          but .... but pics are far far more flexable when using the versions from ubicom
          these come with fully flashable core and instructions cores
          and allow for many orders of magnitude speed increases too be made ... ealisily running at 75mhz /4 4/75 = single instruction lengh
          of 50 ns..... or less...
          this is fast.....

          if you use turbo mode in the chip
          it breaks the functions into layers that exicute in strickt sequence order at orders of magnitude per task demand


          so very optimised

          yes as a processor working on maths
          a dsp is good
          but as a controller it isnt so good and has very strickt limits
          with very little higher level functions just a good maths handling capabilities

          Comment


          • #6
            Speaking of PIC processors...

            If you get frustrated with PIC processors while working on your PI project and need a good laugh have a look at this :-


            http://members.ozemail.com.au/~bobpar/pichate.htm

            Comment


            • #7
              Re: Speaking of PIC processors...

              i suppose that summs up his level of expertise....at programming them
              or he has too much money and no brain

              or likes killing poor risk cores in general.... o well aobtd

              i dont mean to be rude
              but a pic is a dspfunctions encoder
              makings it as a machine far more predictable if you take into account the time of the clock
              most multipic designs fall down becouse the clocks are out of sync ... only a main cpu should have its own clock

              the point of the detector i designed is
              not infact the cpu at a ll
              it is it is multi burst {packets} of pi time per coil then rx on another all three or just one
              tx on two rx on two etc etc etc

              to try to expand the actual knowlage
              taking into account as many parts of sound design that can be
              and desussing the real part of the detector which isnt just its ability to find a "piece of metal"
              so many people look over the fact that many finds are very important being able to say it looks like and here is a print {of say a big find} is important to research}
              find ruggets in rock easy in 3d


              so... if you like dsp coooll i like them i also find pic and senix very friendly ...for detecoors

              and connection to dsp using standard protocols like i2c and can etc..... rs 232 etc etc even parallel or serial shift to from
              complex displays can be set too be driven by one chip giving instant graphing .... abilities etcetc...

              they have there place as does the humble dsp....{unadjustable fixed type hardware.... only core programable } but usefull calculation tools nevertheless

              Comment


              • #8
                Re: Speaking of PIC processors...

                Simeon,

                > i suppose that summs up his level of
                > expertise....at programming them
                > or he has too much money and no brain

                Its called "a bit of fun" ;-) There's another site I quite like that details how to change a card in a PC using an angle grinder & a blow-torch...

                Don't be so serious - no-one is attacking PICs per se, the suggestion was just that for real time DSP, and by that I do not mean trivial ADC/DAC work, PICs simply do not have the grunt.

                You seem to be mis-understanding what the point being made was - DSP-optimised processors can certainly do loads of general purpose I/O - I have an ADSP-2191M system doing over 500,000 12 bit samples/sec, processing them by doing a short form FFT, dividing each frequency in the resultant spectra, aplying filters & other transforms, applying compensation (frequency dependant) for transducer non-linearity over the measured input frequency (10kHz - 150kHz), and then further compensating for acoustic absorbtion (very complex algorithm) due to ambient humidity which is not only RH, but also frequency and temperature, dependent, re-building the output stream and running the results through a 500ksamp/sec DAC.

                Now, no PIC/Scenix/whatever will do that because a) they don't have the grunt, and b) they were never ever designed to do it. BUT, the DSP cannot drive an LCD graphics display properly, but it can do general purpose i/o, but again not well...

                This should not descend into a "religous" agument about the pros & cons of PICs and real DSP systems - they each have their place in the toolkit of an engineer.

                What makes the ADuC841 so interesting is the package - it may not have the special instructions (its an 8052 core), but it has very high quality ADC/DSP/voltage ref etc. Its essentially a "PIC-style" processor & free toolset produced by one of the very best DSP companies in the world.

                Robert has chosen a good processor for what he wants to do. I, for one, applaud not only his experimentation, but that he has taken the time & trouble to explain clearly & simply what it is that he's doing...

                BTW. I have a small multi-PIC-driven robot that wanders round my sons' bedroom, picking up bits of their LEGO & Knex, and putting them in a box on its back. The PICs drive the stepper motors (12F675), the sensors, the battery management etc. I worked out it was taking the cleaner 2 hours each week to clean their room, and that adds up to about GBP 500 in a year of her time. The robot is cheaper, goes under their bunks to get the hidden bits, and is more cute ;-)

                Nicko

                Comment


                • #9
                  Re: Speaking of PIC processors...

                  you seem to miss my point

                  pic micros processing mundain low freq data and acting more as a dsp core than a dsp

                  picking up lego is quite a complex task ....
                  usually consuming energy and thought

                  i seem to remember picking up my own.....


                  as for the grunt

                  the well the grunt is only as big as his dad as wide as his mum and as stong as the steak pies you feed him....


                  so


                  realy i havent herd more ttaal and utter rubbish in a long time

                  keep going your almost in the hole ... youve dug for yourself.....

                  Comment


                  • #10
                    Re: Speaking of PIC processors...

                    listen i dont need this ....


                    i need help with what i a complex chalanging and demanding topic
                    regarding 4metal.....engine

                    NOTHING more i dont wish to arguee the merrits of pic micro

                    other than too add they make nice metal detectors when programmed properly {with no glitches in the software to accomodate the programmers inefficiences


                    these inefficiences slow down a project and make it no fun

                    the start detector is a prime example
                    this uses a pic 16X ic
                    although it is a good choice
                    the problem with it is simple
                    the auther choose the incorrect clock

                    it used a pic 54 then the code has a few re writes and it used a pic 84

                    {i have code for a 10 mhz xtal version {runs smooth as a slow gin}}


                    but all it lacks is a good lcd and get rid of the glitch in the software... like me..... i get a happy 1us tolerance now runing as low as 1us pulse lengh instruction the timing is much better
                    and the buttons run faster {to the tune point} memories load faster etc


                    the art in a pic is in its programmer

                    and no matter how you grind them up there all the same bare bones inside is the point i think you tried too make

                    however your speaking to a seasoned
                    veterin of mr pic and
                    it is a dsp controller providing data {very fast} that can be used BY a dsp to do maths calculations



                    .... get a life and help ...4metal dont argue the merrits of cpu who cares
                    as long as the grunt is up for the job inhand

                    and you dont try too do too much at once

                    you laughting.....

                    Comment


                    • #11
                      Re: Digital PI redux

                      i dont understand the flap about this cpu

                      it no better than a pic is no faster
                      and will if anything run much poorer than a pic877 or 876
                      with the addition of a 12dit d/a makes a nice oversampler using the onboard adc to resample the clocked dac outputs
                      giving only results
                      so using very little onboard power

                      it seems to only posses a 64k core memory also

                      hum....

                      arent analog just a little off the beaten track

                      anyway enough cpu...


                      i realy dont see the point in trying to stretch any single coil pi design
                      single coil is the limitation you all have here apart from me

                      i already know it works WAKE UP!!!!!
                      i realy dont see the point in using
                      one coil that gives about 1/2 meter of actual surface for the re radiated signals from a find {the most depth i have seen also}
                      to form a voltage on.....

                      so i guess youll all wake up too this eventualy


                      if you use 3 or 4 coils
                      to resample in sequence
                      using a large coil in the middle to provide a thud of emf

                      your laughting 5 times the power output
                      5 times more surface area {more like 10 time}

                      and a much more sensative front end
                      mean you get 2 - 3 meters in mineral soils ..... from multicoil pi

                      as opposed to 12 - 30 " on a lucky day... from a single coil

                      reams of figures arent needed
                      if you do a simple surface area check.....

                      poor yagi ... he must have screemed his head off at the delta loop boys of his day
                      he was told he "didnt have a clue about antennas by his friends who were radio guys {he was a mathematics genius}

                      and was prob feeling like i do .....


                      to be told that

                      "The examples you posted are largely unintelligable - post simple GIFs/JPGs and you will get a much better response"

                      is quite unreal when just a few simple steps open a design even an ADuC841 could carry out....

                      lol


                      here we simple add
                      your barking !!!!
                      to use a single coil
                      NO GAIN.... 0 db.... - thats all youll get

                      you can beef up the front end the back end what ever you want

                      but untill you provide more signal from the buried find and a better way to capture it
                      then you are all living the realms of a single coil fantasy



                      simply


                      barking.....

                      Comment


                      • #12
                        Re: Digital PI redux

                        gain in any system is achived the same way as a line of traffic

                        if you burr along behind a fast moving vehicle you get dragged along at a faster speed also you get it for free {gain} in the form of latching on to a faster moving "signal" or harmonic of a freq

                        by simply tuning an antenna to a resiprical of its original freq
                        you capture the power of the higher ones
                        this drags the signal your sending along faster... just like a racing car...

                        for rf this is very true
                        but for emf = rf but not radiated fully
                        and pi detectors {much like banging a drum that youve got your hand on the skin} {tends only to make the wood in the room shake but no sound..... comes back only vibrations
                        it is all down to the surface area at a given freq and the initail thump {that can be amplitude varied like banging a hammer on a wall to find a secret cavity or a dwang for a socket or something}

                        giving a certain amount of "back emf" in the form of a reflected voltage you then amplify

                        go click loudly
                        everything around goes click quietly
                        till you get a bigger ear or an ear with more gain..... or more ears

                        if you increase the surface area of your ear
                        the little click turn up a good few db
                        just look at a dog
                        it has super amplifer properties in its ears but a cat can hear 10,000 times better than a dog
                        a dog 100,000 times better than us

                        ask does the cat have bigger ears or more gain

                        neither
                        it uses its smells to cross referance then its selectivity to remove the rubbish
                        and has a different shape arrangement in its ears to convert the freq to a voltage

                        but an elephant can hear 0-20 khz for 150 miles
                        its hearing is 100,000 times better than a cat

                        and a stagering 100,000,000,000 times better than a human {ask what does it hear}

                        answer white noise and low freq

                        so the morral
                        is if you use bigger coils and sequenced to reject the rubbish
                        and you use a central thumb {to make targeting very easy} and also some comb filter techniques {active pic controlled}
                        {also changing the scanning technique once a find triggers a different cycle


                        you never have a certain limit imposed by the surface area you have


                        the other good point is
                        tuning coils to certain metals

                        then selecting these together
                        and a thumper
                        will increase the possability of finding that one and tuning the rest out

                        a good example is the good old ring pull

                        and a similar way ... in hardware descrimination uses by simply adding the phase shifted sym back into the signal path
                        canceling the selected phased freq or dc shift ... out....


                        ok the real world int a very good analergy


                        but the yagi antenna logarithmic periodics and antilogs
                        are the best
                        becouse they use the increased surface area and tack them self to higher freq carrier flux present around the fields the antenna percures when it comes online
                        {a radio works by sucking electrons from a reciever to make voltage shifts
                        and transmits rf in in the form of excited electrons in an oscilating stream}

                        using a single coil is like using a 1/4 wave in an rf hole ...

                        just dosnt cut it

                        but does work quite well for the local area

                        change to a 5/8 / 5/8 problem solved
                        simply becouse of the way it radiates with respect to a 1/4 wave lengh



                        in short digital {very digital} analysed pulse induction
                        is good too scan anything as long as you follow the rules of gain in a real system
                        and this relates totaly to surface area you cover with an rf /emf skin...... or a skin covers


                        and the way to accumulate relevent data...

                        Comment

                        Working...
                        X