Bitcoin and Blockchain Technology, October-December 2020

Department of Statistics and Quantitative Methods, University of Milano-Bicocca

Because of COVID-19 the course will be streaming only.


If you have an e-mail please join the 202010-bicocca channel in the Slack BBT workspace using your first and last name (no nicknames) and a profile picture. Updates and conversations about the course will be posted in the Slack channel.

The course is for the students of University of Milano-Bicocca only; anyone else, please consider

Learning objectives

The course is an introduction to bitcoin and the associated blockchain technology.

Starting from a computationally focused approach to elliptic curves over finite fields and presenting the discrete logarithm problem as the cornerstone of public-key cryptography, bitcoin is introduced as ingenious breakthrough innovation.

Its game theory, computer science (distributed systems, distributed consensus), and monetary theory elements are examined in the attempt to properly convey the interdisciplinarity of the topic and appreciate its relevance.

Technical and programming elements about digital signatures, blockchain, Merkle tree, addresses, transactions, and timestamping are also provided to assess features and limits of the Bitcoin protocol.


There are no strict prerequisites, even if a computer science mindset and some familiarity with algebra and finance might help to appreciate the course. While a rigorous formal approach is almost impossible in a course touching on so many and so different knowledge areas, intellectual curiosity is stimulated about the interplay between maths, cryptography, economic incentives, technology, monetary theory, regulatory issues, and politics.


  • Cash, Electronic Money, Central Bank Money, eCash
  • Internet Money
  • Bitcoin Transactions
  • About Money
  • Private Money and the Centralization Dilemma
  • The Double Spending Problem
  • Bitcoin as Digital Gold
  • Bitcoin as Investment Asset
  • Bitcoin Financial Services
  • Discrete Logarithm Problem on Finite Cyclic Groups
  • Modular Arithmetic
  • Finite Fields
  • Elliptic Curves Over Real Numbers
  • DLP on Elliptic Curves Over Finite Fields
  • Hash Functions
  • Partial Hash Inversion
  • Hash Pointer Data Structures: Blockchain and Merkle Tree
  • Design of A Simplified Digital Currency
  • Distributed Consensus
  • Mining
  • P2P Network
  • Protocol Governance
  • Elliptic curve digital signature algorithm
  • Elliptic curve Schnorr signature algorithm: Mu(lti)Sig(nature), threshold signature, batch verification
  • Addresses and WIFs
  • Hierarchical deterministic wallets: BIP32, BIP43, BIP44
  • Mnemonic phrase: BIP39 and Electrum
  • TxIns, TxOs, UTxO, nLockTime
  • Bitcoin script language
  • Transactions
  • Blocks
  • Wallets and Bitcoin Core
  • Testnet, regtest, and wallet workshop
  • Money and innovation: monetary and token engineering
  • Hayek money and dual asset ledger money
  • Blockchain beyond bitcoin
  • Finance and blockchain
  • Timestamping, notarization, and anchoring
  • Smart contracts
  • Distributed ledger technology

Teaching method

  • Slide based lessons with associated bibliography
  • Python 3 programming assignments and technology assignments
  • Workshop labs on Bitcoin Core, Electrum, and OpenTimestamps

Teaching language

Italian or English, the latter if foreign students are present.


Students attending the lessons are asked to solve course assignments for each lesson. Assignments have a deadline and are not required/allowed for students that did not actively partecipate to the semester activity.

Assignments can be tackled cooperatively by team of students, up to three students. Successful assignments will contribute up to five points to the final grade.

Please send the assignments to the e-mail that will be indicated with subject BBT202010-BICOCCA #1 for the first assignment, BBT202010-BICOCCA #2 for the second assignment, etc.

The final exam will be individual: a grade of at least 18/30 is required to pass the exam.


Assistant lecturer: Paolo Mazzocchi.

  1. 2020-10-07 Wednesday 16:30-18:30
    Bitcoin as Digital Gold (Part 1)
  2. 2020-10-14 Wednesday 16:30-18:30
    Bitcoin as Digital Gold (Part 2)
    Assignment #1: read the “Bitcoin: oro digitale, finanza e tulipani” interview; then send up to three questions that, in your opinion, might deserve further clarifications; deadline: 2020-10-20
  3. 2020-10-21 Wednesday 16:30-18:30
    Discrete Logarithm Problem on Finite Fields and Elliptic Curves
    Assignments are included in the slides; deadline: 2020-11-10
  4. 2020-10-28 Wednesday 16:30-18:30
    Hash Functions
    Assignments are included in the slides; deadline: 2020-11-10
    Blockchain, Mining, and Distributed Consensus (Part 1)
  5. 2020-11-04 Wednesday 16:30-18:30
    Blockchain, Mining, and Distributed Consensus (Part 2)
  6. 2020-11-11 Wednesday 16:30-18:30
    Elliptic Curve Digital Signature Algorithm
  7. 2020-11-18 Wednesday 16:30-18:30
    Addresses, WIFs, and Bitcoin Message Signing
    Transactions and Scripts
  8. 2020-12-02 Wednesday 16:30-18:30
    Beyond Bitcoin: Between Hype and Reality
  9. 2020-12-09 Wednesday 16:30-18:30
    Wallets and Deterministic Key Chains
  10. 2020-12-16 Wednesday 16:30-18:30
    The Cryptocurrency Frontier in Monetary Engineering
    slides and video
    Bitcoin: oro digitale per nuovi standard monetari
    Hayek Money: The Cryptocurrency Price Stability Solution
  11. 2020-12-23 Wednesday 16:30-18:30
    Final Q&A
    Extra Material: Diffie Hellman and Symmetric Cryptography
    Extra Material: Schnorr Signature

Python library

Python scripts, Excel spreadsheets, and regtest lab material

Introductory reading

Technology references

Cryptography references

Monetary theory references