summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--1_LED-PLC/LED.rst32
-rw-r--r--1_LED-PLC/blinking.ld22
-rw-r--r--2_Motor-PLC/motor-on-off.ld29
-rw-r--r--2_Motor-PLC/motor.rst30
-rw-r--r--2_Motor-PLC/motor.rst~29
-rw-r--r--2_Motor-PLC/switch-motor.ld20
-rw-r--r--Creating-Ladders.rst65
-rw-r--r--Introduction/Comm.pngbin4400 -> 0 bytes
-rw-r--r--Introduction/DB9M.pngbin577056 -> 0 bytes
-rw-r--r--Introduction/Downloading LD Micro.pngbin80514 -> 0 bytes
-rw-r--r--Introduction/Figcmd.pngbin32606 -> 0 bytes
-rw-r--r--Introduction/Makedb9.pngbin7034 -> 0 bytes
-rw-r--r--Introduction/PIN.pngbin24765 -> 0 bytes
-rw-r--r--Introduction/PLC.aux49
-rw-r--r--Introduction/PLC.log500
-rw-r--r--Introduction/PLC.out17
-rw-r--r--Introduction/PLC.pdfbin1739291 -> 0 bytes
-rw-r--r--Introduction/PLC.tex429
-rw-r--r--Introduction/RS1.pngbin122276 -> 0 bytes
-rw-r--r--Introduction/RS2.pngbin109296 -> 0 bytes
-rw-r--r--Introduction/Setup.pngbin4944 -> 0 bytes
-rw-r--r--Introduction/atmega16.pngbin52964 -> 0 bytes
-rw-r--r--Introduction/avrdude1.pngbin25627 -> 0 bytes
-rw-r--r--Introduction/change.pngbin11498 -> 0 bytes
-rw-r--r--Introduction/cont.pngbin29227 -> 0 bytes
-rw-r--r--Introduction/device.pngbin125246 -> 0 bytes
-rw-r--r--Introduction/fuse1.pngbin111615 -> 0 bytes
-rw-r--r--Introduction/fuse2.pngbin91216 -> 0 bytes
-rw-r--r--Introduction/ld1.pngbin13229 -> 0 bytes
-rw-r--r--Introduction/manavrdude.pngbin174706 -> 0 bytes
-rw-r--r--Introduction/prop.pngbin4880 -> 0 bytes
-rw-r--r--Introduction/screen.pngbin85229 -> 0 bytes
-rw-r--r--Introduction/setup.pngbin27983 -> 0 bytes
-rw-r--r--Introduction/states.pngbin9574 -> 0 bytes
-rw-r--r--Introduction/usb.pngbin169092 -> 0 bytes
-rw-r--r--Programmming-the-controller.rst101
-rw-r--r--README.md (renamed from README.txt)0
-rw-r--r--Software-requirements.rst153
-rw-r--r--images/Comm.pngbin4400 -> 0 bytes
-rw-r--r--images/Downloading LD Micro.pngbin80514 -> 0 bytes
-rw-r--r--images/Downloading-LD-Micro.pngbin80514 -> 0 bytes
-rw-r--r--images/Figcmd.pngbin32606 -> 0 bytes
-rw-r--r--images/PIN.pngbin24765 -> 0 bytes
-rw-r--r--images/Setup.pngbin4944 -> 0 bytes
-rw-r--r--images/avrdude1.pngbin25627 -> 0 bytes
-rw-r--r--images/change.pngbin11498 -> 0 bytes
-rw-r--r--images/cont.pngbin29227 -> 0 bytes
-rw-r--r--images/fuse1.pngbin111615 -> 0 bytes
-rw-r--r--images/fuse2.pngbin91216 -> 0 bytes
-rw-r--r--images/ld1.pngbin13229 -> 0 bytes
-rw-r--r--images/manavrdude.pngbin174706 -> 0 bytes
-rw-r--r--images/prop.pngbin4880 -> 0 bytes
-rw-r--r--images/states.pngbin9574 -> 0 bytes
-rw-r--r--images/usb.pngbin169092 -> 0 bytes
54 files changed, 0 insertions, 1476 deletions
diff --git a/1_LED-PLC/LED.rst b/1_LED-PLC/LED.rst
deleted file mode 100644
index c67d4e5..0000000
--- a/1_LED-PLC/LED.rst
+++ /dev/null
@@ -1,32 +0,0 @@
-Light Emitting Diode
-====================
-
-Overview
---------
-
-LEDs (light emitting diodes) are used in all sorts of
-clever things which is why we have induced them in the kit.
-We will start off with something very simple, turning one
-ON and OFF, repeatedly,producing a pleasant blinking effect.
-In the ld micro insert coil and insert contacts and also
-insert Ton and Toff and give particular timings for both.
-Burn the code to OpenPLC and watch the output
-
-
-Components required
--------------------
-
-OpenPLC board
-
-
-blinking of LED
----------------
-
-For blinking of LED we use timers in ldmicro, On timer(Ton) and Off timer(Toff). The LED is connected to pin 35 on the board.
-The code blinkin.ld illustrates above logic.
-
-switch on LED
--------------
-
-We can control on/off LED by using an input to the PLC. The input switch is connnected to pin 1 and LED is connedted to the same pin 35.
-The code for this experiment is switch-led.ld
diff --git a/1_LED-PLC/blinking.ld b/1_LED-PLC/blinking.ld
deleted file mode 100644
index 2dc1811..0000000
--- a/1_LED-PLC/blinking.ld
+++ /dev/null
@@ -1,22 +0,0 @@
-LDmicro0.1
-MICRO=Atmel AVR ATmega16 40-PDIP
-CYCLE=10000
-CRYSTAL=4000000
-BAUD=2400
-COMPILED=Z:\home\nivedita\Downloads\LLED.hex
-
-IO LIST
- Yled at 3
-END
-
-PROGRAM
-RUNG
- CONTACTS Rosc 0
- TON Ton 1000000
- TOF Toff 1000000
- COIL Rosc 1 0 0
-END
-RUNG
- CONTACTS Rosc 0
- COIL Yled 0 0 0
-END
diff --git a/2_Motor-PLC/motor-on-off.ld b/2_Motor-PLC/motor-on-off.ld
deleted file mode 100644
index 2ee739d..0000000
--- a/2_Motor-PLC/motor-on-off.ld
+++ /dev/null
@@ -1,29 +0,0 @@
-LDmicro0.1
-MICRO=Atmel AVR ATmega16 40-PDIP
-CYCLE=10000
-CRYSTAL=16000000
-BAUD=2400
-COMPILED=Z:\home\nivedita\Documents\OpenPLC\ladder-files\motor-on-off.hex
-
-IO LIST
- XOFF at 2
- XON at 1
- Ym1 at 19
- Ym2 at 20
-END
-
-PROGRAM
-RUNG
- CONTACTS XON 1
- PARALLEL
- COIL Ym1 0 1 0
- COIL Ym2 0 0 1
- END
-END
-RUNG
- CONTACTS XOFF 1
- PARALLEL
- COIL Ym1 0 0 1
- COIL Ym2 0 0 1
- END
-END
diff --git a/2_Motor-PLC/motor.rst b/2_Motor-PLC/motor.rst
deleted file mode 100644
index bcb5ba4..0000000
--- a/2_Motor-PLC/motor.rst
+++ /dev/null
@@ -1,30 +0,0 @@
-DC motor
-========
-
-Overview
---------
-
-DC Motor, like the general purpose motors, are used in providing high RPM for rotation purposes, like for a pulley or in lifting action. Motors, are generally heavy duty, which means, connecting it directly to the controller pins may end up frying it up! So, to source higher
-current, transistors or motor driver ICs are used. These are great as they can be easily used to turn your motor in either direction, just by giving digital high or low to the input pins of L293D Motor Driver IC. The easy part is, controlling the speed can be done by just changing the voltage bias given to the driver IC.
-
-Components required
--------------------
-
-OpenPLC board
-
-DC motor
-
-Switch ON motor
----------------
-
-In this experiment using an input switch, PLC turns on the motor connected to it. Motor is driven by l293d as explained above. L293d inputs are conncted to controller pin number 19 and 20. The switch is connected to pin number 1.
-
-To run motor we always need two coils on ldmicro and one should be 'set' and other 'reset'. If we swap the coil status motor will run in opposite direction.
-
-Motor-on-off
-------------
-
-We now know how to turn on a motor, Similarly we can turn it Off by giving another input. To stop motor, status of both the coils should be Reset, So in new rung we can give a switch and reset both the coils.
-Anothr switch is connected to pin number 2.
-
-
diff --git a/2_Motor-PLC/motor.rst~ b/2_Motor-PLC/motor.rst~
deleted file mode 100644
index d0deb8e..0000000
--- a/2_Motor-PLC/motor.rst~
+++ /dev/null
@@ -1,29 +0,0 @@
-DC motor
-========
-
-Overview
---------
-
-DC Motor, like the general purpose motors, are used in providing high RPM for rotation purposes, like for a pulley or in lifting action. Motors, are generally heavy duty, which means, connecting it directly to the controller pins may end up frying it up! So, to source higher
-current, transistors or motor driver ICs are used. These are great as they can be easily used to turn your motor in either direction, just by giving digital high or low to the input pins of L293D Motor Driver IC. The easy part is, controlling the speed can be done by just changing the voltage bias given to the driver IC.
-
-Components required
--------------------
-
-OpenPLC board
-DC motor
-
-Switch ON motor
----------------
-
-In this experiment using an input switch, PLC turns on the motor connected to it. Motor is driven by l293d as explained above. L293d inputs are conncted to controller pin number 19 and 20. The switch is connected to pin number 1.
-
-To run motor we always need two coils on ldmicro and one should be 'set' and other 'reset'. If we swap the coil status motor will run in opposite direction.
-
-Motor-on-off
-------------
-
-We now know how to turn on a motor, Similarly we can turn it Off by giving another input. To stop motor, status of both the coils should be Reset, So in new rung we can give a switch and reset both the coils.
-Anothr switch is connected to pin number 2.
-
-
diff --git a/2_Motor-PLC/switch-motor.ld b/2_Motor-PLC/switch-motor.ld
deleted file mode 100644
index 6a4c894..0000000
--- a/2_Motor-PLC/switch-motor.ld
+++ /dev/null
@@ -1,20 +0,0 @@
-LDmicro0.1
-MICRO=Atmel AVR ATmega16 40-PDIP
-CYCLE=10000
-CRYSTAL=16000000
-BAUD=2400
-
-IO LIST
- Xswitch at 1
- Ym1 at 19
- Ym2 at 20
-END
-
-PROGRAM
-RUNG
- CONTACTS Xswitch 1
- PARALLEL
- COIL Ym1 0 1 0
- COIL Ym2 0 0 1
- END
-END
diff --git a/Creating-Ladders.rst b/Creating-Ladders.rst
deleted file mode 100644
index d04d9dc..0000000
--- a/Creating-Ladders.rst
+++ /dev/null
@@ -1,65 +0,0 @@
-Creating Ladders using Ld micro
-===============================
-
-LD Micro’s simple user interface is really easy to use and is self explanatory.To get started working with LD Micro, just double click the LD Micro executable present in your system. Once opened, you shall get such a GUI.
-
-.. image:: /images/ld1.png
- :height: 540px
- :width: 750px
- :scale: 150
-
-Before starting to make the ladder, first make the necessary changes in
-the default settings, so as to generate the HEX code for your microcontroller.
-
-Under Settings tab, select the MCU Parameters Option
-
-.. image:: /images/Setup.png
- :height: 340px
- :width: 450px
- :scale: 150
-
-Then after selecting, change the clock frequency to 16MHz and if using
-UART change the baud rate to 9600.
-
-.. image:: /images/cont.png
- :height: 540px
- :width: 650px
- :scale: 150
-
-Now that the configurations are set, the next step can be followed to
-design the ladder with the appropriate logic.
-
-Start off with having a look at the Instruction tab. It has a lot of
-instructions that are in accordance with the Ladder logic followed for the PLCs and work in the same way and are similar to the ones described above under the ’Understanding the Instructions’ section.
-
-After selecting the appropriate instruction, just double click the instruction to edit the name of the variable and other parameters related to the particular instruction.
-
-.. image:: /images/change.png
- :height: 540px
- :width: 650px
- :scale: 150
-
-After making the appropriate ladder for the application, the digital input and outputs should be given an appropriate pin number of the controller and the connections should be done accordingly. This can be done by double clicking the appropriate pin to be configured in the consolidated table just below the ladder made.
-
-.. image:: /images/PIN.png
- :height: 540px
- :width: 600px
- :scale: 150
-
-Now that the logic is set, the ladder can be simulated to verify it’s working. This is done by clicking the Simulate tab and Simulation Mode option under it. This is then followed by a similar screen where Blue indicates LOW and Pink indicates HIGH. To start the simulation, under Simulate tab click Start Real-Time Simulation option. After this, to change the state, just double click the instruction. The appropriate changes and values pertaining to different variables can be seen in the consolidated instruction table under the State column. To come out of simulation mode, click the same Simulation Mode option.
-
-.. image:: /images/states.png
- :height: 340px
- :width: 450px
- :scale: 150
-
-After the ladder along with assigning the appropriate pin numbers, the
-HEX code can be generated. This can be done by first saving the ladder
-under the File tab with the Save As option. Save the file in the appropriate destination folder with a suitable name. Remember the final destination of the same for future. Now, to generate the HEX file, select the Compile tab and then the option Compile As. Then save this text file in the desired destination folder. The location shall be noted as it’d be needed to burn the code onto the controller using the command line arguments later.
-
-
-
-
-
-
-
diff --git a/Introduction/Comm.png b/Introduction/Comm.png
deleted file mode 100644
index 78567a8..0000000
--- a/Introduction/Comm.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/DB9M.png b/Introduction/DB9M.png
deleted file mode 100644
index c24e9a8..0000000
--- a/Introduction/DB9M.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/Downloading LD Micro.png b/Introduction/Downloading LD Micro.png
deleted file mode 100644
index 6f5037d..0000000
--- a/Introduction/Downloading LD Micro.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/Figcmd.png b/Introduction/Figcmd.png
deleted file mode 100644
index 6c8197b..0000000
--- a/Introduction/Figcmd.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/Makedb9.png b/Introduction/Makedb9.png
deleted file mode 100644
index 29291ff..0000000
--- a/Introduction/Makedb9.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/PIN.png b/Introduction/PIN.png
deleted file mode 100644
index aba755c..0000000
--- a/Introduction/PIN.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/PLC.aux b/Introduction/PLC.aux
deleted file mode 100644
index c04264c..0000000
--- a/Introduction/PLC.aux
+++ /dev/null
@@ -1,49 +0,0 @@
-\relax
-\ifx\hyper@anchor\@undefined
-\global \let \oldcontentsline\contentsline
-\gdef \contentsline#1#2#3#4{\oldcontentsline{#1}{#2}{#3}}
-\global \let \oldnewlabel\newlabel
-\gdef \newlabel#1#2{\newlabelxx{#1}#2}
-\gdef \newlabelxx#1#2#3#4#5#6{\oldnewlabel{#1}{{#2}{#3}}}
-\AtEndDocument{\let \contentsline\oldcontentsline
-\let \newlabel\oldnewlabel}
-\else
-\global \let \hyper@last\relax
-\fi
-
-\@writefile{toc}{\contentsline {section}{\numberline {1}Introduction}{1}{section.1}}
-\@writefile{toc}{\contentsline {section}{\numberline {2}Setting up the LD Micro executable}{3}{section.2}}
-\@writefile{lof}{\contentsline {figure}{\numberline {1}{\ignorespaces Downloading LD Micro}}{3}{figure.1}}
-\@writefile{toc}{\contentsline {section}{\numberline {3}Getting started with LDMicro}{4}{section.3}}
-\@writefile{toc}{\contentsline {subsection}{\numberline {3.1}Understanding the instructions}{4}{subsection.3.1}}
-\@writefile{toc}{\contentsline {subsubsection}{\numberline {3.1.1}Configuration of ATmega16A}{7}{subsubsection.3.1.1}}
-\@writefile{lof}{\contentsline {figure}{\numberline {2}{\ignorespaces ATmega16A Pin Configuration}}{7}{figure.2}}
-\@writefile{toc}{\contentsline {subsection}{\numberline {3.2}Creating ladders using LD Micro}{8}{subsection.3.2}}
-\@writefile{lof}{\contentsline {figure}{\numberline {3}{\ignorespaces Startup screen of LD Micro}}{8}{figure.3}}
-\@writefile{lof}{\contentsline {figure}{\numberline {4}{\ignorespaces Changing the controller parameters}}{9}{figure.4}}
-\@writefile{lof}{\contentsline {figure}{\numberline {5}{\ignorespaces Selecting the appropriate microcontroller}}{10}{figure.5}}
-\@writefile{lof}{\contentsline {figure}{\numberline {6}{\ignorespaces Editing the parameters of an instruction}}{11}{figure.6}}
-\@writefile{lof}{\contentsline {figure}{\numberline {7}{\ignorespaces Assigning the appropriate pin number}}{12}{figure.7}}
-\@writefile{lof}{\contentsline {figure}{\numberline {8}{\ignorespaces Tracking the pin states from the table}}{13}{figure.8}}
-\@writefile{toc}{\contentsline {section}{\numberline {4}Programming the IC}{15}{section.4}}
-\@writefile{toc}{\contentsline {subsection}{\numberline {4.1}Installing WINAVR}{15}{subsection.4.1}}
-\@writefile{lof}{\contentsline {figure}{\numberline {9}{\ignorespaces AVRDUDE manual on Linux}}{16}{figure.9}}
-\@writefile{toc}{\contentsline {subsection}{\numberline {4.2}Setting up WINAVR on WINDOWS}{17}{subsection.4.2}}
-\@writefile{lof}{\contentsline {figure}{\numberline {10}{\ignorespaces Terminal in Search screen}}{17}{figure.10}}
-\@writefile{lof}{\contentsline {figure}{\numberline {11}{\ignorespaces Terminal in use}}{17}{figure.11}}
-\@writefile{lof}{\contentsline {figure}{\numberline {12}{\ignorespaces Avrdude access via WINAVR and Terminal}}{18}{figure.12}}
-\@writefile{toc}{\contentsline {subsection}{\numberline {4.3}Identifying the Port of the programmer}{19}{subsection.4.3}}
-\@writefile{lof}{\contentsline {figure}{\numberline {13}{\ignorespaces Terminal in Search screen}}{19}{figure.13}}
-\@writefile{toc}{\contentsline {subsection}{\numberline {4.4}USBASP as ISP}{21}{subsection.4.4}}
-\@writefile{lof}{\contentsline {figure}{\numberline {14}{\ignorespaces Using USBASP as an ISP }}{22}{figure.14}}
-\@writefile{toc}{\contentsline {subsubsection}{\numberline {4.4.1}Troubleshooting}{22}{subsubsection.4.4.1}}
-\@writefile{toc}{\contentsline {subsection}{\numberline {4.5}RS232 as a Programmer}{24}{subsection.4.5}}
-\@writefile{lof}{\contentsline {figure}{\numberline {15}{\ignorespaces DB9 connector}}{24}{figure.15}}
-\@writefile{lof}{\contentsline {figure}{\numberline {16}{\ignorespaces DB9 connector}}{24}{figure.16}}
-\@writefile{toc}{\contentsline {subsection}{\numberline {4.6}Programming using RS-232}{25}{subsection.4.6}}
-\@writefile{lof}{\contentsline {figure}{\numberline {17}{\ignorespaces Programming via RS-232}}{26}{figure.17}}
-\@writefile{toc}{\contentsline {subsubsection}{\numberline {4.6.1}Troubleshooting}{26}{subsubsection.4.6.1}}
-\@writefile{toc}{\contentsline {subsection}{\numberline {4.7}Setting up the fuse bits}{28}{subsection.4.7}}
-\@writefile{lof}{\contentsline {figure}{\numberline {18}{\ignorespaces Setting the fuse bits}}{29}{figure.18}}
-\@writefile{lof}{\contentsline {figure}{\numberline {19}{\ignorespaces Setting the fuse bits}}{30}{figure.19}}
-\@writefile{toc}{\contentsline {section}{\numberline {5}Using UART function}{33}{section.5}}
diff --git a/Introduction/PLC.log b/Introduction/PLC.log
deleted file mode 100644
index 016bb11..0000000
--- a/Introduction/PLC.log
+++ /dev/null
@@ -1,500 +0,0 @@
-This is pdfTeX, Version 3.1415926-1.40.10 (TeX Live 2009/Debian) (format=pdflatex 2014.2.22) 22 NOV 2015 12:13
-entering extended mode
- %&-line parsing enabled.
-**PLC.tex
-(./PLC.tex
-LaTeX2e <2009/09/24>
-Babel <v3.8l> and hyphenation patterns for english, usenglishmax, dumylang, noh
-yphenation, farsi, arabic, croatian, bulgarian, ukrainian, russian, czech, slov
-ak, danish, dutch, finnish, french, basque, ngerman, german, german-x-2009-06-1
-9, ngerman-x-2009-06-19, ibycus, monogreek, greek, ancientgreek, hungarian, san
-skrit, italian, latin, latvian, lithuanian, mongolian2a, mongolian, bokmal, nyn
-orsk, romanian, irish, coptic, serbian, turkish, welsh, esperanto, uppersorbian
-, estonian, indonesian, interlingua, icelandic, kurmanji, slovenian, polish, po
-rtuguese, spanish, galician, catalan, swedish, ukenglish, pinyin, loaded.
-(/usr/share/texmf-texlive/tex/latex/base/article.cls
-Document Class: article 2007/10/19 v1.4h Standard LaTeX document class
-(/usr/share/texmf-texlive/tex/latex/base/size12.clo
-File: size12.clo 2007/10/19 v1.4h Standard LaTeX file (size option)
-)
-\c@part=\count79
-\c@section=\count80
-\c@subsection=\count81
-\c@subsubsection=\count82
-\c@paragraph=\count83
-\c@subparagraph=\count84
-\c@figure=\count85
-\c@table=\count86
-\abovecaptionskip=\skip41
-\belowcaptionskip=\skip42
-\bibindent=\dimen102
-)
-(/usr/share/texmf-texlive/tex/latex/amsfonts/amsfonts.sty
-Package: amsfonts 2009/06/22 v3.00 Basic AMSFonts support
-\@emptytoks=\toks14
-\symAMSa=\mathgroup4
-\symAMSb=\mathgroup5
-LaTeX Font Info: Overwriting math alphabet `\mathfrak' in version `bold'
-(Font) U/euf/m/n --> U/euf/b/n on input line 96.
-)
-(/usr/share/texmf-texlive/tex/latex/hyperref/hyperref.sty
-Package: hyperref 2009/10/09 v6.79a Hypertext links for LaTeX
-
-(/usr/share/texmf-texlive/tex/latex/graphics/keyval.sty
-Package: keyval 1999/03/16 v1.13 key=value parser (DPC)
-\KV@toks@=\toks15
-)
-(/usr/share/texmf-texlive/tex/generic/oberdiek/ifpdf.sty
-Package: ifpdf 2009/04/10 v2.0 Provides the ifpdf switch (HO)
-Package ifpdf Info: pdfTeX in pdf mode detected.
-)
-(/usr/share/texmf-texlive/tex/generic/oberdiek/ifvtex.sty
-Package: ifvtex 2008/11/04 v1.4 Switches for detecting VTeX and its modes (HO)
-Package ifvtex Info: VTeX not detected.
-)
-(/usr/share/texmf-texlive/tex/generic/ifxetex/ifxetex.sty
-Package: ifxetex 2009/01/23 v0.5 Provides ifxetex conditional
-)
-(/usr/share/texmf-texlive/tex/latex/oberdiek/hycolor.sty
-Package: hycolor 2009/10/02 v1.5 Code for color options of hyperref/bookmark (H
-O)
-
-(/usr/share/texmf-texlive/tex/latex/oberdiek/xcolor-patch.sty
-Package: xcolor-patch 2009/10/02 xcolor patch
-))
-\@linkdim=\dimen103
-\Hy@linkcounter=\count87
-\Hy@pagecounter=\count88
-
-(/usr/share/texmf-texlive/tex/latex/hyperref/pd1enc.def
-File: pd1enc.def 2009/10/09 v6.79a Hyperref: PDFDocEncoding definition (HO)
-)
-(/usr/share/texmf-texlive/tex/generic/oberdiek/etexcmds.sty
-Package: etexcmds 2007/12/12 v1.2 Prefix for e-TeX command names (HO)
-
-(/usr/share/texmf-texlive/tex/generic/oberdiek/infwarerr.sty
-Package: infwarerr 2007/09/09 v1.2 Providing info/warning/message (HO)
-)
-Package etexcmds Info: Could not find \expanded.
-(etexcmds) That can mean that you are not using pdfTeX 1.50 or
-(etexcmds) that some package has redefined \expanded.
-(etexcmds) In the latter case, load this package earlier.
-)
-(/usr/share/texmf-texlive/tex/latex/latexconfig/hyperref.cfg
-File: hyperref.cfg 2002/06/06 v1.2 hyperref configuration of TeXLive
-)
-(/usr/share/texmf-texlive/tex/latex/oberdiek/kvoptions.sty
-Package: kvoptions 2009/08/13 v3.4 Keyval support for LaTeX options (HO)
-
-(/usr/share/texmf-texlive/tex/generic/oberdiek/kvsetkeys.sty
-Package: kvsetkeys 2009/07/30 v1.5 Key value parser with default handler suppor
-t (HO)
-))
-Package hyperref Info: Hyper figures OFF on input line 2975.
-Package hyperref Info: Link nesting OFF on input line 2980.
-Package hyperref Info: Hyper index ON on input line 2983.
-Package hyperref Info: Plain pages OFF on input line 2990.
-Package hyperref Info: Backreferencing OFF on input line 2995.
-
-Implicit mode ON; LaTeX internals redefined
-Package hyperref Info: Bookmarks ON on input line 3191.
-(/usr/share/texmf-texlive/tex/latex/ltxmisc/url.sty
-\Urlmuskip=\muskip10
-Package: url 2006/04/12 ver 3.3 Verb mode for urls, etc.
-)
-LaTeX Info: Redefining \url on input line 3428.
-
-(/usr/share/texmf-texlive/tex/generic/oberdiek/bitset.sty
-Package: bitset 2007/09/28 v1.0 Data type bit set (HO)
-
-(/usr/share/texmf-texlive/tex/generic/oberdiek/intcalc.sty
-Package: intcalc 2007/09/27 v1.1 Expandable integer calculations (HO)
-)
-(/usr/share/texmf-texlive/tex/generic/oberdiek/bigintcalc.sty
-Package: bigintcalc 2007/11/11 v1.1 Expandable big integer calculations (HO)
-
-(/usr/share/texmf-texlive/tex/generic/oberdiek/pdftexcmds.sty
-Package: pdftexcmds 2009/09/23 v0.6 LuaTeX support for pdfTeX utility functions
- (HO)
-
-(/usr/share/texmf-texlive/tex/generic/oberdiek/ifluatex.sty
-Package: ifluatex 2009/04/17 v1.2 Provides the ifluatex switch (HO)
-Package ifluatex Info: LuaTeX not detected.
-)
-(/usr/share/texmf-texlive/tex/generic/oberdiek/ltxcmds.sty
-Package: ltxcmds 2009/08/05 v1.0 Some LaTeX kernel commands for general use (HO
-)
-)
-Package pdftexcmds Info: LuaTeX not detected.
-Package pdftexcmds Info: \pdf@primitive is available.
-Package pdftexcmds Info: \pdf@ifprimitive is available.
-)))
-\Fld@menulength=\count89
-\Field@Width=\dimen104
-\Fld@charsize=\dimen105
-\Field@toks=\toks16
-Package hyperref Info: Hyper figures OFF on input line 4377.
-Package hyperref Info: Link nesting OFF on input line 4382.
-Package hyperref Info: Hyper index ON on input line 4385.
-Package hyperref Info: backreferencing OFF on input line 4392.
-Package hyperref Info: Link coloring OFF on input line 4397.
-Package hyperref Info: Link coloring with OCG OFF on input line 4402.
-Package hyperref Info: PDF/A mode OFF on input line 4407.
-
-(/usr/share/texmf-texlive/tex/generic/oberdiek/atbegshi.sty
-Package: atbegshi 2008/07/31 v1.9 At begin shipout hook (HO)
-)
-\Hy@abspage=\count90
-\c@Item=\count91
-\c@Hfootnote=\count92
-)
-*hyperref using default driver hpdftex*
-(/usr/share/texmf-texlive/tex/latex/hyperref/hpdftex.def
-File: hpdftex.def 2009/10/09 v6.79a Hyperref driver for pdfTeX
-\Fld@listcount=\count93
-)
-(/usr/share/texmf-texlive/tex/latex/setspace/setspace.sty
-Package: setspace 2000/12/01 6.7 Contributed and Supported LaTeX2e package
-
-Package: `setspace' 6.7 <2000/12/01>
-) (/usr/share/texmf-texlive/tex/latex/graphics/graphicx.sty
-Package: graphicx 1999/02/16 v1.0f Enhanced LaTeX Graphics (DPC,SPQR)
-
-(/usr/share/texmf-texlive/tex/latex/graphics/graphics.sty
-Package: graphics 2009/02/05 v1.0o Standard LaTeX Graphics (DPC,SPQR)
-
-(/usr/share/texmf-texlive/tex/latex/graphics/trig.sty
-Package: trig 1999/03/16 v1.09 sin cos tan (DPC)
-)
-(/etc/texmf/tex/latex/config/graphics.cfg
-File: graphics.cfg 2009/08/28 v1.8 graphics configuration of TeX Live
-)
-Package graphics Info: Driver file: pdftex.def on input line 91.
-
-(/usr/share/texmf-texlive/tex/latex/pdftex-def/pdftex.def
-File: pdftex.def 2010/03/12 v0.04p Graphics/color for pdfTeX
-\Gread@gobject=\count94
-))
-\Gin@req@height=\dimen106
-\Gin@req@width=\dimen107
-)
-(/usr/share/texmf-texlive/tex/latex/was/gensymb.sty
-Package: gensymb 2003/07/02 v1.0 (WaS)
-)
-(/usr/share/texmf-texlive/tex/latex/moresize/moresize.sty
-Package: moresize 1999/07/26 v1.9 (more font sizes)
-) (./PLC.aux)
-\openout1 = `PLC.aux'.
-
-LaTeX Font Info: Checking defaults for OML/cmm/m/it on input line 8.
-LaTeX Font Info: ... okay on input line 8.
-LaTeX Font Info: Checking defaults for T1/cmr/m/n on input line 8.
-LaTeX Font Info: ... okay on input line 8.
-LaTeX Font Info: Checking defaults for OT1/cmr/m/n on input line 8.
-LaTeX Font Info: ... okay on input line 8.
-LaTeX Font Info: Checking defaults for OMS/cmsy/m/n on input line 8.
-LaTeX Font Info: ... okay on input line 8.
-LaTeX Font Info: Checking defaults for OMX/cmex/m/n on input line 8.
-LaTeX Font Info: ... okay on input line 8.
-LaTeX Font Info: Checking defaults for U/cmr/m/n on input line 8.
-LaTeX Font Info: ... okay on input line 8.
-LaTeX Font Info: Checking defaults for PD1/pdf/m/n on input line 8.
-LaTeX Font Info: ... okay on input line 8.
-Package hyperref Info: Link coloring OFF on input line 8.
-
-(/usr/share/texmf-texlive/tex/latex/hyperref/nameref.sty
-Package: nameref 2007/05/29 v2.31 Cross-referencing by name of section
-
-(/usr/share/texmf-texlive/tex/latex/oberdiek/refcount.sty
-Package: refcount 2008/08/11 v3.1 Data extraction from references (HO)
-)
-\c@section@level=\count95
-)
-LaTeX Info: Redefining \ref on input line 8.
-LaTeX Info: Redefining \pageref on input line 8.
- (./PLC.out)
-(./PLC.out)
-\@outlinefile=\write3
-\openout3 = `PLC.out'.
-
-\AtBeginShipoutBox=\box26
- (/usr/share/texmf-texlive/tex/context/base/supp-pdf.mkii
-[Loading MPS to PDF converter (version 2006.09.02).]
-\scratchcounter=\count96
-\scratchdimen=\dimen108
-\scratchbox=\box27
-\nofMPsegments=\count97
-\nofMParguments=\count98
-\everyMPshowfont=\toks17
-\MPscratchCnt=\count99
-\MPscratchDim=\dimen109
-\MPnumerator=\count100
-\everyMPtoPDFconversion=\toks18
-)
-LaTeX Info: Redefining \celsius on input line 8.
-Package gensymb Info: Faking symbols for \degree and \celsius on input line 8.
-
-
-Package gensymb Warning: Not defining \perthousand.
-
-LaTeX Info: Redefining \ohm on input line 8.
-Package gensymb Info: Using \Omega for \ohm on input line 8.
-
-Package gensymb Warning: Not defining \micro.
-
-
-Overfull \hbox (23.7252pt too wide) in paragraph at lines 15--15
-\OT1/cmtt/m/n/12 Block Diagram, Ladder Diagram, Structured Text, Sequential Fun
-ction
- []
-
-[1
-
-{/var/lib/texmf/fonts/map/pdftex/updmap/pdftex.map}] [2]
-LaTeX Font Info: Try loading font information for U+msa on input line 32.
-
-(/usr/share/texmf-texlive/tex/latex/amsfonts/umsa.fd
-File: umsa.fd 2009/06/22 v3.00 AMS symbols A
-)
-LaTeX Font Info: Try loading font information for U+msb on input line 32.
-
-(/usr/share/texmf-texlive/tex/latex/amsfonts/umsb.fd
-File: umsb.fd 2009/06/22 v3.00 AMS symbols B
-)
-<screen.png, id=17, 576.65437pt x 499.8675pt>
-File: screen.png Graphic file (type png)
- <use screen.png> [3 <./screen.png>]
-LaTeX Font Info: Try loading font information for OMS+cmr on input line 59.
- (/usr/share/texmf-texlive/tex/latex/base/omscmr.fd
-File: omscmr.fd 1999/05/25 v2.5h Standard LaTeX font definitions
-)
-LaTeX Font Info: Font shape `OMS/cmr/m/n' in size <12> not available
-(Font) Font shape `OMS/cmsy/m/n' tried instead on input line 59.
- [4] [5] [6]
-<atmega16.png, id=56, 330.23375pt x 406.51875pt>
-File: atmega16.png Graphic file (type png)
- <use atmega16.png> [7 <./atmega16.png>] <ld1.png, id=64, 950.04938pt x 546.541
-87pt>
-File: ld1.png Graphic file (type png)
- <use ld1.png> [8 <./ld1.png>] <prop.png, id=72, 267.24844pt x 129.48375pt>
-File: prop.png Graphic file (type png)
- <use prop.png>
-<Setup.png, id=73, 356.33125pt x 172.645pt>
-File: Setup.png Graphic file (type png)
- <use Setup.png> [9 <./prop.png> <./Setup.png>] <cont.png, id=81, 653.44125pt x
- 515.9275pt>
-File: cont.png Graphic file (type png)
- <use cont.png>
-Overfull \hbox (132.75371pt too wide) in paragraph at lines 119--120
- [][]
- []
-
-[10 <./cont.png>] <change.png, id=88, 459.96844pt x 263.48438pt>
-File: change.png Graphic file (type png)
-
-<use change.png> [11 <./change.png>]
-<PIN.png, id=95, 478.03593pt x 384.6872pt>
-File: PIN.png Graphic file (type png)
- <use PIN.png> [12 <./PIN.png>]
-<states.png, id=102, 598.235pt x 299.1175pt>
-File: states.png Graphic file (type png)
- <use states.png>
-Overfull \hbox (88.58865pt too wide) in paragraph at lines 148--149
- [][]
- []
-
-[13 <./states.png>] [14]
-Missing character: There is no â in font cmr12!
-Missing character: There is no € in font cmr12!
-Missing character: There is no ™ in font cmr12!
-
-Overfull \hbox (48.92522pt too wide) in paragraph at lines 156--161
-[]$\OT1/cmtt/m/n/12 http : / / softlayer-[]sng . dl . sourceforge . net / proje
-ct / winavr / WinAVR / 20100110 /
- []
-
-<manavrdude.png, id=116, 814.54312pt x 558.58687pt>
-File: manavrdude.png Graphic file (type png)
- <use manavrdude.png>
-
-LaTeX Warning: `!h' float specifier changed to `!ht'.
-
-[15] [16 <./manavrdude.png>] <Figcmd.png, id=134, 408.77719pt x 256.70906pt>
-File: Figcmd.png Graphic file (type png)
-
-<use Figcmd.png> <Comm.png, id=135, 673.51625pt x 252.945pt>
-File: Comm.png Graphic file (type png)
- <use Comm.png>
-Overfull \hbox (81.45816pt too wide) in paragraph at lines 194--195
- [][]
- []
-
-<avrdude1.png, id=136, 507.39563pt x 417.05812pt>
-File: avrdude1.png Graphic file (type png)
- <use avrdude1.png>
-Overfull \hbox (15.91705pt too wide) in paragraph at lines 205--206
- [][]
- []
-
-
-LaTeX Warning: `h' float specifier changed to `ht'.
-
-[17
-
- <./Figcmd.png> <./Comm.png>]
-Overfull \hbox (4.3pt too wide) in paragraph at lines 210--211
-[]\OT1/cmtt/m/n/12 IMP: If you do not get this, please download the software an
-d
- []
-
-[18 <./avrdude1.png>] <device.png, id=152, 861.2175pt x 491.8375pt>
-File: device.png Graphic file (type png)
-
-<use device.png>
-Overfull \hbox (255.91154pt too wide) in paragraph at lines 223--224
- [][]
- []
-
-[19 <./device.png>]
-Overfull \hbox (59.87503pt too wide) in paragraph at lines 229--230
-[]\OT1/cmtt/m/n/12 avrdude -p atmega16 -P /dev/ttyUSB0 -c ponyser -v -U flash:w
-:test1.hex
- []
-
-[20]
-Missing character: There is no ï in font cmtt12!
-Missing character: There is no ¬ in font cmtt12!
-Missing character: There is no ‚ in font cmtt12!
-
-Overfull \hbox (29.00002pt too wide) in paragraph at lines 254--255
-[]\OT1/cmtt/m/n/12 sudo avrdude -p atmega16 -P usb -c usbasp -B10 -U ash:w:Blin
-k.hex
- []
-
-<usb.png, id=165, 633.36626pt x 439.6425pt>
-File: usb.png Graphic file (type png)
- <use usb.png>
-Overfull \hbox (180.02437pt too wide) in paragraph at lines 264--265
-[][]
- []
-
-
-LaTeX Warning: `!h' float specifier changed to `!ht'.
-
-[21] [22 <./usb.png>] [23] <DB9M.png, id=183, 1071.00125pt x 602.25pt>
-File: DB9M.png Graphic file (type png)
-
-<use DB9M.png> <Makedb9.png, id=184, 305.14pt x 140.525pt>
-File: Makedb9.png Graphic file (type png)
- <use Makedb9.png>
-[24 <./DB9M.png> <./Makedb9.png (PNG copy)>]
-Overfull \hbox (59.87503pt too wide) in paragraph at lines 318--318
-[]\OT1/cmtt/m/n/12 avrdude -p atmega16 -P /dev/ttyUSB0 -c ponyser -v -U flash:w
-:test1.hex
- []
-
-
-Underfull \hbox (badness 10000) in paragraph at lines 318--318
-
- []
-
-<RS1.png, id=193, 978.65625pt x 534.49687pt>
-File: RS1.png Graphic file (type png)
- <use RS1.png>
-Overfull \hbox (1.45557pt too wide) in paragraph at lines 321--322
-[][]
- []
-
-<RS2.png, id=194, 865.2325pt x 742.775pt>
-File: RS2.png Graphic file (type png)
- <use RS2.png>
-Overfull \hbox (42.61519pt too wide) in paragraph at lines 325--326
-[][]
- []
-
-
-LaTeX Warning: `!h' float specifier changed to `!ht'.
-
-[25 <./RS1.png>] [26 <./RS2.png>] [27]
-Overfull \hbox (16.65001pt too wide) in paragraph at lines 351--352
-[]\OT1/cmtt/m/n/12 WARNING: Fuse bits control the way the controller responds.
-If
- []
-
-
-Overfull \hbox (29.9002pt too wide) in paragraph at lines 351--352
-\OT1/cmtt/m/n/12 any mistake is made in setting up the fuse bits, then the cont
-roller
- []
-
-
-Overfull \hbox (5.2002pt too wide) in paragraph at lines 351--352
-\OT1/cmtt/m/n/12 becomes isolated from the external circuit. This means that th
-e
- []
-
-
-Overfull \hbox (36.07521pt too wide) in paragraph at lines 351--352
-\OT1/cmtt/m/n/12 controller doesn't respond and renders useless. Hence, always
-triple
- []
-
-
-Overfull \hbox (5.2002pt too wide) in paragraph at lines 351--352
-\OT1/cmtt/m/n/12 check before entering the fuse bits. This is the best practice
-,
- []
-
-
-Overfull \hbox (29.00002pt too wide) in paragraph at lines 360--361
-[]\OT1/cmtt/m/n/12 sudo avrdude -p m16 -c usbasp -U lfuse:w:0xFF:m -U hfuse:w:0
-xD9:m
- []
-
-
-Overfull \hbox (10.475pt too wide) in paragraph at lines 365--365
-[]\OT1/cmtt/m/n/12 avrdude -p m16 -c ponyser -P /dev/ttyUSB0 -U lfuse:w:0xFF:m
--U
- []
-
-[28] <fuse1.png, id=218, 835.62187pt x 519.44063pt>
-File: fuse1.png Graphic file (type png)
- <use fuse1.png>
-Overfull \hbox (27.8099pt too wide) in paragraph at lines 369--370
- [][]
- []
-
-[29 <./fuse1.png>] <fuse2.png, id=225, 947.54pt x 654.445pt>
-File: fuse2.png Graphic file (type png)
- <use fuse2.png>
-Overfull \hbox (83.76883pt too wide) in paragraph at lines 375--376
- [][]
- []
-
-[30 <./fuse2.png>] [31] [32] [33
-
-] (./PLC.aux) )
-Here is how much of TeX's memory you used:
- 4526 strings out of 493848
- 65213 string characters out of 1152823
- 133347 words of memory out of 3000000
- 7635 multiletter control sequences out of 15000+50000
- 11671 words of font info for 46 fonts, out of 3000000 for 9000
- 714 hyphenation exceptions out of 8191
- 38i,8n,36p,1081b,371s stack positions out of 5000i,500n,10000p,200000b,50000s
-pdfTeX warning (dest): name{Hfootnote.1} has been referenced but
- does not exist, replaced by a fixed one
-
-</usr/share/texmf-texlive/fonts/type1/public/amsfonts/cm/cmbx12.pfb></usr/share
-/texmf-texlive/fonts/type1/public/amsfonts/cm/cmr10.pfb></usr/share/texmf-texli
-ve/fonts/type1/public/amsfonts/cm/cmr12.pfb></usr/share/texmf-texlive/fonts/typ
-e1/public/amsfonts/cm/cmr7.pfb></usr/share/texmf-texlive/fonts/type1/public/ams
-fonts/cm/cmr8.pfb></usr/share/texmf-texlive/fonts/type1/public/amsfonts/cm/cmsy
-10.pfb></usr/share/texmf-texlive/fonts/type1/public/amsfonts/cm/cmtt12.pfb></us
-r/share/texmf-texlive/fonts/type1/public/amsfonts/symbols/msam10.pfb>
-Output written on PLC.pdf (33 pages, 1739291 bytes).
-PDF statistics:
- 292 PDF objects out of 1000 (max. 8388607)
- 85 named destinations out of 1000 (max. 500000)
- 106 words of extra memory for PDF output out of 10000 (max. 10000000)
-
diff --git a/Introduction/PLC.out b/Introduction/PLC.out
deleted file mode 100644
index 451340e..0000000
--- a/Introduction/PLC.out
+++ /dev/null
@@ -1,17 +0,0 @@
-\BOOKMARK [1][-]{section.1}{Introduction}{}
-\BOOKMARK [1][-]{section.2}{Setting up the LD Micro executable}{}
-\BOOKMARK [1][-]{section.3}{Getting started with LDMicro}{}
-\BOOKMARK [2][-]{subsection.3.1}{Understanding the instructions}{section.3}
-\BOOKMARK [3][-]{subsubsection.3.1.1}{Configuration of ATmega16A}{subsection.3.1}
-\BOOKMARK [2][-]{subsection.3.2}{Creating ladders using LD Micro}{section.3}
-\BOOKMARK [1][-]{section.4}{Programming the IC}{}
-\BOOKMARK [2][-]{subsection.4.1}{Installing WINAVR}{section.4}
-\BOOKMARK [2][-]{subsection.4.2}{Setting up WINAVR on WINDOWS}{section.4}
-\BOOKMARK [2][-]{subsection.4.3}{Identifying the Port of the programmer}{section.4}
-\BOOKMARK [2][-]{subsection.4.4}{USBASP as ISP}{section.4}
-\BOOKMARK [3][-]{subsubsection.4.4.1}{Troubleshooting}{subsection.4.4}
-\BOOKMARK [2][-]{subsection.4.5}{RS232 as a Programmer}{section.4}
-\BOOKMARK [2][-]{subsection.4.6}{Programming using RS-232}{section.4}
-\BOOKMARK [3][-]{subsubsection.4.6.1}{Troubleshooting}{subsection.4.6}
-\BOOKMARK [2][-]{subsection.4.7}{Setting up the fuse bits}{section.4}
-\BOOKMARK [1][-]{section.5}{Using UART function}{}
diff --git a/Introduction/PLC.pdf b/Introduction/PLC.pdf
deleted file mode 100644
index 45f3b14..0000000
--- a/Introduction/PLC.pdf
+++ /dev/null
Binary files differ
diff --git a/Introduction/PLC.tex b/Introduction/PLC.tex
deleted file mode 100644
index a1c27de..0000000
--- a/Introduction/PLC.tex
+++ /dev/null
@@ -1,429 +0,0 @@
-\documentclass[12pt]{article}
-\usepackage{amsfonts}
-\usepackage{hyperref}
-\usepackage{setspace}
-\usepackage{graphicx}
-\usepackage{gensymb}
-\usepackage{moresize}
-\begin{document}
-
-\newpage
-{\Large \section{Introduction}}
-
-Automation in industries is the need of the hour. Everything is done electrically and not manually, right from a really unnoticed process like moving the conveyors to something as power intensive as running pumps. Industrial automation is primarily necessary for high end production and also product quality controls. Mainly, in industries, such automations are carried out by intelligent systems called Programmable Logic Controllers with the help of a host computer. A PLC, is in an actual sense, an electrical version of a microcontroller unit. It's more generic and also controls high power tools which generally work at really high voltages, unlike the microcontroller that merely works at considerably small voltage values. Basically, it intelligently controls whatever is programmed onto it by the host computer. This controller, being so versatile, is highly expensive, due to it's high rising demand and also it's operability credits. \singlespace
-\vspace{12pt}
-A PLC generally has a set of input and output ports to with the external peripherals are connected, which are to be electrically controlled by the PLC. Looking into the flow of working of the PLC, the processor tries to make decisions in accordance to the program, generally written by the user using some logic used to program these units. Some of these logics include \texttt{Function Block Diagram, Ladder Diagram, Structured Text, Sequential Function Chart} and \texttt{Instruction List}.\singlespace
-\vspace{12pt}
-The objective is to create an Open Source PLC, which has the capabilities of the industrial PLC, but the catch here is, it's much cheaper and simpler to work with. It incorporates a development board, that works on AVR's \texttt{ATmega16A} IC, giving upto 40 pins, most of which can be used and programmed as the Input-Output pins as it's done on a PLC. Moreover, the logic used here is \texttt{Ladder Logic} which is one of the easiest and also, robust in terms of its efficiency. Main point here is, this device is a standalone device, which can work without the host system being there, just being powered by a source. \texttt{HEX} files to be generated according to the controller are generated by a software called \texttt{LDMicro}, freely available for \texttt{Windows} and \texttt{Linux} users alike. The programming on the board is done via a \texttt{RS-232} cable by serial communication. All the processor wants now is a code to be dumped on it to start automating your small needs.\singlespace
-\vspace{12pt}
-This prototype will be helpful for students to get the feel of working with the PLCs, to control small automated systems. It'll also be easy as there's no coding involved and it's using a GUI that is user friendly and also efficient. Along with the development board, which can be used as microcontroller also, there are various hardware modules to start off with and later the students can cone up with their own hardware setups and test their modules, with the board. It's really versatile as it can suit your microcontroller needs and also work as a PLC. All you need is the HEX code for your desired usage with hardware.\vspace{12pt}
-
-
-The manual covers the basics of using the associated software and also explains the interfacing with the hardware. Certain simple experiments are given so as to get accustomed to the software usage. Later, some modules that can be made using the various sensors discussed in the preceding sections are covered. Then the imagination of the student and the need can drive the making of various other modules according to the students need.
-
-\newpage
-{\Large \section{Setting up the LD Micro executable}}
-Many softwares support PLC simulation in various logics.
-
-\vspace{12pt}
-
-The software that has been used in the subsequent sections is \texttt{LDMicro} that incorporates \texttt{Ladder Logic}, supporting many microcontrollers, along with the AVR's \texttt{ATmega16A}. This software helps produce the HEX files according to the microcontroller and the pin selected which can be directly dumped onto the core. \vspace{24pt}
-
- To download the software on your \texttt{Windows} system, go to \url{http://cq.cx/ladder.pl}. The download is a direct executable, there's no need to install it.
-
-
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.5]{screen.png}
-\caption{Downloading LD Micro}
-\end{figure}
-
-\newpage
-
-
-\newpage
-{\Large \section{Getting started with LDMicro}}
-{\large \subsection{Understanding the instructions}}
-A PLC is largely programmed using \texttt{Ladder Logic}, which is used in this software. It allows us to select the microcontroller that we wish to program via its HEX codes generated, \texttt{ATmega16A} in this case. The naming convention is very intuitive and is easy to get accustomed to. Some of the naming conventions followed are:
-\vspace{12pt}
-\begin{enumerate}
-\item \texttt{Yvar} implies the component is connected to an input pin on the microcontroller, something like a push button that is user dependent. This generally works for the digital inputs, \texttt{HIGH(+5V) or LOW(GND)}.
-\item \texttt{Xvar} implies the component is connected to an output pin on the microcontroller. This can be something like an LED or a Buzzer that is used to show the outputs. It's generally used to display digital outputs, \texttt{HIGH(+5V) or LOW(GND)}.
-\item \texttt{Tvar} implies, a timer. It can be a turn on, turn off or a retentive timer, just like the ones used in the actual PLCs.
-\item \texttt{Cvar} implies a counter. The arguments in this are simple logical operands to decide the upper bound upto which the counter shall work. There are circular counter too, which count circularly, without any bound.
-\item \texttt{Avar} implies the values read from the Analog pins of the controller. This can be used to take the intermediate readings say from components like Potentiometers, IR sensors etc.
-\end{enumerate}
-\vspace{12pt}
-Things to remember are :\vspace{12pt}
-\begin{itemize}
-\item Variable names can incorporate alphabets, numbers and underscores. It doesn't support the special characters.
-\item Do not start the name of the variable with a number.
-\item The variable names are case sensitive, the variable names \texttt{Relay1} and \texttt{relay1} signify two different variables.
-\item The instructions such as the arithmetic ones can manipulate the variables associated with the timers, counters or input, output pins.
-\item The variables are 16 bit signed decimals, so the variables can also be containing values that are negative pertaining to that range.
-\item As counters, timers in physical sense are internal in the microcontroller, we can only assign the pins to the \texttt{Xname, Yname and Aname} objects and not others.
-\end{itemize}
-Now that the basic ideas are clear, the use of certain instructions can be discussed.
-
-We shall understand normally open and normally closed connections. In normally open case, the contacts are open generally, which means, giving a high input closes the contact, hereby passing the signal over the rung. Whereas, a normally closed connection would imply a high signal to the connection would break the circuit hence giving low as the output.\vspace{12pt}
-\begin{enumerate}
-\item {\textbf{Contacts} are something like a prototype of a switch, which implies, if the signal going into the contact is true, only then it'll be reflected as output, if false, then output is false for normally open case. These can be used as internal relays too. }
-\item{ \textbf{Coils} are basically corresponding to the output devices. They can set the output true, if the signal going into them is true for the normally open case, else it's the other way. They can be used with internal relays too. There is an option of Set only (Reset-only) which are set(reset) when the input goes from \texttt{Low to High}, and retain their states. Hence they are used with Reset-Only(Set-Only) coils to change the states as and when wanted. }
-\item{ \textbf{Internal Relays} are the ones that are never assigned pin numbers. Basically, they are the ones that are used for counters or triggers, which are not given inputs or outputs, hence no pin on the controller.}
-\item{ \textbf{Turn on Delay} simply means delaying turning on of any coil. This mean the sensor, if gives a high at the input, it delays the turning on of the next part of the rung by those many units of time}
-\item{ \textbf{Turn off Delay} literally means turning off of any coil with some delay. This mean the sensor, if gives a false or a low at the input, it delays the turning off of the next part of the rung by those many units of time}
-
-\item{ \textbf{Retentive timer} is used to keep track of the how much time the module under consideration has been true, it cumulates the total time, if the input has been on for atleast that much time, the output of the timer is true. It will always reamin true after this, hence it should be reset by using \textbf{Reset} instruction manually}
-
-\item{ \textbf{Counter} is used to count upto the given value threshold.The count is changed as the input to the counter is made high. This is used as an up counter, down counter or a circular counter. The variables can be manipulated and be suited for the application}
-\item{ \textbf{Mov} is used to move any value, be it character or numeric into the variable named under destination.}
-\item{ \textbf{Arithmetic operands} are used to manipulate the variables values to suit the logic, they cn be used on any kind of variables like the counters variables.}
-
-These are the basic ones that are used. A detailed help for the more instructions and general guidelines is provided on the \texttt{Manual} of the software under the \texttt{Help} menu.
-\end{enumerate}
-\newpage
-{\large \subsubsection{Configuration of ATmega16A}}
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.7]{atmega16.png}
-\caption{ATmega16A Pin Configuration}
-\end{figure}
-\newpage
-{\large \subsection{Creating ladders using LD Micro}}
-LD Micro's simple user interface is really easy to use and is self explanatory.
-
-To get started working with LD Micro, just double click the LD Micro executable present in your system.\vspace{12pt}
-Once opened, you shall get such a GUI.\vspace{12pt}
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.4]{ld1.png}
-\caption{Startup screen of LD Micro}
-\end{figure}
-
-\vspace{12pt}Before starting to make the ladder, first make the necessary changes in the default settings, so as to generate the HEX code for your microcontroller.\vspace{12pt}
-\newpage
-Under \texttt{Settings} tab, select the \texttt{MCU Parameters} Option
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=1]{prop.png}
-\end{figure}
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.8]{Setup.png}
-\caption{Changing the controller parameters}
-\end{figure}
-\newpage
-Then after selecting, change the clock frequency to 16MHz and if using UART change the baud rate to 9600.
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.8]{cont.png}
-\caption{Selecting the appropriate microcontroller}
-\end{figure}
-\newpage
-Now that the configurations are set, the next step can be followed to design the ladder with the appropriate logic.
-
-It's really easy to build up the Ladder, just a few clicks and you're good to go.
-
-Start off with having a look at the \texttt{Instruction} tab. It has a lot of instructions that are in accordance with the Ladder logic followed for the PLCs and work in the same way and are similar to the ones described above under the 'Understanding the Instructions' section.
-
-After selecting the appropriate instruction, just double click the instruction to edit the name of the variable and other parameters related to the particular instruction.\vspace{12pt}
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.8]{change.png}
-\caption{Editing the parameters of an instruction}
-\end{figure}
-
-\vspace{12pt}
-\newpage
-After making the appropriate ladder for the application, the digital input and outputs should be given an appropriate pin number of the controller and the connections should be done accordingly. This can be done by double clicking the appropriate pin to be configured in the consolidated table just below the ladder made. \vspace{12pt}
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.8]{PIN.png}
-\caption{Assigning the appropriate pin number}
-\end{figure}
-\newpage
-Now that the logic is set, the ladder can be simulated to verify it's working. This is done by clicking the \texttt{Simulate} tab and \texttt{Simulation Mode} option under it. This is then followed by a similar screen where \texttt{Blue} indicates \texttt{LOW} and \texttt{Pink} indicates \texttt{HIGH}. To start the simulation, under \texttt{Simulate} tab click \texttt{Start Real-Time Simulation} option. After this, to change the state, just double click the instruction. The appropriate changes and values pertaining to different variables can be seen in the consolidated instruction table under the \texttt{State} column. To come out of simulation mode, click the same \texttt{Simulation Mode} option. \vspace{12pt}
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.8]{states.png}
-\caption{Tracking the pin states from the table}
-\end{figure}
-
-\vspace{12pt}After the ladder along with assigning the appropriate pin numbers, the HEX code can be generated. This can be done by first saving the ladder under the \texttt{File} tab with the \texttt{Save As} option. Save the file in the appropriate destination folder with a suitable name. Remember the final destination of the same for future. Now, to generate the HEX file, select the \texttt{Compile} tab and then the option \texttt{Compile As}. Then save this text file in the desired destination folder. The location shall be noted as it'd be needed to burn the code onto the controller using the command line arguments later.
-\newpage{\Large \section{Programming the IC}}
-{\large \subsection{Installing WINAVR}}
-
-The IC is a standalone one without the Bootloader. One of the ways of dumping the code, is using an In System Programmer or an ISP. So, for burning the same we use the softwares:
-AVRDUDE\footnote{AVRDUDE has once been started by Brian S. Dean as a private project of an in-system programmer for the Atmel AVR microcontroller series, as part of the Opensource and free software tools collection available for these controllers.} - AVR Downloader Uploader - is a program for downloading and uploading the on-chip memories of Atmel’s AVR microcontrollers. It can program the Flash and EEPROM, and where supported by the serial programming protocol, it can program fuse and lock bits. It's available as \texttt{WINAVR} for \texttt{Windows} and can be downloaded from here.
-%\hyperref[WINAVR ]{''http://softlayer-sng.dl.sourceforge.net/project/winavr/WinAVR/20100110/WinAVR-20100110-install.exe''}
-\linebreak
-\url{http://softlayer-sng.dl.sourceforge.net/project/winavr/WinAVR/20100110/WinAVR-20100110-install.exe}\vspace{12pt}
-
-
-Instead if you have \texttt{Linux} system, it's already pre-installed under the name \texttt{AVRDUDE}. Just enter the below command line on your \texttt{terminal} \vspace{12pt}
-
-\texttt{man avrdude}
-
-\vspace{12pt}
-
-You would see a screen full of text, something like the one below. To exit press \texttt{q}. If you don't get a screen like that, then open \texttt{Ubuntu Software Center} and on the search bar enter \texttt{avrdude}, then install it. Enter the same command into the terminal again and you shall see the manual.
-
-\vspace{12pt}
-
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.45]{manavrdude.png}
-\caption{AVRDUDE manual on Linux}
-\end{figure}
-
-
-\clearpage
-
-{\large \subsection{Setting up WINAVR on WINDOWS}}
-Step 1: First, open up the start screen and then search : \texttt{Command Prompt}
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.45]{Figcmd.png}
-\caption{Terminal in Search screen}
-\end{figure}
-\linebreak
-Step 2: Then, a screen like this shall pop up.
-
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.7]{Comm.png}
-\caption{Terminal in use}
-\end{figure}
-
-
-Step 3: Enter into the command prompt for windows: \texttt{avrdude}
-
-
-You should get prompts and flags mentioned like this, which implies that you have downloaded the software properly.
-\begin{figure}[h]
-\centering
-\includegraphics[scale=0.8]{avrdude1.png}
-\caption{Avrdude access via WINAVR and Terminal}
-\end{figure}
-
-\pagebreak
-\texttt{IMP: If you do not get this, please download the software and install it again.}\vspace{12pt}
-
-After this, we can proceed with dumping the HEX code onto the IC.
-\newpage
-\subsection{Identifying the Port of the programmer}
-
-There are several programmers available to program any controller IC. They are called as ISPs. USBASP is one of them. To identify the port at which its connected in \texttt{Linux}. \vspace{12pt}
-
-Type into the \texttt{Terminal:}
-\texttt{ls /dev}\vspace{12pt}
-
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.75]{device.png}
-\caption{Terminal in Search screen}
-\end{figure}
-
-This gives the list of connected devices on the system. After this, connect the ISP to the system and then again enter the same command on the terminal and then find out the new entries in the list. That shall be the port at which the ISP is connected. To use it in the command line with the -P flag just mention \texttt{/dev/ttyUSBx} where the argument trailing the \texttt{/dev/} one is the port at which the device is configured. This helps in recognising the device when programming on the terminal. For example use it in the command line with the appropriate flag like this.\vspace{12pt}
-
-\texttt{avrdude -p atmega16 -P /dev/ttyUSB0 -c ponyser -v -U flash:w:test1.hex}\vspace{12pt}
-
-Note: It can also be used with the correct defined By-id path in the serial programming ISP(RS232) by mentioning
-
-\begin{verbatim}
-
- /dev/serial/by-id/usb-FTDI_FT232R_USB_UART_XXXXX-port0
-
-\end{verbatim}
-which is same as the\texttt{ /dev/ttyUSBx} for identifying the same programmer. So both arguments are valid in case of RS232.
-\newpage\subsection{USBASP as ISP}
-Step 1: We require a precompiled hex file to be burnt onto our microcontroller. In our case, we have generated it by doing simple ladder programming in LDMicro and then compiling it. Before that, ensure that the proper target controller from the drop-down menu is chosen. For input and output part, assign a certain pin no. of the controller to that of the desired application. Now, a certain name is given to the file(say, blink.hex) at the destination folder.\vspace{12pt}
-
-Step 2: After being done with all the software part, one shall supply the power from 12V SMPS to the development board. Now check whether the controller is powered up properly with 5 Volt or not from the appropriate \texttt{Vcc} and \texttt{GND} pins of the controller.
-\vspace{12pt}
-
-
-Step 3: Now, just connect the FRC cable from USBASP to the 10 pin shrouded header on the board.
-\vspace{12pt}
-
-Step 4: Now, turn on \texttt{Terminal} and then change the directory to the one in which you have the saved HEX file to be dumped onto the processor.
-\vspace{12pt}
-
-Step 5: Now, in the terminal, enter the following command.
-
-\texttt{sudo avrdude -p atmega16 -P usb -c usbasp -B10 -U flash:w:Blink.hex}\vspace{12pt}
-
-You shall see such a process going on in the terminal like the one shown below, which means that the process of erasing and writing the internal memory of the ATmega IC is in the process. On correct execution you shall get such a result. Whilst it's burning the code, the red light on the USBASP will be lit showing that it is communicating with the controller appropriately.
-
-\vspace{12pt}
-
-Remember, after the fuses are set (covered in the following sections in detail), then the -B10 flag is necessary and can be deleted.
-
-\vspace{24pt}
-\begin{figure}[h!]
-\includegraphics[scale=0.9]{usb.png}
-\caption{Using USBASP as an ISP }
-\end{figure}
-\newpage
-\subsubsection{Troubleshooting}
-\hspace{12pt}\checkmark Check if the board is powered from the SMPS, if not, power it and try it once powered.
-
-\vspace{12pt}
-
-\checkmark Check if all the essential flags in the command line are incorporated, if not make the appropriate changes.
-
-\vspace{12pt}
-
-\checkmark Check if the FRC cable of the USBASP is not stranded in the midway, if so, replace it.
-
-\vspace{12pt}
-
-\checkmark If all these fail, check if the appropriate MOSI, MISO, SCK, RST and GND pins of the header are appropriately shorted with the ones of the IC and also that the controller firmly sits on the base.
-
-\vspace{12pt}
-\newpage
-\subsection{RS232 as a Programmer}
-To program the IC, we can also use DB9 connector via RS232 cable. The DB9 connector looks like the one below.\vspace{12pt}
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.1]{DB9M.png}
-\caption{DB9 connector}
-\end{figure}
-
-
-For programming the IC using DB9 connector via SPI protocol, we need yo build up some external circuitry first.
-
-The circuit connections are done as the one shown below. This involves connecting some electrical components, which are in the end connected to the same 10 pin shrouded headers that are used for the USBASP as a programmer. In the programmer board the connections made are like the one shown below.
-\vspace{12pt}
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=1]{Makedb9.png}
-\caption{DB9 connector}
-\end{figure}
-\vspace{12pt}
-
-Using DB-9 for the communication as per the RS-232 standard is chosen as the protocol is the oldest, easiest and doesn't require many hardware resources to be incorporated on the board for the IC to be programmed. As most of the present day systems like laptops may not have these ports, we can use a USB to RS-232 cable, which can be plugged into the USB port present on the system.
-
-
-\subsection{Programming using RS-232}
-\vspace{12pt}
-\hspace{17pt}Step 1: Connect the given RS-232 cable to the DB-9 port on the programmer board.
-
-\vspace{12pt}
-Step 2: You should open command line and then enter into the directory in which you have saved the HEX file compiled using LDMicro.
-
-\vspace{12pt}
-Step 3: Now that all the things are ready, finally enter the following command on \texttt{Terminal}.\singlespace
-\vspace{12pt}
-\texttt{avrdude -p atmega16 -P /dev/ttyUSB0 -c ponyser -v -U flash:w:test1.hex}\linebreak\singlespace
-\vspace{12pt}
-\begin{figure}[h!]
-\includegraphics[scale=0.4]{RS1.png}
-\end{figure}
-\vspace{12pt}
-\begin{figure}[h!]
-\includegraphics[scale=0.5]{RS2.png}
-\caption{Programming via RS-232}
-\end{figure}
-\vspace{12pt}
-
-This result is obtained if all the connections are fine. If only you obtain such a result, it means that the HEX code has been burnt onto the IC. If you obtain any other result, please look at the troubleshooting section.
-\newpage
-\subsubsection{Troubleshooting}
-\vspace{12pt}
-\hspace{12pt}\checkmark Check if the board is powered from the SMPS, if not, power it and try it once powered.
-
-\vspace{12pt}
-
-\checkmark Check if all the essential flags in the command line are incorporated, if not make the appropriate changes.
-
-\vspace{12pt}
-
-\checkmark Check if the RS-232 cable of the is connected securely to the DB9 connector.
-
-\vspace{12pt}
-\checkmark If all of this fails, then check if the reset pin of the microcontroller is at \texttt{+5 Volts} if not then externally connect it to \texttt{+5 Volts}.
-\vspace{12pt}
-\newpage
-\subsection{Setting up the fuse bits}
-Now that the programmer is installed on the system, we need to adjust the properties of the controller IC such that it meets the necessary requirements along with the peripherals installed on the board. Essentially, fuse bits are the ones that decide how the controller responds, like which clock frequency it responds to or its programming availabilities. Setting up the fuse is a crucial task as the controller may not respond later if the fuse bits that are set are not in accordance with the attached peripherals. Before setting the fuses, the factory settings on the controller make sure it works on the internal oscillator of clock speed 1MHz. It's mostly dependent on 2 fuses - lfuse and hfuse. Both of these have hex 8 bit values. When working on communication with the device, like UART, these fuse bits play a key role, if not defined, the controller works on the internal clock that's much slower than the external crystal. For the controller, 16MHz external crystal was selected. This meant the controller shall configure this external crystal and work on it.
-
-\texttt{WARNING: Fuse bits control the way the controller responds. If any mistake is made in setting up the fuse bits, then the controller becomes isolated from the external circuit. This means that the controller doesn't respond and renders useless. Hence, always triple check before entering the fuse bits. This is the best practice, or else you may end up wasting one IC.}
-
-\vspace{12pt} Type the following command into the \texttt{Terminal}:
-
-\vspace{12pt}
-
-For USBASP:
-\vspace{12pt}
-
-\texttt{sudo avrdude -p m16 -c usbasp -U lfuse:w:0xFF:m -U hfuse:w:0xD9:m -B10}\vspace{12pt}
-
-For RS232:\vspace{12pt}
-
-
-\texttt{avrdude -p m16 -c ponyser -P /dev/ttyUSB0 -U lfuse:w:0xFF:m -U hfuse:w:0xD9:m }\newpage
-
-\begin{figure}[h!]
-\centering
-\includegraphics[scale=0.5]{fuse1.png}
-\caption{Setting the fuse bits}
-\end{figure}
-\newpage
-\begin{figure}
-\centering
-\includegraphics[scale=0.5]{fuse2.png}
-\caption{Setting the fuse bits}
-\end{figure}
-
-Try to read the fuse bits after setting it. This will help you recognize if the IC has configured the external 16MHz crystal.\vspace{12pt}
-
-If using USBASP enter :
-
-\vspace{12pt}
-
-\texttt{avrdude -p m16 -C usb -P usbasp}
-
-\vspace{12pt}
-
-If using RS232 programmer enter :
-
-\vspace{12pt}
-
-\texttt{avrdude -p m16 -C /dev/ttyUSB0 -P ponyser}
-
-\vspace{12pt}
-
-You will get a screen like this :
-
-You can see that the fuse bits are read off. This implies that the external crystal is working in sync with the controller. You can verify that the fuse bits are the ones that you set earlier.
-
-\newpage If such a reading doesn't come up, follow these steps:
-
-\vspace{12pt}
-
-\checkmark Check that the command line is proper and you have written the correct command line with all the necessary flags like the controller mentioned is correct.
-
-\vspace{12pt}
-
-\checkmark Make sure that the power supply is connected and the programmer i.e. USBASP or RS232 is configured and the correct programmer is mentioned in the command line
-
-\vspace{12pt}
-
-\checkmark Make sure that the controller is firmly connected to the IC base. If not press it so that it sits firmly.
-
-\vspace{12pt}
-
-\checkmark If these do not work, then remove the controller IC from the base and then remove the crystal and solder a new 16MHz crystal. Make sure that you do not heat the crystal extensively. Due to this there's usually a mismatch in the clock speeds.
-
-\vspace{12pt}
-\cleardoublepage
-{\Large \section{Using UART function}}
-UART basically is the most basic protocol for serially transmitting and receiving the data from the sensor. UART stands for Universal Asynchronous Receiver Transmitter. The ladder logic allows us to program the UART facility easily in LD Micro. The values monitored in the ladder can be used to be displayed on the serial monitor. Say for example you have values that change with time and are varying, that is the value is analog, which means the values change over time and aren't discrete. Hence, monitoring the specific values become easy over the serial monitor. \vspace{12pt}
-
-Setting up the UART is so easy. Just connect the TX near the MAX232 IC to pin 14 of the IC and connect RX near the MAX232 IC to pin 15 of the IC. Now in the ladder use the UART send feature. The variable associated with UART send part will be the value that you would want to monitor. Mostly these values being analog will be connected to analog pins i.e. pins of Port A. So, the variables associated with the analog values have Avar kind of a structure, when using that for UART, append the 'A' in front of the variable name. So the variable linked in the UART send part will be 'Avar' and not 'var'.\vspace{12pt}
-
-For looking at the associated values, install a serial monitor on the system. This is helpful to the the Raw data associated. When monitored, the values seen are hex in nature, they start with the '0x' part, which implies the code is hexadecimal. This is helpful for suggesting thresholds and creating a level for a particular application. The hex values are assigned like 0x00 to 0x3FF which means the values range from 0 to 1023. This means the values 0V is mapped to 0x00 and value 5V (maximum from the controller) will be assigned 0x3FF value. This is how the mapping will be done.
-\newpage
-\end{document}
-
diff --git a/Introduction/RS1.png b/Introduction/RS1.png
deleted file mode 100644
index 7093b3c..0000000
--- a/Introduction/RS1.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/RS2.png b/Introduction/RS2.png
deleted file mode 100644
index 7c35410..0000000
--- a/Introduction/RS2.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/Setup.png b/Introduction/Setup.png
deleted file mode 100644
index 400f652..0000000
--- a/Introduction/Setup.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/atmega16.png b/Introduction/atmega16.png
deleted file mode 100644
index 45444e9..0000000
--- a/Introduction/atmega16.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/avrdude1.png b/Introduction/avrdude1.png
deleted file mode 100644
index f35669f..0000000
--- a/Introduction/avrdude1.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/change.png b/Introduction/change.png
deleted file mode 100644
index b0d2000..0000000
--- a/Introduction/change.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/cont.png b/Introduction/cont.png
deleted file mode 100644
index f03205a..0000000
--- a/Introduction/cont.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/device.png b/Introduction/device.png
deleted file mode 100644
index dcc70dc..0000000
--- a/Introduction/device.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/fuse1.png b/Introduction/fuse1.png
deleted file mode 100644
index 9995c99..0000000
--- a/Introduction/fuse1.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/fuse2.png b/Introduction/fuse2.png
deleted file mode 100644
index e1e1086..0000000
--- a/Introduction/fuse2.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/ld1.png b/Introduction/ld1.png
deleted file mode 100644
index 328f268..0000000
--- a/Introduction/ld1.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/manavrdude.png b/Introduction/manavrdude.png
deleted file mode 100644
index 1c2458c..0000000
--- a/Introduction/manavrdude.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/prop.png b/Introduction/prop.png
deleted file mode 100644
index 35626f8..0000000
--- a/Introduction/prop.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/screen.png b/Introduction/screen.png
deleted file mode 100644
index efc7268..0000000
--- a/Introduction/screen.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/setup.png b/Introduction/setup.png
deleted file mode 100644
index 661d7e7..0000000
--- a/Introduction/setup.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/states.png b/Introduction/states.png
deleted file mode 100644
index d858496..0000000
--- a/Introduction/states.png
+++ /dev/null
Binary files differ
diff --git a/Introduction/usb.png b/Introduction/usb.png
deleted file mode 100644
index c28f491..0000000
--- a/Introduction/usb.png
+++ /dev/null
Binary files differ
diff --git a/Programmming-the-controller.rst b/Programmming-the-controller.rst
deleted file mode 100644
index 4e2ed63..0000000
--- a/Programmming-the-controller.rst
+++ /dev/null
@@ -1,101 +0,0 @@
-Programming the Controller
-==========================
-
-There are several programmers available to program any controller IC. They are called as ISPs. USBASP is one of them. Before programming the IC, we need to set the fuses.
-
-Setting up fuse bits
---------------------
-
-Now that the programmer is installed on the system, we need to adjust the
-properties of the controller IC such that it meets the necessary requirements along with the peripherals installed on the board. Essentially, fuse bits are the ones that decide how the controller responds, like which clock frequency it responds to or its programming availabilities.
-
-Setting up the fuse is a crucial task as the controller may not respond later if the fuse bits that are set are not in accordance with the attached peripherals. Before setting the fuses, the factory settings on the controller make sure it works on the internal oscillator of clock speed 1MHz. It’s mostly dependent on 2 fuses - lfuse and hfuse. Both of these have hex 8 bit values. When working on communication with the device, like UART, these fuse bits play a key role, if not defined, the
-controller works on the internal clock that’s much slower than the externalcrystal. For the controller, 16MHz external crystal was selected. This meant the controller shall configure this external crystal and work on it.
-
-**WARNING:** Fuse bits control the way the controller responds. If
-any mistake is made in setting up the fuse bits, then the controller
-becomes isolated from the external circuit. This means that the
-controller doesn’t respond and renders useless. Hence, always triple
-check before entering the fuse bits. This is the best practice,
-or else you may end up wasting one IC.
-
-Type the following command into the Terminal:
-
-**sudo avrdude -p m16 -c usbasp -U lfuse:w:0xFF:m -U hfuse:w:0xD9:m -B10**
-
-Screen like below will pop up after giving the command line
-
-.. image:: /images/fuse1.png
- :height: 540px
- :width: 450px
- :scale: 100
-
-You can read fust bits after setting up, as shown below,
-
-.. image:: /images/fuse2.png
- :height: 540px
- :width: 450px
- :scale: 100
-
-Now the external crystal is working in sync with the controller.
-
-USBASP as ISP
--------------
-
-Step 1: We require a precompiled hex file to be burnt onto our microcontroller. In our case, we have generated it by doing simple ladder programming in LDMicro and then compiling it. Before that, ensure that the proper target controller from the drop-down menu is chosen. For input and output part, assign a certain pin no. of the controller to that of the desired application. Now, a certain name is given to the file(say, blink.hex) at the destination folder.
-
-Step 2: After being done with all the software part, one shall supply the power from 12V SMPS to the development board. Now check whether the
-controller is powered up properly with 5 Volt or not from the appropriate Vcc and GND pins of the controller.
-
-Step 3: Now, just connect the FRC cable from USBASP to the 10 pin
-shrouded header on the board.
-
-Step 4: Now, turn on Terminal and then change the directory to the one
-in which you have the saved HEX file to be dumped onto the processor.
-
-Step 5: Now, in the terminal, enter the following command.
-
-**sudo avrdude -p atmega16 -P usb -c usbasp -B10 -U flash:w:Blink.hex**
-
-You shall see such a process going on in the terminal like the one shown
-below, which means that the process of erasing and writing the internal
-memory of the ATmega IC is in the process. On correct execution you shall
-get such a result. Whilst it’s burning the code, the red light on the USBASP will be lit showing that it is communicating with the controller appropriately.
-
-Remember, after the fuses are set (covered in the following sections in
-detail), then the -B10 flag is necessary and can be deleted.
-
-.. image:: /images/usb.png
- :height: 540px
- :width: 450px
- :scale: 100
-
-Trouble shooting
-~~~~~~~~~~~~~~~~
-
-- Check if the board is powered from the SMPS, if not, power it and try
- it once powered.
-- Check if all the essential flags in the command line are incorporated,
- if not make the appropriate changes.
-- Check if the FRC cable of the USBASP is not stranded in the midway,
- if so, replace it.
-- If all these fail, check if the appropriate MOSI, MISO, SCK, RST and
- GND pins of the header are appropriately shorted with the ones of the
- IC and also that the controller firmly sits on the base.
-
-These are the main errors you may get while programming the PLC.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/README.txt b/README.md
index e2de398..e2de398 100644
--- a/README.txt
+++ b/README.md
diff --git a/Software-requirements.rst b/Software-requirements.rst
deleted file mode 100644
index e67c52c..0000000
--- a/Software-requirements.rst
+++ /dev/null
@@ -1,153 +0,0 @@
-Software requirements
-=====================
-
-Many software support PLC simulation in various logics.
-The software that has been used in the subsequent sections is
-LDMicro, that incorporates Ladder Logic, supporting
-many microcontrollers, along with the AVR's ATmega16A. This
-software helps produce the HEX files according to the microcontroller
-and the pin selected which can be directly dumped onto the
-core.
-
-For windows based system
-------------------------
-
-The IC is a standalone one without the Bootloader. One of the ways of
-dumping the code, is using an In System Programmer or an ISP. So, for burning the same we use the softwares: AVRDUDE1 - AVR Downloader Uploader is a program for downloading and uploading the on-chip memories of Atmels AVR microcontrollers. It can program the Flash and EEPROM, and where supported by the serial programming protocol, it can program fuse and lock bits. It’s available as WINAVR for Windows and can be downloaded from here [#] '<https://sourceforge.net/projects/winavr/files/WinAVR/20100110>'
-
-Setting up WINAVR
-~~~~~~~~~~~~~~~~~
-
-Step 1: First, open up the start screen and then search : Command Prompt
-
-.. image:: /images/Figcmd.png
- :height: 540px
- :width: 550px
- :scale: 150
-
-Step 2: Then, a screen like this shall pop up.
-
-.. image:: /images/Comm.png
- :height: 540px
- :width: 550px
- :scale: 150
-
-Step 3: Enter into the command prompt for windows: avrdude
-
-You should get prompts and flags mentioned like this, which implies that you have downloaded the software properly.
-
-.. image:: /images/avrdude1.png
- :height: 440px
- :width: 650px
- :scale: 100
-
-For Linux based system
-~~~~~~~~~~~~~~~~~~~~~~
-
-Instead if you have Linux system, it’s already pre-installed under the
-name AVRDUDE. Just enter the below command line on your terminal
-
-**man avrdude**
-
-You would see a screen full of text, something like the one below. To
-exit press q. If you don’t get a screen like that, then open Ubuntu Software Center and on the search bar enter avrdude, then install it. Enter the same command into the terminal again and you shall see the manual.
-
-.. image:: /images/manavrdude.png
- :height: 540px
- :width: 450px
- :scale: 100
-
-Setting up the Ld micro executable
-----------------------------------
-
-To download the software on your Windows system, go to [#] `<http://cq.cx/ladder.pl/>`_ The download is a direct executable, there’s no need to install it.
-
-.. image:: /images/Downloading-LD-Micro.png
- :height: 540px
- :width: 450px
- :scale: 100
-
-
-Getting started with Ld micro
------------------------------
-
-A PLC is largely programmed using Ladder Logic, which is used in
-this software. It allows us to select the microcontroller that
-we wish to program via its HEX codes generated, ATmega16A in this case. The naming convention is very intuitive and is easy to get accustomed to. Some of the naming conventions followed are:
-
-[1] *Yvar* implies the component is connected to an input pin on the micro-controller, something like a push button that is user dependent. This generally works for the digital inputs, HIGH(+5V) or LOW(GND).
-
-[2] *Xvar* implies the component is connected to an output pin on the mi-crocontroller. This can be something like an LED or a Buzzer that is used to show the outputs. It’s generally used to display digital outputs, HIGH(+5V) or LOW(GND).
-
-[3] *Tvar* implies, a timer. It can be a turn on, turn off or a retentive timer, just like the ones used in the actual PLCs.
-
-[4] *Cvar* implies a counter. The arguments in this are simple logical
-operands to decide the upper bound upto which the counter shall work.
-There are circular counter too, which count circularly, without any
-bound.
-
-[5] *Avar* implies the values read from the Analog pins of the controller.This can be used to take the intermediate readings say from components like Potentiometers, IR sensors etc.
-
-Things to remember are:
-
-- Variable names can incorporate alphabets, numbers and underscores.
- It doesn’t support the special characters.
-- Do not start the name of the variable with a number.
-- The variable names are case sensitive, the variable names Relay1 and
- relay1 signify two different variables.
-- The instructions such as the arithmetic ones can manipulate the vari-
- ables associated with the timers, counters or input, output pins.
-- The variables are 16 bit signed decimals, so the variables can also
- be containing values that are negative pertaining to that range.
-- As counters, timers in physical sense are internal in the microcontroller,we can only assign the pins to the Xname, Yname and Aname objects and not others.
-
-Now that the basic ideas are clear, the use of certain instructions can be discussed.
-
-We shall understand normally open and normally closed connections. In
-normally open case, the contacts are open generally, which means, giving a high input closes the contact, hereby passing the signal over the rung.Whereas, a normally closed connection would imply a high signal to the connection would break the circuit hence giving low as the output.
-
-[1] **Contacts** are something like a prototype of a switch, which implies, if the signal going into the contact is true, only then it’ll be reflected as output, if false, then output is false for normally open case. These can be used as internal relays too.
-
-[2] **Coils** are basically corresponding to the output devices. They can set the output true, if the signal going into them is true for the normally open case, else it’s the other way. They can be used with internal relays too. There is an option of Set only (Reset-only) which are set(reset) when the input goes from Low to High, and retain their states. Hence they are used with Reset-Only(Set-Only) coils to change the states as and when wanted.
-
-[3] **Internal Relays** are the ones that are never assigned pin numbers.Basically, they are the ones that are used for counters or triggers, which are not given inputs or outputs, hence no pin on the controller.
-
-[4] **Turn on Delay** simply means delaying turning on of any coil. This mean the sensor, if gives a high at the input, it delays the turning on of the next part of the rung by those many units of time
-
-[5] **Turn off Delay** literally means turning off of any coil with some delay.This mean the sensor, if gives a false or a low at the input, it delays the turning off of the next part of the rung by those many units of time
-
-[6] **Retentive timer** is used to keep track of the how much time the
-module under consideration has been true, it cumulates the total time,
-if the input has been on for atleast that much time, the output of the
-timer is true. It will always reamin true after this, hence it should be reset by using Reset instruction manually
-
-[7] **Counter** is used to count upto the given value threshold.The count is changed as the input to the counter is made high. This is used as an up counter, down counter or a circular counter. The variables can be manipulated and be suited for the application
-
-[8] **Mov** is used to move any value, be it character or numeric into the variable named under destination.
-
-[9] **Arithmetic operands** are used to manipulate the variables values to suit the logic, they cn be used on any kind of variables like the counters variables.
-
-These are the basic ones that are used. A detailed help for the more
-instructions and general guidelines is provided on the Manual of the
-software under the Help menu.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/images/Comm.png b/images/Comm.png
deleted file mode 100644
index 78567a8..0000000
--- a/images/Comm.png
+++ /dev/null
Binary files differ
diff --git a/images/Downloading LD Micro.png b/images/Downloading LD Micro.png
deleted file mode 100644
index 6f5037d..0000000
--- a/images/Downloading LD Micro.png
+++ /dev/null
Binary files differ
diff --git a/images/Downloading-LD-Micro.png b/images/Downloading-LD-Micro.png
deleted file mode 100644
index 6f5037d..0000000
--- a/images/Downloading-LD-Micro.png
+++ /dev/null
Binary files differ
diff --git a/images/Figcmd.png b/images/Figcmd.png
deleted file mode 100644
index 6c8197b..0000000
--- a/images/Figcmd.png
+++ /dev/null
Binary files differ
diff --git a/images/PIN.png b/images/PIN.png
deleted file mode 100644
index aba755c..0000000
--- a/images/PIN.png
+++ /dev/null
Binary files differ
diff --git a/images/Setup.png b/images/Setup.png
deleted file mode 100644
index 400f652..0000000
--- a/images/Setup.png
+++ /dev/null
Binary files differ
diff --git a/images/avrdude1.png b/images/avrdude1.png
deleted file mode 100644
index f35669f..0000000
--- a/images/avrdude1.png
+++ /dev/null
Binary files differ
diff --git a/images/change.png b/images/change.png
deleted file mode 100644
index b0d2000..0000000
--- a/images/change.png
+++ /dev/null
Binary files differ
diff --git a/images/cont.png b/images/cont.png
deleted file mode 100644
index f03205a..0000000
--- a/images/cont.png
+++ /dev/null
Binary files differ
diff --git a/images/fuse1.png b/images/fuse1.png
deleted file mode 100644
index 9995c99..0000000
--- a/images/fuse1.png
+++ /dev/null
Binary files differ
diff --git a/images/fuse2.png b/images/fuse2.png
deleted file mode 100644
index e1e1086..0000000
--- a/images/fuse2.png
+++ /dev/null
Binary files differ
diff --git a/images/ld1.png b/images/ld1.png
deleted file mode 100644
index 328f268..0000000
--- a/images/ld1.png
+++ /dev/null
Binary files differ
diff --git a/images/manavrdude.png b/images/manavrdude.png
deleted file mode 100644
index 1c2458c..0000000
--- a/images/manavrdude.png
+++ /dev/null
Binary files differ
diff --git a/images/prop.png b/images/prop.png
deleted file mode 100644
index 35626f8..0000000
--- a/images/prop.png
+++ /dev/null
Binary files differ
diff --git a/images/states.png b/images/states.png
deleted file mode 100644
index d858496..0000000
--- a/images/states.png
+++ /dev/null
Binary files differ
diff --git a/images/usb.png b/images/usb.png
deleted file mode 100644
index c28f491..0000000
--- a/images/usb.png
+++ /dev/null
Binary files differ