Announcement

Collapse
No announcement yet.

Choosing a "universal" MCU/CPU

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

  • Choosing a "universal" MCU/CPU

    G'day everyone,

    I've been reading many threads in many forums, and it seems that there are a lot of CPUs being used with different projects. Some are using different CPUs with the same project!

    I was wondering if it would be worth collaborating to come up with a CPU/MCU that could be used by anyone.

    I'm thinking of polling to find what the most popular and most "user cuddly" IDEs and MCUs are being used right now. Then, since most MCUs differ by only a buck or two, it might be possible to define a "universal" MCU, with a standard codeset (PWM definitions for IB, PI, and so on, sample routines, some maths for analysis) that anyone could then pretty simply "tack together" with whatever their preferred front end and display would be.

    Kind of like an Arduino concept, except much simpler - here are 8 PWMs, 8 ADCs, 4 DACs, and 10 or 14 or 20 GPIOs, but with software that will drive PWMx at a definable rate, a sampler that reads ADCx at time xxnS, a simple array for ground samples, and so on and so forth.

    It would take a little bit more coding at the start, to ensure the "universality" of the code, but in the short, medium, and long term, it would be a HUGE advantage. People wouldn't need to keep reinventing the wheel, like so many of us are doing - how many people have developed a sampling or averaging routine that is more or less identical to someone else's routine, just on a different architecture?

    It seems that if we can get away from "my favourite controller type", and add the benefit of not having to write and debug ADC code and so on, then people could focus on the real fun - getting a fast, accurate front end, doing a great display, adding in logging that others can use, and so on.

    It's not an idea about making money, it's an idea about sharing and supporting, and hopefully getting people enough time that they can forget the nitty-gritty register code, and think about the bigger picture.

    I know there will be a lot of opposition to it (what if people choose an MCU I've never used before?), but the practical advantages would be enormous (it doesn't matter if I've never used that MCU before, because it's got a good IDE, the "drivers" are already written and debugged, and it's almost ready to run!).

    Obviously, the choice would need to be a higher-end device, and in that case, through-hole mounting might not be an option for the MCU. But that's where the designers come in - we can create a standardised MCU board, either with a device already hand-soldered on, (with ICSP, for sure), or at least the ability to obtain a well-made board, with the MCU that everyone is using, and that's two huge steps solved before we even think about programming!

    I'm not saying this will be perfect, but I would like people to consider this option, and maybe suggest better ways of doing the same thing.

    I hope this interests people. So what do you think?
    -PtB

  • #2
    Hi Pete, it's a good projet,i'm very interesting by this.

    Comment


    • #3
      I pretty agree with you, it does not sense to waste time to develop in several way the tools (the MCU HW and basically software routines); is much better to concentrate our brains on relevant and innovative detecting tecniques.

      In these days I am searching for an HW CPU/MCU base to use on my experiment and I am taking a look to the Arduino Due that seems have almost what could be need.
      http://arduino.cc/en/Main/ArduinoBoardDue

      Arduino Due is already a system ready to use, means hardware, most software library and IDE, and it is not expensive.

      So what common alternatives you and others are proposing on forum than give us better advantages? Is really needed to develop from scratch a complete new shared system for our needs? If yes I am ready to contribute, opinions are welcome.

      Comment


      • #4
        IMHO the best one would be the one that uses less current. My eyes were like this when I finally found this, otherwise well hidden, information for Raspberry PI.

        Comment


        • #5
          I suggest a wishlist which we all add to.

          When the wishlist stops growing we tally the list against worldwide availability, budget, IDE, A/D's etc etc etc for popular chips.

          S

          Comment


          • #6
            One potential way to dance about it might be to try and write as universal C programs as possible for various detector configurations. It would likely crop out hardware specific solutions such as timer/port interaction, but still leave a working, if less than optimal, baseline detector mcu.

            There's plenty of portability if one makes any/all hardware interaction through defined constants, and doesn't expect any particular hardware resource to be available. First and foremost one needs any/all timing and delay functions etc. to be freely swappable.

            A particular microcontroller would be one way to go (as long as it's in production!), but it leaves one vulnerable to the usual pitfalls of swapping to a fresh micro family. Be prepared for masses of support requests too!

            Comment


            • #7
              The #1 requirement as far as I'm concerned is the number of output compare modules. The OC is the basis for autonomous timing generators, critical for generating all the pulses we need, whether for PI or VLF. As I mentioned in another thread, STM32 and dsPic/Pic24 are two good choices here, I assume Pic32 as well though I haven't looked.

              Most micros have only up to 12b ADCs which is a little weak for MD design, so I would assume an external ADC and push this down the list. DACs are nice to have but are easy to add externally.

              External ADCs & DACs make built-in SPI support important. Then, DMA can also be useful.

              Low power is nice but somewhat relevant. The micro fades away compared to 500mA of average coil current.

              Other niceties might be USB support, LCD drivers, touch controllers, and quadrature decoders.

              Strong on-line support via community forums and cheap/free development libraries is important.

              Finally, a critical consideration is usability. The micro should either have a thru-hole option or an easily available and inexpensive eval/development board. And the compiler must be essentially free.

              Comment


              • #8
                Recently contacted by Silicon labs, they have been working away on u processors and I was not aware of it.

                I have designed them into GSM products probably 8yrs ago - but from their RF range.


                They do Free IDE and a grapghical IDE

                take a look.

                http://www.silabs.com/products/mcu/P...-software.aspx




                I also spotted a TI MSP 430 type device with a 16bit sigma delta A/d and a simple 12bit D/A, Im sure its lacking in some other areas.
                http://www.ti.com/product/msp430fg477

                S

                Comment

                Working...
                X