<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>http://mw.hh.se/wg211/index.php?action=history&amp;feed=atom&amp;title=WG211%2FM24Hammond</id>
	<title>WG211/M24Hammond - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://mw.hh.se/wg211/index.php?action=history&amp;feed=atom&amp;title=WG211%2FM24Hammond"/>
	<link rel="alternate" type="text/html" href="http://mw.hh.se/wg211/index.php?title=WG211/M24Hammond&amp;action=history"/>
	<updated>2026-04-05T20:58:42Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.5</generator>
	<entry>
		<id>http://mw.hh.se/wg211/index.php?title=WG211/M24Hammond&amp;diff=2642&amp;oldid=prev</id>
		<title>Jacques: Created page with &quot;IOG has been deploying a variety of (lightweight) formal methods as part of its commitment to high assurance software engineering for the multi-billion dollar Cardano blockcha...&quot;</title>
		<link rel="alternate" type="text/html" href="http://mw.hh.se/wg211/index.php?title=WG211/M24Hammond&amp;diff=2642&amp;oldid=prev"/>
		<updated>2024-10-18T13:59:16Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;IOG has been deploying a variety of (lightweight) formal methods as part of its commitment to high assurance software engineering for the multi-billion dollar Cardano blockcha...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;IOG has been deploying a variety of (lightweight) formal methods as part of its commitment to high assurance software engineering for the multi-billion dollar Cardano blockchain.  Techniques that are used include development in Haskell, use of type families to restrict functionality to specific successive ledger “eras&amp;quot;, formal specification in Agda for the ledger and consensus layers, automated conformance testing of the implementation against the specification, property based testing (including new constraint-based checking in QuickCheck to allow the construction of realistic test cases),  rigorous timing analysis using the DeltaQ systems design methodology, use and the development of a type-based mechanism to allow automated upgrades synchronised across the whole system (the “Hard Fork Combinator”), model checking for “stable coins”, and the development of a simulation package for networking code.&lt;br /&gt;
This talk will describe the use of these methods at scale as part of the development of a large, complex, distributed system, the Cardano blockchain implementation.  I will show the formal specification for the ledger code, show how it can be used to generate conformance tests using QuickCheck, and demonstrate consistency of the Haskell implementation.&lt;/div&gt;</summary>
		<author><name>Jacques</name></author>
	</entry>
</feed>