Using formal methods to plan software with flare - Deepstash
Using formal methods to plan software with flare

Using formal methods to plan software with flare

Curated from: increment.com

Ideas, facts & insights covering these topics:

8 ideas

·

45 reads

1

Explore the World's Best Ideas

Join today and uncover 100+ curated journeys from 50+ topics. Unlock access to our mobile app with extensive features.

"Formal specifications are beacons that illuminate the terrain"

"Formal specifications are beacons that illuminate the terrain"

This is a fantastic metaphor for what's otherwise a superpower. Imagine being able to have the computer do the hard work of being able to find design bugs for you!

This is better than any abstract diagram or design document meant solely for human consumption. A computer can't automatically verify a Vizio diagram, check a design document for logical inconsistencies, or call out places where future work might conflict with current constraints.

4

8 reads

What Does A Good Plan Do?

What Does A Good Plan Do?

"Good plans not only light the path forward, but show you where not to tread."

This is very much akin to TDD as it doesn't just tell you what code to write but also when to stop. It's a system design tool using code!

5

8 reads

What's A Good Plan And Why?

What's A Good Plan And Why?

The article is very concise when it comes to describing good plans.

"In software engineering, these flares take the form of formal specifications, or blueprints that describe, analyze, and verify a system design. Often, we spend the bulk of our coding time tinkering with plumbing and fiddly bits; the essential behavior we’re trying to program is just a small part of the equation. Making sure the essential behavior is correct before you start a project can save a lot of time and energy down the road."

4

5 reads

What Are Formal Specifications And What Do They Look Like

What Are Formal Specifications And What Do They Look Like

"Typically, specifications are written in formal specification languages such as TLA+ or Alloy. While programming languages are designed to be run, specification languages are designed to be simulated, and therefore include features like nondeterminism (this call can succeed or fail), atomicity (the server can crash between these two calls), and scalability (10 servers will be trying to make this call). Specification languages can also delineate the parts of the spec you’ve carefully thought through, as well as the parts you’ve shunted to the side for the time being.

4

7 reads

Why Do Planning At All? Isn't That Waterfall?

Why Do Planning At All? Isn't That Waterfall?

Weeks of coding can save you hours of planning. Agile doesn't mean you don't plan, it just means you don't overplan and avoid sticking to plans that don't work.

"It might be annoying to throw out a mostly working plan, but it’s far worse to throw out a mostly working codebase."

Planning with formal specification techniques can be done iteratively to avoid costly big-bang and waterfall design practices such as Big Design Up Front (BDUF).

4

5 reads

What Does Success Look Like?

What Does Success Look Like?

"The formal specifications had done their job, illuminating several possible paths down the hill. Now it was time to apply a little good old-fashioned reasoning. After some discussion with the project manager about our timeline and scope, we settled on a single design and got to work."

Good tools center human judgement by making it more effective. Bad tools make assumptions about completeness that end up remove human judgement entirely. This is a perpetual conflict in the Pure Automation vs. Augmentation discussion.

4

3 reads

Why Don't More People Use Formal Methods Like Specification?

The author writes:

"I came away from the experience wondering why formal specification wasn’t more widespread. It had proved valuable at our startup, which had just 10 engineers. How much might it help development teams building software at scale? Through research, I discovered UX issues are the primary barrier: The tools are hard to learn, hard to use, and their benefits might not be immediately obvious to users. These are genuine problems, but addressable ones."

4

3 reads

How Can You Get Started With This Software Superpower?

How Can You Get Started With This Software Superpower?

There are tons of resources available for TLA+ and Alloy, the two most popular tools for formal specification.

If you want a deep dive into TLA+ you can get started by buying the author's book, Practical TLA+. It's an excellent read

There is also currently a book underway by Daniel Jackson and his team to introduce the exciting new features of Alloy 6. Released in Fall of 2021, Alloy 6 introduces a variety of new capabilities which make it especially attractive for this sort of work.

4

6 reads

IDEAS CURATED BY

yonkeltron

Computer Scientist working in healthcare. Keen on #software and more.

CURATOR'S NOTE

These ideas have greatly influenced my software practice and helped me to build better systems than before.

Jonathan Magen's ideas are part of this journey:

Joining A New Team

Learn more about computerscience with this collection

How to establish a positive team culture

How to collaborate effectively

How to build trust with a new team

Related collections

Read & Learn

20x Faster

without
deepstash

with
deepstash

with

deepstash

Personalized microlearning

100+ Learning Journeys

Access to 200,000+ ideas

Access to the mobile app

Unlimited idea saving

Unlimited history

Unlimited listening to ideas

Downloading & offline access

Supercharge your mind with one idea per day

Enter your email and spend 1 minute every day to learn something new.

Email

I agree to receive email updates