To order this title, and for more information, click here
By Ian Grout, University of Limerick, Ireland
Description This textbook explains how to design and develop digital electronic systems using programmable logic devices (PLDs). Totally practical
in nature, the book features numerous (quantify when known) case study designs using a variety of Field Programmable Gate Array (FPGA)
and Complex Programmable Logic Devices (CPLD), for a range of applications from control and instrumentation to semiconductor automatic
test equipment.
Key features include:
* Case studies that provide a walk through of the design process, highlighting the trade-offs
involved.
* Discussion of real world issues such as choice of device, pin-out, power supply, power supply decoupling, signal integrity-
for embedding FPGAs within a PCB based design.
With this book engineers will be able to:
* Use PLD technology to develop digital and
mixed signal electronic systems
* Develop PLD based designs using both schematic capture and VHDL synthesis techniques
* Interface a
PLD to digital and mixed-signal systems
* Undertake complete design exercises from design concept through to the build and test of PLD
based electronic hardware
This book will be ideal for electronic and computer engineering students taking a practical or Lab based course
on digital systems development using PLDs and for engineers in industry looking for concrete advice on developing a digital system using
a FPGA or CPLD as its core.
Audience
Electrical and electronic engineering and computer engineering undergraduates and masters students taking a course or lab course in digital
systems/digital architecures. Professional electronic engineers using PLDs to build digital systems
Contents Chapter 1 Introduction to Programmable Logic
1.1 Introduction to the Book
1.2 Electronic Circuits: Analogue and Digital
1.2.1 Introduction
1.2.2 Continuous-Time Vs Discrete-Time
1.2.3 Analogue Vs Digital
1.3 History of Digital Logic
1.4 Programmable Logic vs Discrete
Logic
1.5 Programmable Logic vs Processors
1.6 Types of Programmable Logic
1.6.1 Simple Programmable Logic Device (SPLD)
1.6.2
Complex Programmable Logic Device (CPLD)
1.6.3 Field Programmable Gate Array (FPGA)
1.7 PLD Configuration Technologies
1.8 Programmable
Logic Vendors
1.9 Programmable Logic Design Methods and Tools
1.9.1 Introduction
1.9.2 Typical PLD Design Flow
1.10 Technology
Trends
1.11 References
1.12 Student Exercises
Chapter 2 Electronic Systems Design
2.1 Introduction
2.2 Sequential Product Development
Vs Concurrent Engineering Process
2.2.1 Introduction
2.2.2 Sequential Product Development Process
2.2.3 Concurrent Engineering
Process
2.3 Flow Charts
2.4 Block Diagrams
2.5 Gajski-Kuhn Chart
2.6 Hardware-Software Co-Design
2.7 Formal Verification
2.8 Embedded
Systems and Real Time Operating Systems
2.9 Electronic Systems Level Design
2.10 Writing a Design Specification
2.11 UML – Unified
Modeling Language
2.12 Reading a Component Datasheet
2.13 Digital Input-Output
2.13.1 Introduction
2.13.2 Logic Level Definitions
2.13.3 Noise Margin
2.13.4 Interfacing Logic Families
2.14 Parallel and Serial Interfacing
2.14.1 Introduction
2.14.2 Parallel
I/O
2.14.3 Serial I/O
2.15 System Reset
2.16 System Clock
2.17 Power Supplies
2.18 Power Management
2.19 Printed Circuit Boards
and Multi-Chip Modules
2.20 System on a Chip and System in a Package
2.21 Mechatronic Systems
2.22 Intellectual Property
2.23 CE
and FCC Marking
2.25 References
2.26 Student Exercises
Chapter 3 PCB Design
3.1 Introduction
3.2 What is a PCB?
3.2.1 Definition
3.2.2 Structure of the PCB
3.2.3 Typical Components
3.3 Design, Manufacture and Test
3.3.1 PCB Design
3.3.2 PCB Manufacture
3.3.3 PCB Test
3.4 Environmental Issues
3.4.1 Introduction
3.4.2 WEEE Directive
3.4.3 RoHS Directive
3.4.4 Lead-Free Solder
3.4.5 Electromagnetic Compatibility
3.5 Case Study PCB Designs
3.5.1 Introduction
3.5.2 System Overview
3.5.3 CPLD Development
Board
3.5.4 LCD Display and Hex Keypad Board
3.5.5 PC Interface Board
3.5.6 Digital I/O Board
3.5.7 Analogue I/O Board
3.6 Technology
Trends
3.7 References
3.8 Student Exercises
Chapter 4 Design Languages
4.1 Introduction
4.2 Software Programming Languages
4.2.1 Introduction
4.2.2 C
4.2.3 C++
4.2.4 JAVATM
4.2.5 Visual BasicTM
4.2.6 Scripting Languages
4.2.7 PHP
4.3 Hardware
Description Languages
4.3.1 Introduction
4.3.2 VHDL
4.3.3 Verilog -HDL
4.3.4 Verilog -A
4.3.5 VHDL-AMS
4.3.6 Verilog -AMS
4.4 SPICE
4.5 Mathematical Modelling Tools
4.6 References
Chapter 5 Introduction to Digital Logic Design (Design Principles)
5.1
Introduction
5.2 Number Systems
5.2.1 Introduction
5.2.2 Decimal-Unsigned Binary Conversion
5.2.3 Signed Binary Numbers
5.2.4
Gray Code
5.2.5 Binary Coded Decimal
5.2.6 Octal-Binary Conversion
5.2.7 Hexadecimal-Binary Conversion
5.3 Binary Data Manipulation
5.3.1 Introduction
5.3.2 Logical Operations
5.3.3 Boolean Algebra
5.3.4 Combinational Logic Gates
5.3.5 Truth-Tables
5.4 Combinational
Logic Design
5.4.1 Introduction
5.4.2 NAND and NOR Logic
5.4.3 Karnaugh Maps
5.4.4 ?Don't Care? Conditions
5.5 Sequential Logic
Design
5.5.1 Introduction
5.5.2 Latches and Bistables
5.5.3 The D-Latch and D-Type Bistable
5.5.4 Counter Design
5.5.5 State
Machine Design
5.5.6 Moore Vs Mealy State Machine
5.5.7 Shift Registers
5.5.8 Digital Scan Path
5.6 Memory
5.6.1 Introduction
5.6.2 Random Access Memory
5.6.3 Read Only Memory
5.7 References
5.8 Student Exercises
Chapter 6 Introduction to Digital Logic
Design with VHDL
6.1 Introduction
6.2 Designing with HDLs
6.3 Design Entry Methods
6.3.1 Introduction
6.3.2 Schematic Capture
6.3.3 HDL Design Entry
6.4 Logic Synthesis
6.5 Entities, Architectures, Packages and Configurations
6.5.1 Introduction
6.5.2
AND Gate Example
6.5.3 Commenting the Code
6.6 A First Design
6.6.1 Introduction
6.6.2 Dataflow Description Example
6.6.3 Behavioural
Description Example
6.6.4 Structural Description Example
6.7 Signals Vs Variables
6.7.1 Introduction
6.7.2 Example – Architecture
with Internal Signals
6.7.3 Example – Architecture with Internal Variables
6.8 Generics
6.9 Reserved Words
6.10 Data Types
6.11
Concurrent Vs Sequential Statements
6.12 Loops and Program Control
6.13 Coding Styles for VHDL
6.14 Combinational Logic Design
6.14.1
Introduction
6.14.2 Complex Logic Gates
6.14.3 1-Bit Half Adder
6.14.4 4-to-1 Multiplexer
6.14.5 Thermometer Code to Binary Encoder
6.14.6 Seven Segment Display Driver
6.14.7 Tristate Buffer
6.15 Sequential Logic Design
6.15.1 Introduction
6.15.2 Latches and
Bistables
6.15.3 Counter Design
6.15.4 State Machine Design
6.16 Memories
6.16.1 Introduction
6.16.2 Random Access Memory
6.16.3 Read Only Memory
6.17 Unsigned Vs Signed Arithmetic
6.17.1 Introduction
6.17.2 Example 1: Adder
6.176.3 Example 2: Multiplier
6.18 Testing the Design: The VHDL Test Bench
6.19 References
6.20 Student Exercises
Chapter 7 Introduction to Digital Signal Processing
7.1 Introduction
7.2 Z-Transform
7.3 Digital Control
7.3.1 Introduction
7.3.2 Digital Controller Example
7.4 Digital Filtering
7.4.1 Introduction
7.4.2 Infinite Impulse Response Filters
7.4.3 Finite Impulse Response Filters
7.5 References
7.6 Student Exercises
Chapter 8 Interfacing Digital Logic to the ?Real World?: A/D Conversion, D/A Conversion and Power Electronics
8.1 Introduction
8.2
Digital to Analogue Conversion
8.2.1 Introduction
8.2.2 DAC Characteristics
8.2.3 Types of DAC
8.2.4 DAC Control Example
8.3
Analogue to Digital Conversion
8.3.1 Introduction
8.3.2 ADC Characteristics
8.3.3 Types of ADC
8.3.4 Aliasing
8.4 Power Electronics
8.4.1 Introduction
8.4.2 Diodes
8.4.3 Power Transistor
8.4.4 Thyristor
8.4.5 Gate Turn Off Thyristor
8.4.6 Asymmetric Thyristor
8.4.7 Triac
8.5 Heat Dissipation and Heatsinks
8.6 Operational Amplifiers
8.7 References
8.8 Student Exercises
Chapter 9 Testing
the Electronic System
9.1 Introduction
9.2 Integrated Circuit Testing
9.2.1 Introduction
9.2.2 Digital IC Test
9.2.3 Analogue
IC Test
9.2.4 Mixed-Signal IC Test
9.3 Printed Circuit Board Testing
9.4 Boundary Scan Test
9.5 Software Test
9.6 References
9.7
Student Exercises
Chapter 10 Systems Level Design
10.1 Introduction
10.2 Electronic System Level Design
10.3 Case Study 1: D.C. Motor
Control
10.3.1 Introduction
10.3.2 Motor Control System Overview
10.3.3 MATLAB /SIMULINK Model Creation and Simulation
10.3.4
Translating the Design to VHDL
10.3.5 Concluding Remarks
10.4 Case Study 2: Digital Filter Design
10.4.1 Introduction
10.4.2 Digital
Filter Overview
10.4.3 MATLAB /SIMULINK Model Creation and Simulation
10.4.4 Translating the Design to VHDL
10.4.5 Concluding
Remarks
10.5 Automating the Design Process
10.6 Future Directions
10.7 References
10.8 Student Exercises
Appendix A Organisations
and Standards
Appendix B Programmable Logic Device Vendors
Appendix C Integrated Circuit Package Types
Appendix D Modelling and
Simulation Language Summary
Appendix E Introduction to the Design Tools
E.1 Introduction
E.2 4-Bit Adder Design Case Study
E.3
Design Entry
E.3.1 Starting the Tools
E.3.2 Creating a New Project
E.3.3 Opening an Existing Project
E.3.4 Creating a New Schematic
E.3.5 Editing the Schematic
E.3.6 Connecting the Symbols
E.3.7 Adding Net Names
E.3.8 Adding Input and Output Markers
E.3.9
Adding Input and Output Cells
E.4 Simulating the Design
E.4.1 Introduction
E.4.2 Creating a VHDL Test Bench
E.4.3 Running the
Simulation
E.4.4 Viewing the Results
E.4.5 Closing ISETM
E.5 Configuring the CPLD
E.5.1 Introduction
E.5.2 Package Pin Assignment
E.5.3 Implementing the Design
E.6 Introductory Guide Exercise
Appendix F Case Study PCB Designs
F.1 Introduction
F.2 System
Overview
F.3 CPLD Pin Assignments
F.4 Connector Pin Assignments
F.5 CPLD Development Board
F.6 LCD Display and Hex Keypad Board
F.7 PC Interface Board
F.8 Digital I/O Board
F.9 Analogue I/O Board
Appendix G Chapter 6 VHDL Code Examples
G.1 Introduction
G.2 VHDL Code Examples
Appendix H Chapter 7 VHDL Code Examples
H.1 Introduction
H.2 VHDL Code Examples
Appendix I Chapter 8 VHDL
Code Examples
I.1 Introduction
I.2 VHDL Code Examples
Appendix J Chapter 10 Code Examples
J.1 Introduction
J.2 Digital PI Controller
J.3 CIC Filter
Bibliography
Index
Books and book related electronic products are priced in US dollars (USD), euro (EUR), and Great Britain Pounds (GBP). USD prices apply to the Americas and Asia Pacific. EUR prices apply in Europe and the Middle East. GBP prices apply to the UK and all other countries.