yego.me
💡 Stop wasting time. Read Youtube instead of watch. Download Chrome Extension

Simulations and repetition | Intro to CS - Python | Khan Academy


2m read
·Nov 10, 2024

I'm running a coin flip experiment and I want to find out how likely each outcome is: heads or tails. So I flip a coin once, twice, 100 times. Once I've repeated that experiment enough times, I see that about 50% of my flips are heads and 50% are tails.

Now, that's not a particularly interesting result. You probably could have told me that's what would happen at the beginning. But what if the experiment I want to repeat is much bigger? Instead of physically performing the experiment, we can simulate it with code.

For example, maybe I want to simulate a car crash to predict the risk of injury to the passengers, or I want to simulate a forest fire to predict how far it'll spread, or I want to simulate crop growth so I can predict yields and decide what to plant. These are all things that would be far too costly, too devastating, or take far too long to repeat in the real world.

But if we build a computer simulation, we can repeat the experiment as many times as we want for free, modifying different data inputs along the way. To simulate crop growth, I might combine climate and soil data with different irrigation and fertilizer choices, and then repeat how that affects my crop growth over a series of time steps.

Weather simulations work the same way. They collect wind, air pressure, and other readings from hundreds of different balloons, buoys, and satellites, and apply mathematical models over a series of time steps.

Okay, but why is the weather forecast wrong so much of the time then? It's almost impossible to 100% model the real world in a program. There's just so much data and randomness to take into account. And as humans, we don't always have access to all the data or 100% understand all the relationships involved.

Sometimes there are simply too many relationships that the computer physically can't process that much information in a reasonable amount of time. These are some of the limitations of our current weather models. We don't have data on the conditions at every single point on Earth, and even if we did, the computer wouldn't be able to handle all that data.

We can, in theory, more accurately predict tomorrow's weather, but by the time we get the result, it'll be the day after tomorrow. So for practicality, almost all simulations make some assumptions or simplifications about the world around us and settle for good enough results according to their needs.

Whether there's constraints on the data available, the amount of time they have to build the simulation, or the sheer computing power required, with just conditionals and variables, we can start to write our own basic simulations in Python. We're only missing two things: we need to be able to repeat our experiment and we need to be able to model some of the randomness that occurs in the real world.

More Articles

View All
Assassination politics: Not inevitable
In my previous video, I described Jim Bell’s idea of assassination politics and said that I agreed with him that the emergence of such a system seemed inevitable. Thanks to the user, peace requires anarchy. I’ve since read an article by Bob Murphy, which …
You Can't Touch Anything
Hey, Vsauce. Michael here. And today we’re going to get close, like really close. In fact, I want to answer the question: what’s the closest we can get to other objects and other people? Now, it might sound like kind of a simple, easy question, but when …
Population regulation | Ecology | Khan Academy
What I want to do in this video is think a little bit more about how populations can be regulated. Broadly speaking, we can think of the regulation of populations in two different categories: there’s the regulation dependent on density - so, density-depen…
Federalist No. 10 (part 2) | US government and civics | Khan Academy
In the part 1 video, we already saw James Madison and Federalist number 10 argue strongly that a republican form of government is better for addressing the issues of having a majority faction that might try to overrun minority groups. In this video, we’re…
Khan Academy Ed Talks - Reimagining School with Sal Khan, Rachel E. Skiffer, & Kim Dow
Hi everyone, Sal Khan here from Khan Academy. Welcome to Ed Talks! You could view this as a flavor of our homeroom live stream that we’ve… we, we focus more on education topics. Uh, first of all, I want to wish everyone a happy new year! Hopefully, your …
Differentiability at a point: algebraic (function is differentiable) | AP Calculus AB | Khan Academy
Is the function given below continuous differentiable at x = 3? And they’ve defined it piecewise, and we have some choices: continuous, not differentiable, differentiable, not continuous, both continuous and differentiable, neither continuous nor differen…