This content originally appeared on DEV Community and was authored by Steven Read
There have been a number of times in my life when I have found that I have learned things through doing, and then later discovered empowering vocabularies and models which further enhance and improved what I was already doing. Domain-driven design was one such area, but systems thinking recently became another.
To illustrate my point we have Theme Park; a game I played in my early school years, which was overflowing in systems experiences. In the game you manage staff, set prices and salaries, build a park, stock shops, and more. Behind every computer programmer you often get a background story about computer games, so I guess I am no different.
Today we will be using Theme Park to introduce a systems thinking modelling technique – the Stocks and Flows diagram. The purpose? Well besides to apply stock and flow diagrams, it was to explore an explosive phenomenon that can occur when you have a busy system, which I will refer to as the vomit loop. Some actions within this system are optimisations – staff training for instance. Others such as staff strikes could place the system in a critical position. Many of those optimisations that enable operation at scale then only make the system more susceptible to failure.
The diagram is made up of:
𝗦𝘁𝗼𝗰𝗸𝘀: Where some entity is accumulated over time via inflows and outflows. This could also be considered like a water level. A bath can be described as a stock of water
𝗙𝗹𝗼𝘄𝘀: Where a stock is being changed over time, typically measured as a rate. Water going down the plug hole is a flow
𝗖𝗼𝗻𝘃𝗲𝗿𝘁𝗲𝗿𝘀: Calculated values based on other parts of the system, or boundary values entering the model. Despite stocks and flow diagramsnot including converters in the name they are an import part of the notation
𝗔𝗿𝗿𝗼𝘄𝘀: Representing the effects of each instance on the others
The following relationships are also illegal:
Flows cannot influence other flows
Stocks cannot influence other stocks
Converters cannot influence stocks
In my diagram I have used all of these components, and used the terms 𝘳𝘢𝘵𝘦 to label 𝗳𝗹𝗼𝘄𝘀 and 𝘴𝘵𝘰𝘤𝘬 to label 𝘀𝘁𝗼𝗰𝗸𝘀. All remaining components are 𝗰𝗼𝗻𝘃𝗲𝗿𝘁𝗲𝗿𝘀. As you can see the model is pretty large already, so for brevity, in an attempt to avoid text becoming too small, I have simplified the modelling of litter and toilet stocks.
If all of your cleaning staff go on strike, you are quickly left with no option but to close the park, or suffer significant reputational damage. Are there other solutions? Yes! Multiple cleaning contracts, or having sickbags at the exits to exciting rides and bins around the park. This is where your stocks and flows diagram comes in. You can use the diagram to explore how new measures would affect the system. The diagram isn’t to document a system, it is to explore changes to the system.
This content originally appeared on DEV Community and was authored by Steven Read
Steven Read | Sciencx (2024-08-11T18:32:31+00:00) Teaching systems thinking through computer games. Retrieved from https://www.scien.cx/2024/08/11/teaching-systems-thinking-through-computer-games/
Please log in to upload a file.
There are no updates yet.
Click the Upload button above to add an update.