5 Myths Everyone Believes about Arduino (that aren’t true)

Having spent the past 6 years writing code for the Arduino platform, I’ve noticed a trend in myths from both new-comers and veteran users. Here are the Top 5 Myths I see come up on forums, in classes, and on IRC.

1. The Arduino uses its own Language

This myth isn’t helped by the Arduino.cc home page which says

“The microcontroller on the board is programmed using the Arduino programming language.

While it is true that the structure of an Arduino sketch looks unique, it is really just C++ with a tiny bit of preprocessing. Users writing “Arduino Code” are actually writing C++ with, what I call, the Arduino Library. Functions like digitalWrite() are just that, C++ functions.

So while the Arduino Library does a great job of making microcontroller programming very simple, it is not its own language.

2. Pin 13 Has a Resistor

Countless tutorials have lulled newbies into this trap. The very first Arduino board, of which something like 200 were produced, had a LED and series resistor on Pin 13. That’s the only board which did. So you should never never never connect a LED to Pin 13, without a resistor!

Update: Clarification. There *is* a resistor on Pin 13. However, it is only connected to the LED that is in series with it to ground. So that resistor does *nothing* to protect anything you attach to the pin, like your own LED.

3. Commercial products don’t use Arduino

Corollary: “real” engineers don’t use Arduino!

Okay. I try not to toot this horn, but I’m a “real engineer.”  You already know that: it’s in my twitter name and URL. Here’s a top secret piece of information:  I use Arduino. Now it is true. You aren’t going to go to Best Buy or your local big-box electronics store and find any products that have an “Arduino Inside” sticker. However, Arduino is a prototyping platform. You aren’t going to ship an Uno with every product. You might, however, develop a product with an Arduino and embed the ATmega328 inside of it. Or, more likely, you’ll prototype the idea, run it through a crowd funding effort and then redesign.

You have to define what “commercial” means, but there are plenty of products out there that started with an Arduino in the early stages.

Ever hear of 3D printers?

4. analogWrite() is Analog

This one catches a lot of people who don’t really understand Pulse-Width Modulation. With the exception of the “Due”, Arduino boards do not output “analog” signals. (Note, you might want to watch this video on the difference between Analog and Digital.)

PWM signals are actually digital signals, where you change the length of time between the “on” and “off” states.

5. The Header Spacing was a mistake (or it wasn’t.)

If you know anything about the Arduino pinout, you should know that the spacing between pins 7 and 8 isn’t 0.1″ (or 2.54mm). At one point the Arduino web site had this in the FAQ as an “eleventh hour” mistake. Then there was the explanation that it prevented shields being plugged in backwards. Now, I’m not sure if it was intentional, but it is true that a benefit of the spacing is that you can’t plug in a shield backwards.

The perceived downside to this decision is that it makes the board difficult to plug into a breadboard, or a shield into a breadboard. However, magic jumper wires do exist which solve this “problem.”

Okay, so those are the 5 Myths I encounter most.

Question: What other myths have you heard or helped to dispel? You can leave a comment by clicking here.

Long comments, URLs, and code tend to get flagged for spam moderation. No need to resubmit.

ALL comments submitted with fake or throw-away services are deleted, regardless of content.

Don't be a dweeb.

Leave a comment

57 thoughts on “5 Myths Everyone Believes about Arduino (that aren’t true)

  1. I was reading about the header spacing issue some days ago, and there is a post on the arduino forums which confirms it was a mistake, the actual arduino “founder” himself confirmed he screwed up in the design and that they had no time to check the files, as the board manufacturer for the first batch had told them he needed the files next morning or they would be delayed for the next month.

  2. Real engineers now have the ability to make custom lab equipment for data measurement and acquisition that 10-15 years ago would have required an expensive license and data acquisition board from the 800 pound gorilla of data acquisition. As soon as another competitor for low cost boards popped up, they bought them and poof, no more inexpensive competition. For those of us engineers in experimental R&D, the explosion of low cost boards with modest data acquisition rates is nirvana. Sometimes you don’t have an undergrad/ grad student to sit and watch the test for time x logging temperature, or they can do higher level work actually analyzing the other data, or working out how the next step can be done. Now I can put together a miniature controlled environment chamber with a couple thermocouples, a thermoelectric cooler/heater, an Arduino and the PID library some kind soul worked out and shared with the world. It fits my sample! It compensates when the university shuts off the chillers in the fall and we have a heat wave! It slices and dices! Well, not yet, but the next version could!

    Real engineers use the technology that fits the requirements, and if you’re too snooty to use a low cost board that fits the actual needs, you may find yourself looking for another job, when the kid that can design and test within an order of magnitude finishes the proof of concept prototype at half the cost or half the time.

  3. about pin 13 it depends if you sink or source the pin 13 it will use the leds resiser if your using the pin as ground,ive never used resistor on that pin and its fine,if i do its verry dim lit as its usinf two tesistors,the other pins work brighter with the resistor wich seems to back up my theory,i could be totaly wrong of cource,this ive been told by arduino makers,

    • I’m not sure your statements make sense.

      From the Diecmila to the Uno R2, there was a current limiting resistor for the LED on the board. However, that has no effect on limiting current to an LED connected at the pin header. From the R3 on, an op-amp circuit was used to reduce loading that the LED and Resistor presented to the pin. Again, has no effect on what you attach to the pin.

      Your “experiment” would be better down with measurements, not a visual comparison.

  4. Four(ty) years ago I coont evn spel injuneer, now I are won. No offense intended to anyone. Maybe you hear the line also, “Really. You don’t look like an engineer.” Still never figured that one out, what are we supposed to look like? If I might paraphrase point number 3 thus allowing it’s removal from the myth list;

    Real engineers aren’t afraid to use Arduino.

  5. QUOTE: The very first Arduino board, of which something like 200 were produced, had a LED and series resistor on Pin 13. That’s the only board which did.

    Actually ALL current Arduino boards DO have “a LED and a [series] resistor” connected from pin 13 to ground.

    There is no SERIES resistor between the Atmel chip and the pin 13 connector.

    Regards, Terry King …In The Woods In Vermont

  6. -First of all thanks for the post.

    -Second, if I get it right, these statements below are all true:

    1) Let’s go on through an example. Let’s say I want to produce a rgb mood light and sell it commercially. And my product is something that does not need firmware upgrade or sth like that…

    I have an arduino board, rgb led and arduino sketch. I connect the rgb led with arduino and upload my skecth to it and it works when I power it. So this is basically a prototype.
    Now let’s say I want to sell it as a commercial product. Since using an arduino board in every product might cost a lot I decided to use an atmel chip instead. I programmed my atmel chip with arduino board and arduino ide. So my final product will have a chip and a led. And a casing.
    So I’m free to sell this product locally, worldwide or online without any copyright etc. restrictions? It does not have an arduino inside right?
    And I do not have to open up my sketch/circuit to public?

    2) Let’s say I’ve made a complicated device which needs to have an arduino inside to run. And some other components.
    I can make an arduino based on the open source diagram and use it inside my device. Add other components etc.
    And I do not have to mention that the device uses an arduino inside?
    And I do not have to open up my sketch/circuit to public?

    3) Same situation as number 2 but instead of making one, I buy arduino compatible boards and use them.
    And I do not have to mention that the device uses an arduino inside?
    And I do not have to open up my sketch/circuit to public?

    4) I use a sketch with gpl (without changing/modyfyng any codes) in my device.
    And I do not have to open up my circuit to public?
    And I do not have to mention the code inside is open source?

      • I would like to point out that the majority of 3D Printers are made with some form of Arduino (using RAMPS shield) or are an off shoot Arduino + RAMPS rolled into a single board. Marlin is one of the more popular firmwares and is programed using the Arduino IDE.
        So yes you can use Arduino commercially and yes engineers do use Arduinos that do go to market.

  7. There are many mis-understood things about the Arduino.

    The 5 items listed are some questions I have gotten about Arduinos as well.

    These (and many others) are the type of questions beginners ask, but not those whom have not started the learning process.

    Look at the “myths” proposed:

    1. The Arduino uses its own Language
    2. Pin 13 Has a Resistor
    3. Commercial products don’t use Arduino
    4. analogWrite() is Analog
    5. The Header Spacing was a mistake (or it wasn’t.)

    Items 2,4,5 are asked by those who have started learning about those things, that only someone who has looked at the manual or demo programs.

    Item 1 is Arduinos fault as baldengineer has discussed.

    But item 3 is a ringger !!

    A beginner may ask this question because they think their great idea will make them a million bucks. 😉

    But as I have stated previously, I let those would be entrepreneurs know how hard it is to bring a real product to market.

    Now if item 3 said: “real” engineers don’t use Arduino! , I would agree, that this statement is a myth.

    • Hey it’s not hard to bring a product to market entrepeneurs just like to think it is so they can bang on how great they are. Not hard but lots you need to do other than write code and build Pcb’s.

  8. When millis() rolls over, it is TEOTWAWKI. Magic smoke will be released, the board will reset, the sketch will hang, dogs and cats will sleep together, etc. The fact is, the only limitation with millis() is that it cannot be used to time events that last more than about 49 days.

  9. I think there are some misunderstanding about the role of shields available for Arduino. For example, I hear many friends doubt that Arduino can NOT communicate with a WiFi transceiver without a WiFi-Shield !

    Even though I didn’t try that, I believe that Shields are important but not necessary ! So hope someone explain in what really shields do for Arduino ..

  10. Regarding myth 3.

    I have been involved and designed the programs for a light module for model railway houses. We used a clone of UNO called Brage (Swedish educational version). Small form factor.
    Every house has a Brage inside connected in a group to a Uno with ethernet to a central PC-program controlling over 100 Brage modules for synchronizing the light effects. A simple but yet vesatile system based on Arduino products.

    It’s not a commercial product itself but Its used in the same way. It will be used in a “professional” manner.

    So I think defenitly it can be used in real world applications.

    Yes, I am an enegineer and have worked with programming since late 70’s. Worked as a manager for many years, but I fell in love with Ardunio and was excited over the possibillites to create this application. The whole system was up and running within a week of programming in my spare time.

  11. Myth #6: There is a reason for non-typical, non-rectangular shape (form factor) of the Arduino board.

    Reality: No, there is no special reason, they just wanted to be “different”.

  12. Hello,

    Commenting on Myth 3,

    I consider myself more or less an engineer. I am a PhD student with an electrical engineering background currently in the field of biomedical engineering focusing on surgical robotics. Many times I love to go into the Arduino platform just for proof of concept and prototyping. I have done so for years and have been proud of it. It is feasible and community support is through the roof.

    Although Arduino is open-source and many say it is targeted for beginners, research and industrial engineers do use it thoroughly. My personal board is the Due because of the ARM processor – matter of fact the Arduino Due truly did push me into ARM designs into my custom PCBs. I do believe the Arduino is a viable tool for any engineer. And although your final design may not have the legendary Arduino logo, you can bet your ass that in many final products, there is a good chance it may have used the Arduino as a prototype.

  13. Strictly speaking, I think the Arduino language is based on the Processing language, which itself is a simplified form of C++. /nitpick 🙂

  14. #2 is wrong. I have 3 Arduino boards. A Duemilanove, an Uno and a Mega and ALL of them have an LED and series resistor tied to pin 13.

    • I can confirm that the Arduino Uno schematics show a 1k resistor on the SCK (pin 13). However, I think it’s for the LED that’s also linked to the pin.. not for additional loads.

    • Yes, but that resistor is ONLY limits current to the LED onboard. It does nothing to protect additional loads connected to the pin.

      The resistor and LED is in parallel with the pin header.

      • That’s a good clarification – the onbord LED DOES have a current limiting resistor, but this resistor is NOT in series with the off-board connector.

  15. One of the biggest myths I’ve encountered is the assumption that you have to use one whole Arduino board for a project. In my experience it’s better to use the board for testing and debugging and then flash an atmega chip with your sketch. Then you can integrate the chip into your design on a perf board. It may be a little more work and you lose the ability to use shields but it makes for a cleaner and smaller profile. (Plus it’s cheaper)

    • I’ve seen that a lot, you can get ATMega328 chips flashed with the Arduino Bootloader for just under £3. I’ve done several projects where I’ve prototyped with an Arduino and then etched my own PCB.

      You don’t really need much to get an ATMega328 to run, all you need is a couple of capacitors, a crystal and a datasheet with the pinouts of the 328 and you are sorted. I have built arduino ‘clones’ on stripboard with a 5V regulator, the process is trivial and inexpensive and shouldn’t really cost more than £5 to achieve.

  16. Dose anyone has an information about how to move from Arduino to real commercial product? I’ve been searching for a long time but it seems not much clue on it.

    • You might be over thinking it. Im not sure such leap exist.
      You design a product with an atmega chip inside and program it with any other programmer . You can even order hundreds of chips preprogrammed.
      You can even cheat and load the arduino bootloader and run the same code you already created i believe this is known as a arduino clone. Same skills you just use the exact amount of hardware you need. No extra headers no shields
      This should be faster end cheaper.

      • I have done this quite a few times as part of my learning process of arduino and electronics.

        I prototype on arduino, then make a custom board with a 328 inside and good old soldering.

        My latest project, I burn my own bootloader on a 328 chip and put it on a breadboard and load my programs from the arduino software directly via a usb-serial adaptor or directly through icsp.
        Once my dev work was done, I soldered everything on a prototype pcb board (hours of soldering).

        If I wanted to comercialize the product I would make a PCB design and send it to a pcb fab.


  17. Can confirm, am engineering student, have used arduino to prototype a setup with Atmega328 for use in my Sr. Design project.

  18. I have taken stage equipment apart before and been surprised to find an atmega 328 as the microprocessor, the product was a dmx hazer, that was a commercial application

        • There is really no way of knowing.

          Arduino requires the bootloader to be programmed first.

          So if the bootloader is not there, the Arduino IDE will not work.

          Also, if the 328p is soldered down, there will be a small chance to get the bootloader programmed into that chip.

          • > Arduino requires the bootloader to be programmed first. So if the bootloader is not there, the Arduino IDE will not work.

            That’s not true. For one thing, the Arduino IDE works whether or not an Arduino is connected in any way. Second, you can program “via an ICSP” (see File Menu -> Upload Using Programmer).

            Alternatively, you can take the .hex file from an Arduino IDE compile, and upload that using other methods (eg. avrdude).