Arduino Manual

Download as pdf or txt
Download as pdf or txt
You are on page 1of 40

arduino

programming
notebook
brian w. evans
Arduino Programming Notebook
Written and compiled by Brian W. Evans
With information or inspiration taken from:
http://www.arduino.cc
http://www.wiring.org.co
http://www.arduino.cc/en/Booklet/HomePage
http://cslibrary.stanford.edu/101/
ncluding material written by:
Massimo Banzi
Hernando Barragn
David Cuartielles
Tom goe
Daniel Jolliffe
Todd Kurt
David Mellis
and others
Published:
First Edition August 2007
! #$%&'
This work is licensed under the Creative Commons
Attribution-Noncommercial-Share Alike 3.0 License.
To view a copy of this license, visit:
http://creativecommons.org/licenses/by-nc-sa/3.0/
Or send a letter to:
Creative Commons
171 Second Street, Suite 300
San Francisco, California, 94105, USA
contents
!"#$%"$#&
structure !"
setup() !"
loop() !"
functions !#
{} curly braces !$
; semicolon !$
/*. */ block comments %&
// line comments %&
'(#)(*+&!
variables %%
variable declaration %'
variable scope %(
,("("-.&!
byte %)
int %)
long %)
float %)
arrays %*
(#)"/0&")%
arithmetic %+
compound assignments %+
comparison operators %"
logical operators %"
%12!"(2"!
constants %#
true/false %#
high/low %#
input/output %#
3+145%12"#1+
if %$
if. else '&
for '%
while ''
do. while ''
,)6)"(+5)71
pinMode(pin, mode) '(
digitalRead(pin) ')
digitalWrite(pin, value) ')
(2(+165)71
analogRead(pin) '*
analogWrite(pin, value) '+
")0&
delay(ms) '"
millis() '"
0("/
min(x, y) '"
max(x, y) '"
#(2,10
randomSeed(seed) '#
random(min, max) '#
!&#)(+
Serial.begin(rate) '$
Serial.println(data) '$
(..&2,)8
digital output ('
digital input ((
high current output ()
pwm output (*
potentiometer input (+
variable resistor input ("
servo output (#
preface
This notebook serves as a convenient, easy to use programming reference for
the command structure and basic syntax of the Arduino microcontroller. To keep
it simple, certain exclusions were made that make this a beginner's reference
best used as a secondary source alongside other websites, books, workshops,
or classes. This decision has lead to a slight emphasis on using the Arduino for
standalone purposes and, for example, excludes the more complex uses of
arrays or advanced forms of serial communication.
Beginning with the basic structure of Arduino's C derived programming
language, this notebook continues on to describe the syntax of the most
common elements of the language and illustrates their usage with examples and
code fragments. This includes many functions of the core library followed by an
appendix with sample schematics and starter programs. The overall format
compliments O'Sullivan and goe's Physical Computing where possible.
For an introduction to the Arduino and interactive design, refer to Banzi's
Getting Started with Arduino, aka the Arduino Booklet. For the brave few
interested in the intricacies of programming in C, Kernighan and Ritchie's The C
Programming Language, second edition, as well as Prinz and Crawford's C in a
Nutshell, provide some insight into the original programming syntax.
Above all else, this notebook would not have been possible without the great
community of makers and shear mass of original material to be found at the
Arduino website, playground, and forum at http://www.arduino.cc.

structure
The basic structure of the Arduino programming language is fairly simple and
runs in at least two parts. These two required parts, or functions, enclose blocks
of statements.
!!!!!
,-./!0123456
7
!!0282191:20;
<
,-./!=--456
7
!!0282191:20;
<
Where setup() is the preparation, loop() is the execution. Both functions are
required for the program to work.
The setup function should follow the declaration of any variables at the very
beginning of the program. t is the first function to run in the program, is run only
once, and is used to set pinMode or initialize serial communication.
The loop function follows next and includes the code to be executed
continuously reading inputs, triggering outputs, etc. This function is the core of
all Arduino programs and does the bulk of the work.
setup()
The setup() function is called once when your program starts. Use it to initialize
pin modes, or begin serial. t must be included in a program even if there are no
statements to run.
,-./!0123456
7
!!4.:>-/154.:?!@ABCAB6;!!!!!!DD!0120!2E1!F4.:F!80!-32432
<
Ioop()
After calling the setup() function, the loop() function does precisely what its
name suggests, and loops consecutively, allowing the program to change,
respond, and control the Arduino board.

,-./!=--456
7
!!/.G.28=HI.2154.:?!JKLJ6;!!!DD!23I:0!F4.:F!-:
!!/1=8M5%&&&6;!!!!!!!!!!!!!!!DD!483010!N-I!-:1!01O-:/
!!/.G.28=HI.2154.:?!P@H6;!!!!DD!23I:0!F4.:F!-NN
!!/1=8M5%&&&6;!!!!!!!!!!!!!!!DD!483010!N-I!-:1!01O-:/
<
02I3O23I1!Q!"
functions
A function is a block of code that has a name and a block of statements that are
executed when the function is called. The functions void setup() and void loop()
have already been discussed and other built-in functions will be discussed later.
Custom functions can be written to perform repetitive tasks and reduce clutter in
a program. Functions are declared by first declaring the function type. This is the
type of value to be returned by the function such as 'int' for an integer type
function. f no value is to be returned the function type would be void. After type,
declare the name given to the function and in parenthesis any parameters being
passed to the function.
2M41!N3:O2.-:R891548I89121I06
7
!!0282191:20;
<
The following integer type function delayVal() is used to set a delay value in a
program by reading the value of a potentiometer. t first declares a local variable
v, sets v to the value of the potentiometer which gives a number between 0-
1023, then divides that value by 4 for a final value between 0-255, and finally
returns that value back to the main program.
.:2!/1=8MS8=56
7
!!.:2!,;!!!!!!!!!!!!!!!!!!!DD!OI1821!2194-I8IM!,8I.8T=1!F,F
!!,!!U!8:8=-GV18/54-26;!!!!DD!I18/!4-21:2.-9121I!,8=31
!!,!DU!);!!!!!!!!!!!!!!!!!!DD!O-:,1I20!&W%&'(!2-!&W'**
!!I123I:!,;!!!!!!!!!!!!!!!!DD!I123I:!N.:8=!,8=31
<
#!Q!02I3O23I1
{} curIy braces
Curly braces (also referred to as just "braces" or "curly brackets") define the
beginning and end of function blocks and statement blocks such as the void
loop() function and the for and if statements.
2M41!N3:O2.-:56
7
!!0282191:20;
<
An opening curly brace { must always be followed by a closing curly brace }.
This is often referred to as the braces being balanced. Unbalanced braces can
often lead to cryptic, impenetrable compiler errors that can sometimes be hard
to track down in a large program.
The Arduino environment includes a convenient feature to check the balance of
curly braces. Just select a brace, or even click the insertion point immediately
following a brace, and its logical companion will be highlighted.
; semicoIon
A semicolon must be used to end a statement and separate elements of the
program. A semicolon is also used to separate elements in a for loop.
.:2!X!U!%(;!!!DD!/1O=8I10!,8I.8T=1!FXF!80!2E1!.:21G1I!%(
Note: Forgetting to end a line in a semicolon will result in a compiler error. The
error text may be obvious, and refer to a missing semicolon, or it may not. f an
impenetrable or seemingly illogical compiler error comes up, one of the first
things to check is a missing semicolon, near the line where the compiler
complained.
02I3O23I1!Q!$
/*. */ bIock comments
Block comments, or multi-line comments, are areas of text ignored by the
program and are used for large text descriptions of code or comments that help
others understand parts of the program. They begin with /* and end with */ and
can span multiple lines.
DY!!2E.0!.0!8:!1:O=-01/!T=-OZ!O-991:2
!!!!/-:[2!N-IG12!2E1!O=-0.:G!O-991:2!W
!!!!2E1M!E8,1!2-!T1!T8=8:O1/\
YD
Because comments are ignored by the program and take no memory space
they should be used generously and can also be used to "comment out blocks
of code for debugging purposes.
Note: While it is possible to enclose single line comments within a block
comment, enclosing a second block comment is not allowed.
// Iine comments
Single line comments begin with // and end with the next line of code. Like block
comments, they are ignored by the program and take no memory space.
DD!2E.0!.0!8!0.:G=1!=.:1!O-991:2
Single line comments are often used after a valid statement to provide more
information about what the statement accomplishes or to provide a future
reminder.
%&!Q!02I3O23I1
variabIes
A variable is a way of naming and storing a numerical value for later use by the
program. As their namesake suggests, variables are numbers that can be
continually changed as opposed to constants whose value never changes. A
variable needs to be declared and optionally assigned to the value needing to
be stored. The following code declares a variable called inputVariable and then
assigns it the value obtained on analog input pin 2:
.:2!.:432S8I.8T=1!U!&;!!!!!!!!!DD!/1O=8I10!8!,8I.8T=1!8:/!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!800.G:0!,8=31!-N!&
.:432S8I.8T=1!U!8:8=-GV18/5'6;!DD!012!,8I.8T=1!2-!,8=31!-N!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!8:8=-G!4.:!'
'inputVariable' is the variable itself. The first line declares that it will contain an
int, short for integer. The second line sets the variable to the value at analog pin
2. This makes the value of pin 2 accessible elsewhere in the code.
Once a variable has been assigned, or re-assigned, you can test its value to see
if it meets certain conditions, or you can use its value directly. As an example to
illustrate three useful operations with variables, the following code tests whether
the inputVariable is less than 100, if true it assigns the value 100 to
inputVariable, and then sets a delay based on inputVariable which is now a
minimum of 100:
.N!5.:432S8I.8T=1!]!%&&6!DD!21020!,8I.8T=1!.N!=100!2E8:!%&&
7
!!.:432S8I.8T=1!U!%&&;!!!DD!.N!2I31!800.G:0!,8=31!-N!%&&
<
/1=8M5.:432S8I.8T=16;!!!!DD!3010!,8I.8T=1!80!/1=8M!
Note: Variables should be given descriptive names, to make the code more
readable. Variable names like tiltSensor or pushButton help the programmer
and anyone else reading the code to understand what the variable represents.
Variable names like var or value, on the other hand, do little to make the code
readable and are only used here as examples. A variable can be named any
word that is not already one of the keywords in the Arduino language.
,8I.8T=10!Q!%%
variabIe decIaration
All variables have to be declared before they can be used. Declaring a variable
means defining its value type, as in int, long, float, etc., setting a specified name,
and optionally assigning an initial value. This only needs to be done once in a
program but the value can be changed at any time using arithmetic and various
assignments.
The following example declares that inputVariable is an int, or integer type, and
that its initial value equals zero. This is called a simple assignment.
.:2!.:432S8I.8T=1!U!&;
A variable can be declared in a number of locations throughout the program and
where this definition takes place determines what parts of the program can use
the variable.
%'!Q!,8I.8T=10
variabIe scope
A variable can be declared at the beginning of the program before void setup(),
locally inside of functions, and sometimes within a statement block such as for
loops. Where the variable is declared determines the variable scope, or the
ability of certain parts of a program to make use of the variable.
A global variable is one that can be seen and used by every function and
statement in a program. This variable is declared at the beginning of the
program, before the setup() function.
A local variable is one that is defined inside a function or as part of a for loop. t
is only visible and can only be used inside the function in which it was declared.
t is therefore possible to have two or more variables of the same name in
different parts of the same program that contain different values. Ensuring that
only one function has access to its variables simplifies the program and reduces
the potential for programming errors.
The following example shows how to declare a few different types of variables
and demonstrates each variable's visibility:
.:2!,8=31;!!!!!!!!!!!!!!!DD!F,8=31F!.0!,.0.T=1!
!!!!!!!!!!!!!!!!!!!!!!!!!DD!2-!8:M!N3:O2.-:
,-./!0123456
7
!!DD!:-!01234!:11/1/
<
,-./!=--456
7
!!N-I!5.:2!.U&;!.]'&;6!!DD!F.F!.0!-:=M!,.0.T=1
!!7!!!!!!!!!!!!!!!!!!!!!DD!.:0./1!2E1!N-IW=--4
!!!!.^^;!!!!!!!!!!!!!!!
!!<
!!N=-82!N;!!!!!!!!!!!!!!DD!FNF!.0!-:=M!,.0.T=1
<!!!!!!!!!!!!!!!!!!!!!!!DD!.:0./1!=--4
,8I.8T=10!Q!%(
byte
Byte stores an 8-bit numerical value without decimal points. They have a range
of 0-255.
TM21!0-91S8I.8T=1!U!%#&;!!!DD!/1O=8I10!F0-91S8I.8T=1F!
!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!80!8!TM21!2M41
int
ntegers are the primary datatype for storage of numbers without decimal points
and store a 16-bit value with a range of 32,767 to -32,768.
.:2!0-91S8I.8T=1!U!%*&&;!!!DD!/1O=8I10!F0-91S8I.8T=1F!
!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!80!8:!.:21G1I!2M41!
Note: nteger variables will roll over if forced past their maximum or minimum
values by an assignment or comparison. For example, if X!U!('"+" and a
subsequent statement adds 1 to x, X!U!X!^!%!-I!X^^, x will then rollover
and equal -32,768.
Iong
Extended size datatype for long integers, without decimal points, stored in a 32-
bit value with a range of 2,147,483,647 to -2,147,483,648.
=-:G!0-91S8I.8T=1!U!$&&&&;!DD!/1O=8I10!F0-91S8I.8T=1F!
!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!80!8!=-:G!2M41
fIoat
A datatype for floating-point numbers, or numbers that have a decimal point.
Floating-point numbers have greater resolution than integers and are stored as
a 32-bit value with a range of 3.4028235E+38 to -3.4028235E+38.
N=-82!0-91S8I.8T=1!U!(_%);!DD!/1O=8I10!F0-91S8I.8T=1F
!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!80!8!N=-82.:GW4-.:2!2M41

Note: Floating-point numbers are not exact, and may yield strange results when
compared. Floating point math is also much slower than integer math in
performing calculations, so should be avoided if possible.
%)!Q!/8282M410
arrays
An array is a collection of values that are accessed with an index number. Any
value in the array may be called upon by calling the name of the array and the
index number of the value. Arrays are zero indexed, with the first value in the
array beginning at index number 0. An array needs to be declared and optionally
assigned values before they can be used.
.:2!9M`II8Mab!U!7,8=31&?!,8=31%?!,8=31'___<
Likewise it is possible to declare an array by declaring the array type and size
and later assign values to an index position:
.:2!9M`II8Ma*b;!!!!DD!/1O=8I10!.:21G1I!8II8M!cD!+!4-0.2.-:0
9M`II8Ma(b!U!%&;!!!DD!800.G:0!2E1!)2E!.:/1X!2E1!,8=31!%&
To retrieve a value from an array, assign a variable to the array and index
position:
X!U!9M`II8Ma(b;!!!!DD!X!:-c!1d38=0!%&
Arrays are often used in for loops, where the increment counter is also used as
the index position for each array value. The following example uses an array to
flicker an LED. Using a for loop, the counter begins at 0, writes the value
contained at index position 0 in the array flicker[], in this case 180, to the PWM
pin 10, pauses for 200ms, then moves to the next index position.
.:2!=1/C.:!U!%&;!!!!!!!!!!!!!!!!!!!!!DD!Pef!-:!4.:!%&
TM21!N=.OZ1Iab!U!7%#&?!(&?!'**?!'&&?!%&?!$&?!%*&?!+&<;
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!8T-,1!8II8M!-N!#!
,-./!0123456!!!!!!!!!!!!!!!!!!!!!!!!!DD!/.NN1I1:2!,8=310
7
!!4.:>-/15=1/C.:?!@ABCAB6;!!!!!!!!!!!DD!0120!@ABCAB!4.:
<
,-./!=--456
7
!!N-I5.:2!.U&;!.]";!.^^6!!!!!!!!!!!!!DD!=--4!1d38=0!:39T1I
!!7!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!-N!,8=310!.:!8II8M
!!!!8:8=-GHI.215=1/C.:?!N=.OZ1Ia.b6;!DD!cI.21!.:/1X!,8=31
!!!!/1=8M5'&&6;!!!!!!!!!!!!!!!!!!!!!!DD!48301!'&&90
!!<
<
/8282M410!Q!%*
arithmetic
Arithmetic operators include addition, subtraction, multiplication, and division.
They return the sum, difference, product, or quotient (respectively) of two
operands.
M!U!M!^!(;
X!U!X!W!";
.!U!g!Y!+;
I!U!I!D!*;
The operation is conducted using the data type of the operands, so, for
example, 9 / 4 results in 2 instead of 2.25 since 9 and 4 are ints and are
incapable of using decimal points. This also means that the operation can
overflow if the result is larger than what can be stored in the data type.
f the operands are of different types, the larger type is used for the calculation.
For example, if one of the numbers (operands) are of the type float and the
other of type integer, floating point math will be used for the calculation.
Choose variable sizes that are large enough to hold the largest results from your
calculations. Know at what point your variable will rollover and also what
happens in the other direction e.g. (0 - 1) OR (0 - - 32768). For math that
requires fractions, use float variables, but be aware of their drawbacks: large
size and slow computation speeds.
Note: Use the cast operator e.g. (int)myFloat to convert one variable type to
another on the fly. For example, .!U!5.:26(_+ will set i equal to 3.
compound assignments
Compound assignments combine an arithmetic operation with a variable
assignment. These are commonly found in for loops as described later. The
most common compound assignments include:
X!^^!!!!!!DD!0891!80!X!U!X!^!%?!-I!.:OI191:20!X!TM!^%
X!WW !!!!DD!0891!80!X!U!X!W!%?!-I!/1OI191:20!X!TM!W%
X!^U!M!!!!DD!0891!80!X!U!X!^!M?!-I!.:OI191:20!X!TM!^M
X!WU!M!!!!DD!0891!80!X!U!X!W!M?!-I!/1OI191:20!X!TM!WM
X!YU!M!!!!DD!0891!80!X!U!X!Y!M?!-I!93=2.4=.10!X!TM!M
X!DU!M!!!!DD!0891!80!X!U!X!D!M?!-I!/.,./10!X!TM!M
Note: For example, x *= 3 would triple the old value of x and re-assign the
resulting value to x.
%+!Q!8I.2E912.O
comparison operators
Comparisons of one variable or constant against another are often used in if
statements to test if a specified condition is true. n the examples found on the
following pages, ?? is used to indicate any of the following conditions:
X!UU!M!!!!DD!X!.0!1d38=!2-!M
X!\U!M!!!!DD!X!.0!:-2!1d38=!2-!M
X!]!!M!!!!DD!X!.0!=100!2E8:!M!!
X!h!!M!!!!DD!X!.0!GI1821I!2E8:!M!
X!]U!M!!!!DD!X!.0!=100!2E8:!-I!1d38=!2-!M!
X!hU!M!!!!DD!X!.0!GI1821I!2E8:!-I!1d38=!2-!M
IogicaI operators
Logical operators are usually a way to compare two expressions and return a
TRUE or FALSE depending on the operator. There are three logical operators,
AND, OR, and NOT, that are often used in if statements:
Logical AND:
.N!5X!h!&!ii!X!]!*6!!!!DD!2I31!-:=M!.N!T-2E
!!!!!!!!!!!!!!!!!!!!!!!DD!1X4I100.-:0!8I1!2I31
Logical OR:
.N!5X!h!&!QQ!M!h!&6!!!!DD!2I31!.N!1.2E1I!
!!!!!!!!!!!!!!!!!!!!!!!DD!1X4I100.-:!.0!2I31
Logical NOT:
.N!5\X!h!&6!!!!!!!!!!!!DD!2I31!-:=M!.N!
!!!!!!!!!!!!!!!!!!!!!!!DD!1X4I100.-:!.0!N8=01

8I.2E912.O!Q!%"
constants
The Arduino language has a few predefined values, which are called constants.
They are used to make the programs easier to read. Constants are classified in
groups.
true/faIse
These are Boolean constants that define logic levels. FALSE is easily defined as
0 (zero) while TRUE is often defined as 1, but can also be anything else except
zero. So in a Boolean sense, -1, 2, and -200 are all also defined as TRUE.
.N!5T!UU!BVAe6;
7
!!/-j-912E.:G;
<
high/Iow
These constants define pin levels as HGH or LOW and are used when reading
or writing to digital pins. HGH is defined as logic level 1, ON, or 5 volts while
LOW is logic level 0, OFF, or 0 volts.
/.G.28=HI.215%(?!JKLJ6;
input/output
Constants used with the pinMode() function to define the mode of a digital pin as
either NPUT or OUTPUT.
4.:>-/15%(?!@ABCAB6;
%#!Q!O-:028:20
if
if statements test whether a certain condition has been reached, such as an
analog value being above a certain number, and executes any statements
inside the brackets if the statement is true. f false the program skips over the
statement. The format for an if test is:
.N!50-91S8I.8T=1!kk!,8=316
7
!!/-j-912E.:G;
<
The above example compares someVariable to another value, which can be
either a variable or constant. f the comparison, or condition in parentheses is
true, the statements inside the brackets are run. f not, the program skips over
them and continues on after the brackets.
Note: Beware of accidentally using '=', as in .N5XU%&6, while technically valid,
defines the variable x to the value of 10 and is as a result always true. nstead
use '==', as in .N5XUU%&6, which only tests whether x happens to equal the
value 10 or not. Think of '=' as "equals" opposed to '==' being "is equal to".
N=-c!O-:2I-=!Q!%$
if. eIse
if. else allows for 'either-or' decisions to be made. For example, if you wanted
to test a digital input, and do one thing if the input went HGH or instead do
another thing if the input was LOW, you would write that this way:
.N!5.:432C.:!UU!JKLJ6
7
!!/-BE.:G`;
<
1=01
7
!!/-BE.:Gl;
<
else can also precede another if test, so that multiple, mutually exclusive tests
can be run at the same time. t is even possible to have an unlimited number of
these else branches. Remember though, only one set of statements will be run
depending on the condition tests:
.N!5.:432C.:!]!*&&6
7
!!/-BE.:G`;
<
1=01!.N!5.:432C.:!hU!%&&&6
7
!!/-BE.:Gl;
<
1=01
7
!!/-BE.:Gm;
<
Note: An if statement simply tests whether the condition inside the parenthesis
is true or false. This statement can be any valid C statement as in the first
example, .N!5.:432C.:!UU!JKLJ6. n this example, the if statement only
checks to see if indeed the specified input is at logic level high, or +5v.
'&!Q!N=-c!O-:2I-=
for
The for statement is used to repeat a block of statements enclosed in curly
braces a specified number of times. An increment counter is often used to
increment and terminate the loop. There are three parts, separated by
semicolons (;), to the for loop header:
N-I!5.:.2.8=.n82.-:;!O-:/.2.-:;!1X4I100.-:6!
7
!!/-j-912E.:G;
<
The initialization of a local variable, or increment counter, happens first and only
once. Each time through the loop, the following condition is tested. f the
condition remains true, the following statements and expression are executed
and the condition is tested again. When the condition becomes false, the loop
ends.
The following example starts the integer i at 0, tests to see if i is still less than 20
and if true, increments i by 1 and executes the enclosed statements:
N-I!5.:2!.U&;!.]'&;!.^^6!!DD!/1O=8I10!.?!21020!.N!=100!
7!!!!!!!!!!!!!!!!!!!!!!!!!DD!2E8:!'&?!.:OI191:20!.!TM!%!
!!/.G.28=HI.215%(?!JKLJ6;!DD!23I:0!4.:!%(!-:!
!!/1=8M5'*&6;!!!!!!!!!!!!!DD!483010!N-I!%D)!01O-:/
!!/.G.28=HI.215%(?!P@H6;!!DD!23I:0!4.:!%(!-NN
!!/1=8M5'*&6;!!!!!!!!!!!!!DD!483010!N-I!%D)!01O-:/
<!
Note: The C for loop is much more flexible than for loops found in some other
computer languages, including BASC. Any or all of the three header elements
may be omitted, although the semicolons are required. Also the statements for
initialization, condition, and expression can be any valid C statements with
unrelated variables. These types of unusual for statements may provide
solutions to some rare programming problems.
N=-c!O-:2I-=!Q!'%
whiIe
while loops will loop continuously, and infinitely, until the expression inside the
parenthesis becomes false. Something must change the tested variable, or the
while loop will never exit. This could be in your code, such as an incremented
variable, or an external condition, such as testing a sensor.
cE.=1!50-91S8I.8T=1!kk!,8=316
7
!!/-j-912E.:G;
<
The following example tests whether 'someVariable' is less than 200 and if true
executes the statements inside the brackets and will continue looping until
'someVariable' is no longer less than 200.
HE.=1!50-91S8I.8T=1!]!'&&6!DD!21020!.N!=100!2E8:!'&&
7
!!/-j-912E.:G;!!!!!!!!!!!!!DD!1X1O3210!1:O=-01/!0282191:20
!!0-91S8I.8T=1^^;!!!!!!!!!!DD!.:OI191:20!,8I.8T=1!TM!%
<
do. whiIe
The do loop is a bottom driven loop that works in the same manner as the while
loop, with the exception that the condition is tested at the end of the loop, so the
do loop will always run at least once.
/-
7
!!/-j-912E.:G;
<!cE.=1!50-91S8I.8T=1!kk!,8=316;
The following example assigns readSensors() to the variable 'x', pauses for 50
milliseconds, then loops indefinitely until 'x' is no longer less than 100:
/-
7
!!X!U!I18/j1:0-I056;!!!!DD!800.G:0!2E1!,8=31!-N!!
!!!!!!!!!!!!!!!!!!!!!!!!DD!I18/j1:0-I056!2-!X
!!/1=8M5*&6;!!!!!!!!!!!!DD!483010!*&!9.==.01O-:/0
<!cE.=1!5X!]!%&&6;!!!!!!DD!=--40!.N!X!.0!=100!2E8:!%&&
''!Q!N=-c!O-:2I-=
pinMode(pin, mode)
Used in ,-./!0123456 to configure a specified pin to behave either as an
NPUT or an OUTPUT.
4.:>-/154.:?!@ABCAB6;!!!!DD!0120!o4.:[!2-!-32432
Arduino digital pins default to inputs, so they don't need to be explicitly declared
as inputs with pinMode(). Pins configured as NPUT are said to be in a high-
impedance state.
There are also convenient 20KC pullup resistors built into the Atmega chip that
can be accessed from software. These built-in pullup resistors are accessed in
the following manner:
4.:>-/154.:?!KRCAB6;!!!!!!!!DD!012!o4.:[!2-!.:432
/.G.28=HI.2154.:?!JKLJ6;!!!!DD!23I:!-:!43==34!I10.02-I0
Pullup resistors would normally be used for connecting inputs like switches.
Notice in the above example it does not convert!4.:!to an output, it is merely a
method for activating the internal pull-ups.
Pins configured as OUTPUT are said to be in a low-impedance state and can
provide 40 mA (milliamps) of current to other devices/circuits. This is enough
current to brightly light up an LED (don't forget the series resistor), but not
enough current to run most relays, solenoids, or motors.
Short circuits on Arduino pins and excessive current can damage or destroy the
output pin, or damage the entire Atmega chip. t is often a good idea to connect
an OUTPUT pin to an external device in series with a 470C or 1KC resistor.
/.G.28=!.D-!Q!'(
digitaIRead(pin)
Reads the value from a specified digital pin with the result either HGH or LOW.
The pin can be specified as either a variable or constant (0-13).
,8=31!U!/.G.28=V18/5C.:6;!!!DD!0120!F,8=31F!1d38=!2-!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!2E1!.:432!4.:
digitaIWrite(pin, vaIue)
Ouputs either logic level HGH or LOW at (turns on or off) a specified digital pin.
The pin can be specified as either a variable or constant (0-13).
/.G.28=HI.2154.:?!JKLJ6;!!!DD!0120!F4.:F!2-!E.GE
The following example reads a pushbutton connected to a digital input and turns
on an LED connected to a digital output when the button has been pressed:
.:2!=1/!!!U!%(;!!!DD!O-::1O2!Pef!2-!4.:!%(
.:2!4.:!!!U!!";!!!DD!O-::1O2!430ET322-:!2-!4.:!"
.:2!,8=31!U!!&;!!!DD!,8I.8T=1!2-!02-I1!2E1!I18/!,8=31
,-./!0123456
7
!!4.:>-/15=1/?!@ABCAB6;!!!!DD!0120!4.:!%(!80!-32432
!!4.:>-/154.:?!KRCAB6;!!!!!DD!0120!4.:!"!80!.:432
<
,-./!=--456
7
!!,8=31!U!/.G.28=V18/54.:6;!!DD!0120!F,8=31F!1d38=!2-!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!2E1!.:432!4.:
!!/.G.28=HI.215=1/?!,8=316;!!DD!0120!F=1/F!2-!2E1
<!!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!T322-:F0!,8=31
')!Q!/.G.28=!.D-
anaIogRead(pin)
Reads the value from a specified analog pin with a 10-bit resolution. This
function only works on the analog in pins (0-5). The resulting integer values
range from 0 to 1023.

,8=31!U!8:8=-GV18/54.:6;!!DD!0120!F,8=31F!1d38=!2-!F4.:F
Note: Analog pins unlike digital ones, do not need to be first declared as NPUT
nor OUTPUT.
8:8=-G!.D-!Q!'*
anaIogWrite(pin, vaIue)
Writes a pseudo-analog value using hardware enabled pulse width modulation
(PWM) to an output pin marked PWM. On newer Arduinos with the ATmega168
chip, this function works on pins 3, 5, 6, 9, 10, and 11. Older Arduinos with an
ATmega8 only support pins 9, 10, and 11. The value can be specified as a
variable or constant with a value from 0-255.
8:8=-GHI.2154.:?!,8=316;!!DD!cI.210!F,8=31F!2-!8:8=-G!F4.:F
A value of 0 generates a steady 0 volts output at the specified pin; a value of
255 generates a steady 5 volts output at the specified pin. For values in
between 0 and 255, the pin rapidly alternates between 0 and 5 volts - the higher
the value, the more often the pin is HGH (5 volts). For example, a value of 64
will be 0 volts three-quarters of the time, and 5 volts one quarter of the time; a
value of 128 will be at 0 half the time and 255 half the time; and a value of 192
will be 0 volts one quarter of the time and 5 volts three-quarters of the time.
Because this is a hardware function, the pin will generate a steady wave after a
call to analogWrite in the background until the next call to analogWrite (or a call
to digitalRead or digitalWrite on the same pin).
Note: Analog pins unlike digital ones, do not need to be first declared as NPUT
nor OUTPUT.
The following example reads an analog value from an analog input pin, converts
the value by dividing by 4, and outputs a PWM signal on a PWM pin:
.:2!=1/!U!%&;!!!!DD!Pef!c.2E!''&!I10.02-I!-:!4.:!%&
.:2!4.:!U!!&;!!!!DD!4-21:2.-9121I!-:!8:8=-G!4.:!&
.:2!,8=31;!!!!!!!DD!,8=31!N-I!I18/.:G
,-./!01234567<!!!DD!:-!01234!:11/1/
,-./!=--456
7
!!,8=31!U!!8:8=-GV18/54.:6;!!DD!0120!F,8=31F!1d38=!2-!F4.:F
!!,8=31!DU!);!!!!!!!!!!!!!!!!DD!O-:,1I20!&W%&'(!2-!&W'**
!!8:8=-GHI.215=1/?!,8=316;!!!DD!-324320!CH>!0.G:8=!2-!=1/
<
'+!Q!8:8=-G!.D-
deIay(ms)
Pauses your program for the amount of time as specified in milliseconds, where
1000 equals 1 second.
/1=8M5%&&&6;!!!DD!c8.20!N-I!-:1!01O-:/
miIIis()
Returns the number of milliseconds since the Arduino board began running the
current program as an unsigned long value.
,8=31!U!9.==.056;!!DD!0120!o,8=31[!1d38=!2-!9.==.056
Note: This number will overflow (reset back to zero), after approximately 9
hours.
min(x, y)
Calculates the minimum of two numbers of any data type and returns the
smaller number.
,8=31!U!9.:5,8=31?!%&&6;!DD!0120!F,8=31F!2-!2E1!098==1I!-N!
!!!!!!!!!!!!!!!!!!!!!!!!!DD!F,8=31F!-I!%&&?!1:03I.:G!2E82!
!!!!!!!!!!!!!!!!!!!!!!!!!DD!.2!:1,1I!G120!8T-,1!%&&_
max(x, y)
Calculates the maximum of two numbers of any data type and returns the larger
number.
,8=31!U!98X5,8=31?!%&&6;!DD!0120!F,8=31F!2-!2E1!=8IG1I!-N!
!!!!!!!!!!!!!!!!!!!!!!!!!DD!F,8=31F!-I!%&&?!1:03I.:G!2E82!
!!!!!!!!!!!!!!!!!!!!!!!!!DD!.2!.0!82!=1802!%&&_
2.91!8:/!982E!Q!'"
randomSeed(seed)
Sets a value, or seed, as the starting point for the random() function.
I8:/-9j11/5,8=316;!!!DD!0120!o,8=31[!80!2E1!I8:/-9!011/
Because the Arduino is unable to create a truly random number, randomSeed
allows you to place a variable, constant, or other function into the random
function, which helps to generate more random "random numbers. There are a
variety of different seeds, or functions, that can be used in this function including
millis() or even analogRead() to read electrical noise through an analog pin.
random(max)
random(min, max)
The random function allows you to return pseudo-random numbers within a
range specified by min and max values.
,8=31!U!I8:/-95%&&?!'&&6;!!DD!0120!F,8=31F!2-!8!I8:/-9!
!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!:39T1I!T12c11:!%&&W'&&
Note: Use this after using the randomSeed() function.
The following example creates a random value between 0-255 and outputs a
PWM signal on a PWM pin equal to the random value:
.:2!I8:/R39T1I;!!DD!,8I.8T=1!2-!02-I1!2E1!I8:/-9!,8=31
.:2!=1/!U!%&;!!!!DD!Pef!c.2E!''&!I10.02-I!-:!4.:!%&
,-./!0123456!7<!!DD!:-!01234!:11/1/
,-./!=--456
7
!!I8:/-9j11/59.==.0566;!!!!!!!!!DD!0120!9.==.056!80!011/
!!I8:/R39T1I!U!I8:/-95'**6;!!!!!DD!I8:/-9!:39T1I!NI-9!&W'**
!!8:8=-GHI.215=1/?!I8:/R39T1I6;!DD!-324320!CH>!0.G:8=
!!/1=8M5*&&6;!!!!!!!!!!!!!!!!!!!DD!483010!N-I!E8=N!8!01O-:/
<
'#!Q!I8:/-9
SeriaI.begin(rate)
Opens serial port and sets the baud rate for serial data transmission. The typical
baud rate for communicating with the computer is 9600 although other speeds
are supported.
,-./!0123456!
7
!!j1I.8=_T1G.:5$+&&6;!!!DD!-41:0!01I.8=!4-I2
<!!!!!!!!!!!!!!!!!!!!!!!DD!0120!/828!I821!2-!$+&&!T40
Note: When using serial communication, digital pins 0 (RX) and 1 (TX) cannot
be used at the same time.
SeriaI.printIn(data)
Prints data to the serial port, followed by an automatic carriage return and line
feed. This command takes the same form as Serial.print(), but is easier for
reading data on the Serial Monitor.
j1I.8=_4I.:2=:58:8=-GS8=316;!!DD!01:/0!2E1!,8=31!-N!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!DD!F8:8=-GS8=31F
Note: For more information on the various permutations of the Serial.println()
and Serial.print() functions please refer to the Arduino website.
The following simple example takes a reading from analog pin0 and sends this
data to the computer every 1 second.
,-./!0123456
7
!!j1I.8=_T1G.:5$+&&6;!!!!!!!!!!!!DD!0120!01I.8=!2-!$+&&T40
<
,-./!=--456
7
!!j1I.8=_4I.:2=:58:8=-GV18/5&66;!DD!01:/0!8:8=-G!,8=31
!!/1=8M5%&&&6;!!!!!!!!!!!!!!!!!!!DD!483010!N-I!%!01O-:/
<
01I.8=!Q!'$
appendix
digitaI output
This is the basic 'hello world' program used to simply turn something on or off. n
this example, an LED is connected to pin13, and is blinked every second. The
resistor may be omitted on this pin since the Arduino has one built in.
.:2!=1/C.:!U!%(;!!!!!!!!!!!!!!!DD!Pef!-:!/.G.28=!4.:!%(
,-./!0123456!!!!!!!!!!!!!!!!!!!DD!I3:!-:O1
7
!!4.:>-/15=1/C.:?!@ABCAB6;!!!!!DD!0120!4.:!%(!80!-32432
<
,-./!=--456!!!!!!!!!!!!!!!!!!!!DD!I3:!-,1I!8:/!-,1I!8G8.:
7
!!/.G.28=HI.215=1/C.:?!JKLJ6;!!DD!23I:0!2E1!Pef!-:
!!/1=8M5%&&&6;!!!!!!!!!!!!!!!!!DD!483010!N-I!%!01O-:/
!!/.G.28=HI.215=1/C.:?!P@H6;!!!DD!23I:0!2E1!Pef!-NN
!!/1=8M5%&&&6;!!!!!!!!!!!!!!!!!DD!483010!N-I!%!01O-:/
<
('!Q!8441:/.X
digitaI input
This is the simplest form of input with only two possible states: on or off. This
example reads a simple switch or pushbutton connected to pin2. When the
switch is closed the input pin will read HGH and turn on an LED.
.:2!=1/C.:!U!%(;!!!!!!!!!!!!DD!-32432!4.:!N-I!2E1!Pef
.:2!.:C.:!U!';!!!!!!!!!!!!!!DD!.:432!4.:!5N-I!8!0c.2OE6
,-./!0123456!
7
!!4.:>-/15=1/C.:?!@ABCAB6;!!DD!/1O=8I1!Pef!80!-32432
!!4.:>-/15.:C.:?!KRCAB6;!!!!DD!/1O=8I1!0c.2OE!80!.:432
<
,-./!=--456
7
!!.N!5/.G.28=V18/5.:C.:6!UU!JKLJ6!DD!OE1OZ!.N!.:432!.0!JKLJ
!!7
!!!!/.G.28=HI.215=1/C.:?!JKLJ6;!!!DD!23I:0!2E1!Pef!-:
!!!!/1=8M5%&&&6;!!!!!!!!!!!!!!!!!!DD!48301!N-I!%!01O-:/
!!!!/.G.28=HI.215=1/C.:?!P@H6;!!!!DD!23I:0!2E1!Pef!-NN
!!!!/1=8M5%&&&6;!!!!!!!!!!!!!!!!!!DD!48301!N-I!%!01O-:/
!!<
<
8441:/.X!Q!((
high current output
Sometimes it is necessary to control more than 40ma from the Arduino. n this
case a MOSFET or transistor could be used to switch higher current loads. The
following example quickly turns on and off the MOSFET 5 times every second.
Note: The schematic shows a motor and protection diode but other non-
inductive loads could be used without the diode.
.:2!-32C.:!!U!!*;!!!!!!!!DD!-32432!4.:!N-I!2E1!>@jpeB!
,-./!0123456
7
!!4.:>-/15-32C.:?!@ABCAB6;!!!!!!DD!0120!4.:*!80!-32432
<!!!
,-./!=--456
7
!!N-I!5.:2!.U&;!.]U*;!.^^6!!!!!!DD!=--40!*!2.910
!!7
!!!!/.G.28=HI.215-32C.:?!JKLJ6;!DD!23I:0!>@jpeB!-:
!!!!/1=8M5'*&6;!!!!!!!!!!!!!!!!!DD!483010!%D)!01O-:/
!!!!/.G.28=HI.215-32C.:?!P@H6;!!DD!23I:0!>@jpeB!-NN
!!!!/1=8M5'*&6;!!!!!!!!!!!!!!!!!DD!483010!%D)!01O-:/
!!<
!!/1=8M5%&&&6;!!!!!!!!!!!!!!!!!!DD!483010!%!01O-:/
<
()!Q!8441:/.X
pwm output
Pulsewidth Modulation (PWM) is a way to fake an analog output by pulsing the
output. This could be used to dim and brighten an LED or later to control a servo
motor. The following example slowly brightens and dims an LED using for loops.
.:2!=1/C.:!!U!!$;!!!!!DD!CH>!4.:!N-I!2E1!Pef!
,-./!01234567<!!!!!!!!DD!:-!01234!:11/1/
,-./!=--456
7
!!N-I!5.:2!.U&;!.]U'**;!.^^6!!DD!80O1:/.:G!,8=31!N-I!.
!!7
!!!!8:8=-GHI.215=1/C.:?!.6;!!!DD!0120!TI.GE2100!=1,1=!2-!.
!!!!/1=8M5%&&6;!!!!!!!!!!!!!!!DD!483010!N-I!%&&90
!!<
!!N-I!5.:2!.U'**;!.hU&;!.WW6!!DD!/10O1:/.:G!,8=31!N-I!.
!!7
!!!!8:8=-GHI.215=1/C.:?!.6;!!!DD!0120!TI.GE2100!=1,1=!2-!.
!!!!/1=8M5%&&6;!!!!!!!!!!!!!!!DD!483010!N-I!%&&90
!!<!
<
8441:/.X!Q!(*
potentiometer input
Using a potentiometer and one of the Arduino's analog-to-digital conversion
(ADC) pins it is possible to read analog values from 0-1024. The following
example uses a potentiometer to control an LED's rate of blinking.
.:2!4-2C.:!U!&;!!!!DD!.:432!4.:!N-I!2E1!4-21:2.-9121I
.:2!=1/C.:!U!%(;!!!DD!-32432!4.:!N-I!2E1!Pef
,-./!0123456!
7
!!4.:>-/15=1/C.:?!@ABCAB6;!!DD!/1O=8I1!=1/C.:!80!@ABCAB
<
,-./!=--456!
7
!!/.G.28=HI.215=1/C.:?!JKLJ6;!!!!DD!23I:0!=1/C.:!-:
!!/1=8M58:8=-GV18/54-2C.:66;!!!!!DD!48301!4I-GI89
!!/.G.28=HI.215=1/C.:?!P@H6;!!!!!DD!23I:0!=1/C.:!-NN
!!/1=8M58:8=-GV18/54-2C.:66;!!!!!DD!48301!4I-GI89
<
(+!Q!8441:/.X
variabIe resistor input
Variable resistors include CdS light sensors, thermistors, flex sensors, and so
on. This example makes use of a function to read the analog value and set a
delay time. This controls the speed at which an LED brightens and dims.
.:2!=1/C.:!!!!U!!$;!!!!DD!CH>!4.:!N-I!2E1!Pef!
.:2!8:8=-GC.:!U!!&;!!!!DD!,8I.8T=1!I10.02-I!-:!8:8=-G!4.:!&
,-./!01234567<!!!!!!!!DD!:-!01234!:11/1/
,-./!=--456
7
!!N-I!5.:2!.U&;!.]U'**;!.^^6!!DD!80O1:/.:G!,8=31!N-I!.
!!7
!!!!8:8=-GHI.215=1/C.:?!.6;!!!DD!0120!TI.GE2100!=1,1=!2-!.
!!!!/1=8M5/1=8MS8=566;!!!!!!!!DD!G120!2.91!,8=31!8:/!483010
!!<
!!N-I!5.:2!.U'**;!.hU&;!.WW6!!DD!/10O1:/.:G!,8=31!N-I!.
!!7
!!!!8:8=-GHI.215=1/C.:?!.6;!!!DD!0120!TI.GE2100!=1,1=!2-!.
!!!!/1=8M5/1=8MS8=566;!!!!!!!!DD!G120!2.91!,8=31!8:/!483010
!!<!
<
.:2!/1=8MS8=56
7
!!.:2!,;!!!!!!!!!!!!!!!!!!!!!!DD!OI1821!2194-I8IM!,8I.8T=1
!!,!!U!8:8=-GV18/58:8=-GC.:6;!DD!I18/!8:8=-G!,8=31
!!,!DU!#;!!!!!!!!!!!!!!!!!!!!!DD!O-:,1I2!&W%&')!2-!&W%'#
!!I123I:!,;!!!!!!!!!!!!!!!!!!!DD!I123I:0!N.:8=!,8=31
<
8441:/.X!Q!("
servo output
Hobby servos are a type of self-contained motor that can move in a 180 arc. All
that is needed is a pulse sent every 20ms. This example uses a servoPulse
function to move the servo from 10 -170 and back again.
.:2!01I,-C.:!U!';!!!DD!01I,-!O-::1O21/!2-!/.G.28=!4.:!'
.:2!9M`:G=1;!!!!!!!!DD!8:G=1!-N!2E1!01I,-!I-3GE=M!&W%#&
.:2!43=01H./2E;!!!!!DD!01I,-C3=01!N3:O2.-:!,8I.8T=1
!!
,-./!0123456
7
!!4.:>-/1501I,-C.:?!@ABCAB6;!!!DD!0120!4.:!'!80!-32432
<
!
,-./!01I,-C3=015.:2!01I,-C.:?!.:2!9M`:G=16!!!!!
7!!!!!!!
!!43=01H./2E!U!59M`:G=1!Y!%&6!^!+&&;!!DD!/121I9.:10!/1=8M!
!!/.G.28=HI.21501I,-C.:?!JKLJ6;!!!!!!!DD!012!01I,-!E.GE
!!/1=8M>.OI-01O-:/0543=01H./2E6;!!!!!!DD!9.OI-01O-:/!48301
!!/.G.28=HI.21501I,-C.:?!P@H6;!!!!!!!!DD!012!01I,-!=-c
<
!
,-./!=--456
7
!!DD!01I,-!028I20!82!%&!/1G!8:/!I-28210!2-!%"&!/1G
!!N-I!59M`:G=1U%&;!9M`:G=1]U%"&;!9M`:G=1^^6!!!!
!!7
!!!!01I,-C3=01501I,-C.:?!9M`:G=16;!!!!DD!01:/!4.:!8:/!8:G=1
!!!!/1=8M5'&6;!!!!!!!!!!!!!!!!!!!!!!!!DD!I1NI10E!OMO=1
!!<
!!DD!01I,-!028I20!82!%"&!/1G!8:/!I-28210!2-!%&!/1G
!!N-I!59M`:G=1U%"&;!9M`:G=1hU%&;!9M`:G=1WW6!!!!
!!7
!!!!01I,-C3=01501I,-C.:?!9M`:G=16;!!!!DD!01:/!4.:!8:/!8:G=1
!!!!/1=8M5'&6;!!!!!!!!!!!!!!!!!!!!!!!!DD!I1NI10E!OMO=1
!!<
<
(#!Q!8441:/.X

You might also like