#### Overview of this book

Dancing with Python helps you learn Python and quantum computing in a practical way. It will help you explore how to work with numbers, strings, collections, iterators, and files. The book goes beyond functions and classes and teaches you to use Python and Qiskit to create gates and circuits for classical and quantum computing. Learn how quantum extends traditional techniques using the Grover Search Algorithm and the code that implements it. Dive into some advanced and widely used applications of Python and revisit strings with more sophisticated tools, such as regular expressions and basic natural language processing (NLP). The final chapters introduce you to data analysis, visualizations, and supervised and unsupervised machine learning. By the end of the book, you will be proficient in programming the latest and most powerful quantum computers, the Pythonic way.
Table of Contents (29 chapters)
Free Chapter
Chapter 1: Doing the Things That Coders Do
Part I: Getting to Know Python
Chapter 2: Working with Expressions
Chapter 3: Collecting Things Together
Chapter 4: Stringing You Along
Chapter 5: Computing and Calculating
Chapter 6: Defining and Using Functions
Chapter 7: Organizing Objects into Classes
Chapter 8: Working with Files
PART II: Algorithms and Circuits
Chapter 9: Understanding Gates and Circuits
Chapter 10: Optimizing and Testing Your Code
Chapter 11: Searching for the Quantum Improvement
PART III: Advanced Features and Libraries
Chapter 12: Searching and Changing Text
Chapter 13: Creating Plots and Charts
Chapter 14: Analyzing Data
Chapter 15: Learning, Briefly
References
Other Books You May Enjoy
Index
Appendices
Appendix B: Staying Current
Appendix C: The Complete UniPoly Class
Appendix D: The Complete Guitar Class Hierarchy
Appendix E: Notices
Appendix F: Production Notes

# 9.4 Simplifying bit expressions

When we compose gates, we can often rearrange and simplify the combinations. If `x` and `y` are bits, then

• not not `x` = `x`
• `x` and 1 = 1
• `x` and `x` = `x`
• 0(`x`) = `x` and (not `x`) = 0
• `x` and `y` = `y` and `x`
• `x` or 0 = `x`
• `x` or `x` = `x`
• 1(`x`) = `x` or (not `x`) = 1
• `x` or `y` = `y` or `x`
• not (`x` and `y`) = (not `x`) or (not `y`)
• not (`x` or `y`) = (not `x`) and (not `y`)

The last two are known as De Morgan’s Laws after British mathematician Augustus De Morgan. With a third bit `z` we also have:

• `x` and (`y` and `z`) = (`x` and `y`) and `z`
• `x` or (`y` or `z`) = (`x` or `y`) or `z`
• `x` and (`y` or `z`) = (`x` and `y`) or (`x` and `z`)
• `x` or (`y` and `z`) = (`x` or `y`) and (`x` or `z`)

Exercise 9.19

Which of these relationships hold for xor, nand, nor, xnor, and their...