#423: Solving 10 different simulation problems with Python Transcript
00:00 Python is used for a wide variety of software projects.
00:03 One area that's really gained a lot of momentum is in the computational space, including data science.
00:07 On this episode, we welcome back Allen Downey to dive into a particular slice of this space,
00:13 simulation problems in Python and physics and engineering in general.
00:17 This is Talk Python to Me, episode 423, recorded June 6, 2023.
00:23 Welcome to Talk Python to Me, a weekly podcast on Python.
00:39 This is your host, Michael Kennedy.
00:41 Follow me on Mastodon, where I'm @mkennedy, and follow the podcast using @talkpython,
00:46 both on fosstodon.org.
00:49 Be careful with impersonating accounts on other instances.
00:51 There are many.
00:53 Keep up with the show and listen to over seven years of past episodes at talkpython.fm.
00:57 We've started streaming most of our episodes live on YouTube.
01:01 Subscribe to our YouTube channel over at talkpython.fm/youtube to get notified about upcoming
01:07 shows and be part of that episode.
01:09 This episode of Talk Python to Me is brought to you by InfluxDB.
01:13 InfluxDB is the database purpose built for handling time series data at a massive scale
01:19 for real-time analytics.
01:20 Try them for free at talkpython.fm/InfluxDB.
01:25 And it's brought to you by the PyBites Developer Mindset Program.
01:28 PyBytes' core mission is to help you break the vicious cycle of tutorial paralysis through
01:33 developing real-world applications.
01:35 The PyBites Developer Mindset Program will help you build the confidence you need to become
01:39 a highly effective developer.
01:41 Check it out at talkpython.fm/PDM.
01:44 Hey, Alan.
01:45 Welcome to Talk Python to Me.
01:47 Welcome back.
01:48 Thank you.
01:48 It's a pleasure to be here.
01:49 Pleasure to have you back.
01:50 We were talking just a little bit before the show, realizing it's only been six years since
01:55 you were on the podcast.
01:56 How about that?
01:56 Last time we talked about Python and engineering way back in 2017, which was a lot of fun and
02:03 has some interesting lead-ins to some of the things that are actually created now.
02:08 You were hinting I'm working on this project about simulating things with Python.
02:12 Here we are talking about it.
02:13 Yeah.
02:13 I was just getting started then and the book has come out very recently.
02:18 So we've kind of bookended the project.
02:20 Absolutely.
02:21 Well, it's quite a project and it's a very interesting one.
02:25 I think a lot of people out there, they hear maybe they should use Python instead of, I don't
02:31 know, MATLAB or some other language for modeling their domain, right?
02:36 And with your book that you put together, which is available for purchase, or you can
02:42 read it online for free.
02:43 That works for you.
02:44 It has a bunch of different examples.
02:45 How many examples?
02:46 Maybe 30 or so?
02:47 I think that's right.
02:48 There are examples in the chapter and then case studies that get into more detail.
02:53 Yeah.
02:53 So there's a lot of different areas of specialization where you're bringing Python to answer problems.
02:59 And we're going to have a lot of fun talking about that.
03:02 But let's just do a quick catch up.
03:04 It's been six years since we last spoke.
03:06 What have you been up to?
03:07 Well, I've changed jobs a couple of times.
03:09 I was a professor at Olin College for 19 years.
03:13 I left at the end of last May.
03:16 And then I was at Driven Data for a little while, working on data competitions and machine
03:23 learning.
03:23 And then recently I've joined Brilliant, where I'm doing curriculum design.
03:28 That sounds very fun.
03:29 You know, first of all, leaving college you were at for 19 years.
03:33 That's a big deal.
03:34 Yeah.
03:35 I've been an academic pretty much all the way through.
03:37 You know, I graduated from college.
03:39 I went to grad school.
03:40 I had my first job.
03:41 I was a faculty member at Colby College and then Wellesley College.
03:46 And then, as I said, Olin for 19 years.
03:48 So it's a real change of career.
03:50 How's it going?
03:52 It's good.
03:54 I'm learning a ton.
03:55 You just, you know, whenever you start something new, you're always, you're on this, you know,
03:59 the steep part of the learning curve, which is challenging, but it's also just exciting.
04:03 You're getting exposed to different things, learning a ton.
04:06 Yeah, absolutely.
04:07 And working at Brilliant now, you know, Brilliant's a good company.
04:12 They've been past sponsors of the show, which is great.
04:15 And, you know, maybe just talk a bit about how you think about curriculum design, since
04:20 that's what you're focused on there.
04:21 How do you think about putting together small class, not semester-wide classes for people
04:27 to learn?
04:28 Yeah, that's a big part of it.
04:29 It's a different format.
04:31 It's smaller, as you said, it's interactive in the sense that the learner is interacting
04:37 with these, you know, graphical elements and other ways of communicating ideas visually.
04:43 We use a lot of animation and the text is deliberately very concise.
04:49 We're trying to, you know, show, not tell.
04:52 And that's a really different kind of curriculum design for me.
04:55 I'm used to, you know, I have a semester-long course.
04:57 I've got several hours a week.
05:00 It's very different.
05:01 And that's part of the challenge that was appealing to me.
05:04 Because I saw some of the courses and I was very impressed with the pedagogy and the opportunities
05:10 that you have there with animation and sound and interactives.
05:14 It's a very different kind of teaching.
05:15 But it's not, there's no, I don't have any interaction with students.
05:20 So that's a challenge as well.
05:21 It's a big challenge.
05:22 I went from teaching in person to teaching online as well.
05:26 Not through Brilliant.
05:27 But I think there's a couple of really big differences.
05:30 One is when you're either, you have a student for a semester, Monday, Wednesday, Friday at 11 to 12.
05:38 Or if you're doing a week-long training class in person.
05:40 Those groups are captive, right?
05:43 And so the constant need to keep their attention for every single minute is really different, right?
05:50 Because it's not impossible, but it's rare that students just get up and walk out because, you know, there's a five-minute section they weren't engaged with.
05:57 But they could easily leave a website.
05:59 Yeah.
05:59 It's particularly in a format like Brilliant, you know, there's not a certificate at the end.
06:04 The motivation to keep going is you're having a good time and you're intrinsically interested in the topic.
06:12 So from my point of view as an instructor, the challenge there is to maintain that.
06:16 It has to be interesting, engaging all the time.
06:21 As you said, if you've got, you know, a five-minute lull, you might lose your audience.
06:25 Yeah.
06:25 The other part that is a big difference is when you have those folks in class, even in a Zoom meeting to a degree, you get immediate feedback of how does an idea land?
06:35 If I present it this way, are they engaged?
06:38 If I present it, or are they clearly not getting it?
06:41 Whereas you put it out into the world at Brilliant or Talk Python or wherever, and they've got to, you take a guess and you put it out there, right?
06:49 You don't get that feedback.
06:50 Yeah.
06:50 Not directly.
06:51 That's definitely challenging.
06:52 We do have some signals where we can see if a learner is getting stuck at a particular place or if we see a lot of drop-off on a particular lesson, we can go in and try to figure out what's happening.
07:03 We get a little bit of explicit feedback.
07:05 Sometimes the learners will tell us what's wrong.
07:07 But most of the time, you're kind of, it's on you to make sure that that lesson works.
07:12 And your colleagues were constantly reviewing each other's lessons and looking for those places where we think we might lose learners.
07:19 Excellent.
07:20 Well, I'm sure it's a lot of fun.
07:21 Some nice comments in the live chat out here.
07:24 People appreciate that as well.
07:26 So one thing that you said you learned, which I haven't really learned before, is I don't even really know what it looks like, is Elm.
07:35 Tell us about Elm.
07:36 What is this?
07:36 This is a programming language.
07:38 As it says, it's primarily for web applications.
07:41 It is a functional programming language.
07:44 And it's mostly a stateless computational model.
07:47 So it's very different from Python.
07:50 I've been learning it.
07:51 This is what we use for a lot of the interactive elements.
07:53 And it was new to me.
07:56 Honestly, I had not even heard of it.
07:58 But it's been great.
08:00 I just, you know, it's been a little while since I learned a new language.
08:03 It's been about 23 years since I learned a new language.
08:06 And I've done functional programming, but I haven't used it, you know, really for applications.
08:12 So this has been, you know, challenging but fun.
08:15 It looks a little bit like Lisp meets HTML.
08:18 That's not bad.
08:20 Yeah.
08:20 Okay.
08:21 Certainly the semantics is very Lisp-like.
08:23 Syntax can be, although not too many parentheses.
08:27 Not as many.
08:29 You get that blister on your pinky or whatever finger you use for the parentheses.
08:32 Maybe your right index figure.
08:34 Right.
08:35 Or ring figure.
08:35 Yeah.
08:36 Yeah.
08:37 And then the syntax, it has a couple of nice features like pipes.
08:40 So, you know, taking a value and piping it through a sequence of functions.
08:44 And of course, you know, functional features like passing around functions as first class
08:48 objects and partial function evaluation.
08:50 Is this a front-end language, like a JavaScript?
08:52 Or is it a back-end language, more like Python?
08:54 Yeah.
08:54 No, front-end, it's getting compiled into JavaScript.
08:56 Okay.
08:57 But it is strongly typed, like extremely strongly typed.
09:00 Like integer and float are incompatible types.
09:03 There we go.
09:05 So very strongly typed.
09:06 But that, along with a lot of error checking, gives you some more confidence that if you put
09:12 this on a web page and a large number of people interact with it, there are maybe fewer errors
09:17 that can get past a compiler.
09:19 You know, a really dynamically typed language like Python, you're rolling the dice.
09:24 You deploy that code.
09:25 You know, some of those lines of code have never run.
09:28 And the first time they do, you might be in trouble.
09:31 The type hints are helping.
09:32 mypy is helping, but that's not a runtime thing.
09:34 Pydantic, for example, is a runtime version that option that helps a lot.
09:39 Before we move off this front-end stuff, then we'll get to the modeling.
09:41 Have you been tracking PyScript and the front-end Python stuff?
09:46 Is that interesting to you?
09:46 It definitely is, and especially from a teaching point of view, getting people into Python.
09:51 One of the challenges, you know, from way back has always been, how do you get a new programmer
09:57 to the point of executing their first line of code?
10:00 That is definitely not as big a barrier as it used to be.
10:04 It used to be.
10:05 You know, you had to install things and download things and all that.
10:08 But yeah, the lower that barrier, the better.
10:11 And yeah, I think PyScript is one of the things that can help to lower it.
10:14 Yeah, I do too. I'm very excited about PyScript.
10:16 It had been interesting in the realm of kind of different ways to execute notebook-style code
10:22 and so on when it was based on Pyodide.
10:25 And now that they're talking about moving to MicroPython, it starts to get into the realm of it.
10:30 It could download the same size as Vue or Angular almost.
10:34 And then it becomes, maybe you can make real apps with this thing.
10:38 So I'm looking forward to see where that goes.
10:39 Oh, interesting. I had not heard about that. So that's exciting.
10:43 Yeah, yeah. One of the big things that they're trying out, I had a couple of the folks on from various projects four or five months ago,
10:49 is they're trying to, instead of using full CPython as the foundation, to use MicroPython,
10:54 which means the download goes from like 10 megs to 100K.
10:58 Yeah.
10:59 When you're talking 100K download, you're like, you know, that's kind of like a big JavaScript.
11:03 And if it's over a CDN and it's cached, you know, maybe you could just make that part of your app in general, not as a specialized thing.
11:09 Yeah, that's interesting, particularly because I think one of the other challenges for Python right now is it takes a while before you're doing really interesting stuff.
11:20 And, you know, JavaScript, for example, you can immediately start doing front end kinds of interactions.
11:27 And a beginner can start to write programs where it resembles the kind of apps that they're using.
11:34 And I think that's a pretty important hook.
11:36 For Python, that's a long path.
11:37 And so it sounds like this could shorten that path quite a bit.
11:40 It sure could. That would be very interesting.
11:42 And I think your insight there comes in as a bit of a teacher as well, right?
11:48 Like it's one thing as an engineer, like I'm going to build this thing, so I'm going to choose this language for such and such.
11:53 But as a teacher, you realize like if you don't have a win early enough in the learning cycle, then you might just bail.
11:59 And for a lot of people, a win is I have a UI.
12:02 I have a thing that looks like an app that I could see on my phone or I could see in my web browser or something like that, right?
12:09 Yeah, definitely.
12:10 Or a robot or some interaction with the real world.
12:13 But yeah, converting Fahrenheit to Celsius is not going to do it.
12:18 No, but Celsius to Fahrenheit, that one is the one.
12:20 That's the one.
12:21 Okay.
12:21 But speaking of converting numbers and so on.
12:26 This portion of Talk Python to Me is brought to you by Influx Data, the makers of InfluxDB.
12:33 InfluxDB is a database purpose built for handling time series data at a massive scale for real-time analytics.
12:41 Developers can ingest, store, and analyze all types of time series data, metrics, events, and traces in a single platform.
12:48 So, dear listener, let me ask you a question.
12:50 How would boundless cardinality and lightning-fast SQL queries impact the way that you develop real-time applications?
12:57 InfluxDB processes large time series data sets and provides low-latency SQL queries, making it the go-to choice for developers building real-time applications and seeking crucial insights.
13:08 For developer efficiency, InfluxDB helps you create IoT, analytics, and cloud applications using timestamped data rapidly and at scale.
13:18 It's designed to ingest billions of data points in real-time with unlimited cardinality.
13:23 InfluxDB streamlines building once and deploying across various products and environments from the edge, on-premise, and to the cloud.
13:31 Try it for free at talkpython.fm/influxDB.
13:35 The link is in your podcast player show notes.
13:38 Thanks to Influx Data for supporting the show.
13:42 Let's talk about your latest book.
13:44 You have a lot of books over at Green Tea Press.
13:48 This is your home for where your books go, right?
13:51 Yeah.
13:52 As well as links to other ones you've written at places like O'Reilly.
13:54 Right.
13:55 Yeah.
13:55 So, everything starts here and there's a free version of all of the books and you can get to it from here.
14:01 You can see kind of the evolution of my process because some of the earlier books, you know, some of them look better than others.
14:06 Let's put it that way.
14:08 And then links there for the ones that have been published, there are hard copies available and electronic versions in convenient format.
14:16 I think we might have spoken about this six years ago, but it was six years ago and I'm not sure and I imagine a lot of people don't remember it.
14:22 Did we talk about your textbook manifesto?
14:24 What is this?
14:25 That was what really got me started and came from my frustration with existing programming books, but also just textbooks in general.
14:35 The way they're used in a lot of classes, they are expensive, they are way too big.
14:40 You know, if there are 700 pages or a thousand pages, nobody's going to read that in a semester.
14:46 And if you're assigning 50 pages a day, I think, you know, you're kidding yourself and the students are not getting much out of that.
14:55 So this is the idea that you can write a book that your students can read and understand and that is at the size where you can do something like a flipped classroom where they are actually going to do some reading before class.
15:10 Not 50 pages, but 10 maybe.
15:13 Come to class.
15:13 Now, as an instructor, I can help to figure out, you know, what are the problem spots?
15:18 What should we cover in class?
15:19 What can we do to practice those ideas in class to take advantage of the time when we're actually in a room together?
15:25 So, you know, read when you're on your own.
15:28 Come to class.
15:29 Let's do things that are more useful than me standing at the front of the room talking to you.
15:33 Yeah, sure.
15:34 Okay.
15:35 That makes a lot of sense.
15:36 So let's dive into your book, Modeling and Simulation in Python.
15:40 Now, as I'm going through this, I'm not sure what I would classify it as.
15:45 Is this a science book?
15:47 Is this an engineering book?
15:48 Is it a programming book?
15:49 It kind of feels like it's a little bit of all of those.
15:52 How would you, what's your elevator pitch here?
15:54 Yeah, it's that.
15:55 It is the solution to a chicken and egg problem, which is that in an engineering curriculum, a science curriculum,
16:02 and maybe even more broadly, I think, for teaching physics and math to almost anyone, a computational approach is really appealing.
16:12 There are things that you can do with computation that are very difficult to do analytically.
16:17 You can do more interesting things faster.
16:21 So that's the appeal.
16:22 The hard part is most people are not coming into college with programming experience.
16:28 Some do, most don't.
16:30 So whatever your curriculum is, but let me focus on engineering because that's where I was.
16:34 You've got a cohort coming in who have programmed, a cohort who have never programmed, and then kind of maybe a middle.
16:41 Maybe they've done like HTML or something like that.
16:43 And now I want to teach them physical modeling, but I have to do kind of three things at the same time.
16:49 The modeling piece, the physical models, the domain knowledge, you know, if it's a scientific system or an engineering system, whatever it is, and programming.
16:59 And there's no good sequence.
17:01 Like I can't send people out to take a computer science class, and then they come back and we do computational science.
17:10 It's just there are a number of reasons that that doesn't work.
17:13 And same thing if they go, let's say they go take calculus or linear algebra, and then they come back.
17:18 Collecting that knowledge and then trying to synthesize it is really hard.
17:22 And it means it's a sequence of courses instead of starting in right from the beginning.
17:27 So those are some of the problems that we were working with.
17:30 And the best solution, at least we think, is put it all together.
17:35 We're going to teach people how to program using these physical models as examples.
17:40 And so they're getting some mathematics, not a ton, kind of a gentle introduction to differential equations.
17:47 Some physics, but it's a bit more broad because it's not just mechanics.
17:52 And then some programming, but it's really a subset of programming that's focused on those domains.
17:59 So that was my best explanation.
18:01 Oh, it's good.
18:03 It's good.
18:04 I can see how there's not a real great solution for that in a college curriculum, right?
18:08 You send them off to take a CS class, and they might come back of having done an introduction to programming course,
18:14 but still not really be able to do too much, or an algorithms course.
18:17 And like, I can really tell you about a doubly linked list.
18:21 You're like, all right, well, you're still not ready.
18:22 I'm sorry.
18:22 You know, right?
18:23 It's a challenge to bring these things together.
18:25 I think that's generally a challenge in education a lot is to cross these things over and why a lot of people feel like certain things are, that's useless.
18:33 I'll never use that.
18:34 That doesn't have any value to me because it's taught in such an abstract, isolated silo.
18:40 Yeah, and you never close the loop because we're making a promise.
18:43 If we send a student to take a prerequisite class, the contract is, you go do this thing, and then when you come back, we're going to make it pay off.
18:53 You're going to see the benefit, and we never do.
18:56 It never pays off.
18:57 It's tough.
18:59 It's tough.
19:00 So, like we said, there's about 30 different problems in here, like population growth.
19:05 How long does it take for your coffee to cool?
19:08 What's the optimal way to transfer it to work?
19:10 Glucose, disease modeling, as well as vaccines.
19:14 People can check out.
19:15 So, I thought it might be fun for us to just pick out however many we get through.
19:19 Let's say we take a shot at 10.
19:21 We'll see if we get there.
19:22 10 of these and just kind of talk through what is the problem?
19:25 What are some of the Python ideas at play here?
19:28 Maybe what are some of the math or science ideas as well?
19:30 So, you want to start with world population?
19:33 Sure.
19:34 Yeah, this one was interesting for me.
19:36 It's something I didn't know very much about, so I got to learn.
19:39 I think it's a sweet spot of you don't need a lot of computational tools because this one comes very early in the book.
19:47 But you can study a real system that's happening right now and get to understand it.
19:52 So, it's a discrete system.
19:54 So, we're just counting the number of people and modeling population growth.
19:59 And so, the number of new people in any year is going to be some function of the current population.
20:05 And so, we can introduce a couple of different models.
20:08 You know, starting very simple.
20:10 One of them says, what if we have the same number of births and deaths every year?
20:15 Well, okay, the population would grow linearly or maybe shrink linearly, but it would be linear growth, constant slope.
20:21 All right?
20:22 What if it's proportional?
20:23 What if we have a birth rate that's proportional to the current population?
20:28 Some people might know.
20:29 You're going to get exponential growth.
20:31 And I think if you ask people what's going on in the world right now, they probably believe that we are experiencing exponential growth.
20:40 That was my thought when I read this.
20:41 I thought, oh, yeah, okay.
20:42 So, we'll probably talk about geometric growth and those types of things.
20:45 Yeah.
20:45 Right.
20:46 Well, that's the model.
20:47 And we try to fit that model to the data, and it doesn't.
20:50 And so, that's where the first lesson comes from, which is you can do all the theory you want, and eventually you will collide with data.
20:57 And your theory may or may not survive the impact.
21:00 And that's what happened here.
21:02 The population is currently not growing exponentially.
21:06 Going back to about 1960, it's pretty close to linear.
21:10 And that one's kind of weird because, okay, wait a minute.
21:13 If it's linear, that means we have roughly the same number of births and deaths every year.
21:18 But how?
21:19 You know, how do you get 7 billion people to coordinate and make that happen?
21:23 So, there are a couple of ways to think about what's happening.
21:26 One of them is the logistic growth model, which starts out exponential.
21:31 And then, as you approach a carrying capacity, you approach this limit.
21:35 It approaches that limit asymptotically at the high end.
21:39 And in the middle, there's a piece that looks linear.
21:42 So, you could look at that model and you could, okay, maybe that's what's going on.
21:45 Except it turns out that's not quite right either.
21:48 And that's where the domain knowledge comes in.
21:50 Because so far, it's just been programming and looking at data.
21:55 At some point, you have to talk to a demographer because they actually know what's going on.
21:59 And what's going on turns out to be very interesting.
22:01 It's the demographic transition.
22:04 And this is a social and economic phenomenon, which is as societies, countries become more economically
22:12 developed and have more personal freedom, fertility rates tend to go down.
22:16 And they very often, it's often dramatic.
22:18 It would be a shift from lifetime fertility of five, six, seven, or eight children down to very close to two.
22:26 And 2.1 is the replacement level where population levels off.
22:30 A lot of developed countries right now are at or below replacement in terms of birth rate.
22:36 And so, the populations are leveling off or starting to decline.
22:40 Yeah.
22:40 There's going to be some knock-on economic effects.
22:42 Although, I don't know that those were modeled in your book.
22:44 But, you know, like, how does things like social security and support nets happen when the thing being supported is heavier or larger than the people doing the supporting, right?
22:55 Right.
22:56 Speaking of economies like Japan, for example, and so on.
22:59 Yes.
22:59 Yeah.
23:00 They've been below replacement level for quite a while.
23:02 So, in some sense, they are the predictor of what a lot of other countries are looking like now.
23:07 And as you said, you know, vast economic consequences.
23:10 Now, that's where I stopped.
23:12 It's not an economics book.
23:14 That's where it was, I think, fun for us to, you know, get to that point and say, look, okay, we have found some interesting things.
23:21 And now, you know, go explore because there's a lot more to learn about this.
23:26 Yeah.
23:26 I doubt it would surprise the listeners that the standard data science pieces are at play here.
23:32 Jupyter Notebooks, Pandas, Matplotlib, those kinds of things, right?
23:37 Yeah, there it is.
23:38 From Pandas, read HTML.
23:40 Yes.
23:41 Whenever we can, we try to get real data.
23:43 One of the goals of this class is to connect students to the real world.
23:47 And that's one of the places where data science is a real opportunity because the availability of data is great.
23:54 And the computational tools for working with data are very good.
23:58 Now, obviously, in Python, you know, Pandas is one of the popular libraries for data.
24:03 There are others, you know, more generally, you know, there's R, you know, Matlab.
24:06 This is a real, I think, teaching opportunity.
24:09 One of the things I thought was interesting from a lot of these was the...
24:13 The acquisition of the starter data for a lot of these.
24:16 So, for example, in this one, you have...
24:19 You're getting the world population estimates from a table.
24:22 And I think this table originally comes from Wikipedia, but you've saved it locally because you're smart.
24:28 And in case they change the format of that page, you don't have to rewrite your book.
24:32 But, you know, it really highlights certain things that are just so easy if you know the way, but are not necessarily obvious.
24:39 So, for example, here you have from Pandas, read, import, read, HTML.
24:43 You can just go read HTML and you give it a...
24:46 Either a URL or just a HTML file in this case.
24:50 And then you can say, well, we just want the second table that was in that HTML.
24:54 And it literally grabs out of Wikipedia.
24:57 It grabs the table and turns it into a Pandas data frame, which is pretty remarkable, honestly.
25:02 Yeah.
25:02 Well, you know, I have mixed feelings about this because it is...
25:05 Okay.
25:06 It's great that we can get the data and it's easy with these tools.
25:10 It's a little bit sketchy in the sense that, you know, as you said, we have to...
25:15 What if Wikipedia changes the format?
25:16 This is not exactly data that anybody intended to export.
25:22 So, I think I would prefer to get this data from the original source in a format that was really intended.
25:30 An HTML table is not exactly a data transport format.
25:33 No, an Elm table.
25:35 No, just kidding.
25:35 I mean, it's fragile in a lot of ways.
25:38 Somebody could insert a column, delete a column, more likely the insert one, right?
25:42 To add, oh, we found a new data source.
25:43 We added it.
25:44 And all of a sudden, all of your stuff breaks.
25:45 But it could even be as simple as we added more information to the Wikipedia page.
25:50 And now there's a table that precedes this table in HTML.
25:52 So, when you say, get me the second table, you actually get some unrelated thing, right?
25:56 So, obviously, I mean, it's effectively web scraping behind the scenes, which is always fraught with instability.
26:03 But you're taking advantage of what Wikipedia did, which is to collate all of these sources.
26:09 People have gathered this and curated this collection of data.
26:13 So, that's why I say mixed feelings, because it is a great opportunity to take advantage of that.
26:19 But web scraping might not be the best way to do it.
26:21 Yeah.
26:22 Quick question from Marwan.
26:23 Does the book include attempts to visualize the simulations, like modeling a bouncing ball becomes more rewarding if you can see it in action?
26:31 Definitely.
26:31 And that comes up in the third part of the book, which is about mechanical systems.
26:36 And those are the things where, yeah, we've got objects moving in space.
26:39 And that begs to be an animation.
26:42 There's not a ton of it because it's a little bit.
26:45 The tools for animation in Jupyter Notebooks using Matplotlib are a little bit clumsy.
26:52 So, I didn't get deep into it.
26:54 But definitely the point where you get to see the simulation and you see the objects moving in space, you, I think, appreciate it, for one thing.
27:03 You also, I think, get to debug it because your eye is really good at seeing physical errors.
27:10 If your physical model is doing something incorrect, you're going to see it instantly.
27:15 It's going to bother you.
27:16 Yeah.
27:16 That does look right.
27:18 And, you know, it's probably not necessarily a problem with the animation, with the modeling.
27:22 But even things like acceleration and deceleration, if a thing just goes over and stops, you're like, oh, it didn't.
27:27 That's not right.
27:27 It shouldn't do that.
27:28 It should slow down and come to a stop.
27:30 It didn't hit an imaginary wall.
27:32 This portion of Talk Python to Me is brought to you by the PyBites Developer Mindset Program.
27:40 It's run by my two friends and frequent guests, Bob Belderbos and Julian Sequira.
27:45 And instead of me telling you about it, let's hear them describe their program.
27:49 Are you trying to code your way to a more flexible and impactful career but aren't getting anywhere?
27:55 If so, the PyBytes Developer Mindset Coaching Program, PDM, can help get you unblocked.
28:02 Imagine this.
28:03 Building and deploying your own applications, mastering Python, and getting personalized one-on-one coaching every step of the way.
28:10 We know the struggle of tutorial paralysis all too well.
28:15 And that's why PDM focuses on real-world applications.
28:20 Our mission is to help you build confidence as an effective developer.
28:24 And remember, this isn't a bootcamp.
28:27 It's a highly personalized, invite-only program.
28:30 You won't be just another face in the crowd in some classroom, but a valued part of our inclusive community.
28:36 And are you ready to give back to the open source world?
28:40 With PDM, you'll gain the skills and the confidence to contribute meaningful code to the projects that matter to you.
28:49 And it's not just about the coding.
28:51 It's about joining a community of like-minded developers, fueling your intellectual curiosity and making a difference with your skills.
29:00 So, are you ready to take your Python skills to new heights?
29:03 We hope you are.
29:05 So, please, apply now for the PDM program.
29:09 With PyBytes, you don't just learn to code.
29:11 You code to learn, to grow, and to give back.
29:16 See you on the inside.
29:17 Apply for the Python developer mindset today at talkpython.fm/PDM.
29:23 It's quick and free to apply.
29:26 The link is in your podcast player show notes.
29:28 Thanks to PyBytes for sponsoring the show.
29:30 All right.
29:33 Next one to talk about is epidemiology.
29:37 And in this one, you can talk about the freshman plague.
29:41 People maybe with regard to college have heard of the freshman 15, like a certain amount of weight.
29:46 A lot of people seem to put on from the stress of going to college.
29:49 But the freshman plague is more about coming together in a big group from all over the place more than maybe people are used to coming from their hometown.
29:58 Yeah.
29:59 Well, we started this example.
30:01 Well, let's see.
30:02 I think we were working on this in 2017.
30:05 But we were using this example previously.
30:08 So before COVID is the point.
30:10 And I guess at the time, it was sort of a fun example.
30:13 Like, hey, everybody gets a cold during the first few weeks of the semester.
30:16 Ha ha.
30:17 And it's, you know, it's less funny now.
30:20 But it's also definitely more relevant.
30:22 You know, we're thinking about, you know, modeling an epidemic and modeling interventions.
30:28 And in particular, understanding a concept like herd immunity.
30:31 So if you're talking about, you know, public health and what, you know, what's our civic obligation, it's not just looking after yourself.
30:39 There is a public consequence to your individual decisions.
30:44 Yeah, absolutely.
30:45 There sure is.
30:46 And, yeah, this used to be somewhat of an interesting example.
30:50 And then it became one of the biggest stories, you know, maybe of our lifetimes.
30:57 Who knows?
30:58 Anyway, so this is the Kermak-McKendrick model.
31:01 And there's a couple of interesting things that I thought were interesting models here.
31:05 So in this model, you have the susceptible folks who are not yet infected, but potentially could be.
31:11 You have the recovered people.
31:12 And you assume they have some kind of immunity, at least for their freshman year, I guess.
31:16 And then the people who are infected.
31:17 And you talk about this idea of having, what's it called?
31:21 Stalk.
31:22 Yeah.
31:23 Stalk and flow diagrams.
31:26 Those are pretty interesting because you think of the freshman class as kind of a fixed set, right?
31:33 Mm-hmm.
31:34 There are some different versions of the model.
31:36 And right, Kermak-McKendrick.
31:37 Nobody calls it that.
31:38 Everybody just calls it an SIR model because those are your three.
31:42 And you can extend it.
31:43 There are additional groups.
31:45 And what you're modeling is the flow of, in this case, it's people, from one stock to another.
31:52 So someone who is susceptible, if they become infected, they move into the infectious stock.
31:59 And when they recover, they move into the recovered.
32:01 So this is the simplest model.
32:03 And usually, it's a fixed population.
32:06 The reason that this is where we start is that this lends itself to a differential equation that we can do some work with.
32:14 We can't solve it analytically, but there are some useful analytic methods.
32:19 And we can also work with it computationally.
32:21 So this is one of several examples in the book where we do both.
32:24 And that gives us a chance to show the strengths and weaknesses of analysis and computation,
32:31 and also to do some validation by comparing the results from one and the other.
32:37 So yeah, that's why this is where it is in the book.
32:39 It's kind of the transition from the discrete systems in part one to the first order continuous systems.
32:47 Yeah.
32:47 Okay.
32:48 One of the things that, I don't know, maybe I should have just known this or not,
32:51 but what was interesting to me was thinking about applying differential equations to a discrete set, right?
32:58 Like I think of differential equations of being either applied to like maybe an interval,
33:03 all of the real numbers or the complex numbers or, but not to 90 things, you know, which that was surprising, I thought.
33:12 And then your ability to model that in Python was pretty cool.
33:15 Yeah.
33:16 So I'm glad you mentioned that because it's a really useful modeling method.
33:21 And it's a good example of the kind of modeling decisions that you're making all the time.
33:25 And it can go in both directions.
33:27 You can take something that you know is actually discrete, like people, and treat it as if it were continuous.
33:33 And that works pretty well if you have a large population.
33:36 Obviously, if you get down to very small numbers of people, it starts to break down.
33:39 And that's where we can have a conversation about modeling and say, look, this is an approximation, right?
33:46 This isn't how the world really is.
33:48 But I can pretend, I can run the model, and those results can be useful even if the model isn't perfectly realistic.
33:56 Because, you know, that's how models work.
33:58 None of them are perfectly realistic.
34:00 So that's, I think, one of the goals of the book is to engage the learner in those kinds of discussions about modeling decisions.
34:10 Because I think that's missing in a lot of science classes.
34:14 If you think about the traditional freshman physics class, you are told what the model is.
34:20 You say, we're going to do a block on a frictionless plane.
34:23 We're going to do a projectile moving in a vacuum.
34:26 Well, the frictionless, that's a modeling decision.
34:29 It says, we're going to temporarily ignore friction in order to solve this problem.
34:33 But you as the learner didn't get to make that decision.
34:36 You don't, you're not required to figure out the consequences of it or think about when it doesn't apply.
34:42 And that's what we really wanted to get at here.
34:44 Yeah, that's a really interesting point.
34:47 And that's why a lot of people think math is just a bunch of formulas or, you know, science, hard sciences are often just a bunch of formulas.
34:55 Then you just got to remember to use the formula.
34:57 Because it just goes from this sterilized version, final version, without understanding, going from observation to making your way through it until you end up with something like this, right?
35:10 Yeah, yeah.
35:11 Yeah.
35:11 Now, there's a scary version of this, which is that it's not objective.
35:15 Because if there's one answer and your job is to figure out, you know, what's the right formula, apply the formula, get the answer at the back of the book, that's nice and objective.
35:26 And, you know, we want our science to be objective.
35:29 But regardless of what we want, it isn't.
35:32 Because it's based on modeling decisions.
35:34 All science is based on modeling decisions.
35:37 And those are subjective decisions.
35:40 It's deciding whether a particular model is suitable for purpose.
35:45 It depends on what you're trying to do.
35:48 If you want to make a general qualitative description of a system, maybe you can use a simple model.
35:53 Maybe you can leave friction out of it.
35:55 If you want to land an orbiter on Mars or a rover on Mars, you might need a more detailed model.
36:04 Yeah, if you're off by 1% of 1 degree, it's going to matter by the time you get there.
36:10 Yeah.
36:10 Where's that playing in again?
36:11 Yeah.
36:12 Yeah.
36:12 So in this one, you talked to using this, a couple of types and ideas in here with states and systems.
36:19 And it sounds like in the book, it looks like in the book, you provided some foundational building blocks for modeling the mod sim module, right?
36:28 So in addition to just having the books, you've got a bunch of Jupyter Notebooks that people can check out and as well as some code to kind of help this modeling here.
36:38 You want to talk a bit about that?
36:39 Sure.
36:39 So this was my attempt to use some programming ideas to communicate modeling ideas by creating these objects.
36:48 So one of them is a state object and it represents the state of a system.
36:52 So if you think about an object moving through space, it has position and velocity.
36:58 And at any point in time, if I write down the position and velocity, that's the state of that object.
37:04 So in object-oriented programming, that begs to be an object.
37:08 It is a state object that contains position and velocity.
37:12 Now, under the hood, it is a pandas series that is mapping from names to values.
37:19 Similarly with a system object, that's actually a Python namespace.
37:22 So there are a couple of different things, but this one's a namespace.
37:26 And it represents everything that you need to know about a system in order to model it.
37:32 So it'll be the parameters of the system.
37:34 If it's, let's take that projectile moving in space again, it might be mass, cross-sectional area, coefficient of drag, density of air, temperature of air, all the things to model.
37:45 One of the examples is like a baseball in flight.
37:47 Excellent.
37:48 So in this one, you go through, you model, you run the simulation over time and eventually end up with a graph that shows, you know, a little over half of the students got lucky and didn't get the plague.
37:59 But about half of them did at some point throughout the year or the semester or whatever it was.
38:03 So that's, you can do a single run in order to simulate a hypothetical course of the disease.
38:10 And now you can start to vary the parameters and say, you know, what if the disease is more infectious?
38:15 What if the recovery time is longer or shorter?
38:18 What if people start washing their hands?
38:20 And what if we start vaccinating them?
38:23 And so by varying the parameters now, you can see how the output of the model depends on the system parameters.
38:30 And that's where another one of these objects comes in.
38:33 We have a thing that's called a sweep series.
38:35 It's a mapping from a hypothetical parameter to the output of the model using that parameter.
38:42 Yeah, when you hear people talking about COVID, I remember them talking about the infection rate.
38:48 You know, is it bigger than one?
38:49 Is it less than one?
38:50 And all of those things were very relevant here, right?
38:54 Right.
38:54 Yes.
38:55 The R0 and R, the contact rate.
38:59 And that term comes straight out of this model.
39:03 That is the ratio of the two parameters here.
39:06 So beta is the rate of infection, depending on how many people are susceptible and how many are infected.
39:12 And gamma is the rate of recovery, which is the fraction of infected people who recover in a unit of time.
39:20 And the ratio of those two things is the contact rate, the R0.
39:24 Yep.
39:25 All right.
39:26 Well, way more relevant these days than it was a few years ago.
39:28 Oh, yeah.
39:30 We all know a lot more about epidemiology than we used to.
39:33 We sure do.
39:35 So my daughter was just enjoying going back and watching some of her favorite YouTubers videos from February and March of 2020.
39:43 Just laughing.
39:44 They were saying, oh, it looks like we're going to have to stay home for a week.
39:47 And she's just like, they have no idea.
39:48 They have no idea.
39:49 Okay.
39:49 All right.
39:51 Let's go on to something more fun.
39:52 One of my favorite things, coffee.
39:54 Come on.
39:55 Yeah.
39:56 Awesome.
39:56 And so tell us about the coffee cooling problem that you solve here.
40:00 This one's a classic.
40:02 The source that I'm aware of is a Martin Gardner column in Scientific American.
40:07 And it posed this question, which is, if I get my coffee and I also have some milk and I'm planning to add the milk to the coffee, should I add it now?
40:17 And so that they cool down together.
40:18 Or should I drive to my destination?
40:21 Let's suppose you're commuting.
40:22 Should I get to my destination and then mix them?
40:25 With the goal of getting the coffee down to a pleasantly drinkable temperature as quickly as possible.
40:31 Okay.
40:32 Yeah.
40:32 You pick it up.
40:33 Maybe you hit one of those drive-through coffee shack things that just stands on its own.
40:37 And you're like, oh, it's always too hot here.
40:39 How should I do this so that I can basically have a perfect coffee when I arrive where I'm going, right?
40:45 Okay.
40:45 Excellent.
40:46 So this one involves Newton's law of cooling, right?
40:50 Did I get that right?
40:51 You got it.
40:52 And the heat transfer.
40:53 There we go.
40:53 Newton's law of cooling.
40:54 Another differential equation here.
40:56 As they want to be in simulation.
40:59 Yes.
41:00 Right.
41:00 So this is another one, which is a first order differential equation.
41:04 You can do it two ways, which is you can break it up into discrete steps in time.
41:09 And so your differential equation becomes a difference equation.
41:12 And that's a natural thing for a programming language because now it's a loop.
41:18 And during each time step, you figure out the difference between the coffee and the environment.
41:23 That tells you the rate of change.
41:25 And then that lets you make a prediction for the next time step.
41:29 And so if you repeat that process, that is Euler's method for solving differential equations.
41:35 So there's kind of a natural transition there.
41:37 And then I think for this problem, we don't yet use the ODE solver.
41:42 But then later in the book, we do.
41:44 And that's trying to motivate, you know, why are we using this library?
41:48 Well, you know, there are limits to Euler's method.
41:51 At some point, it's not very accurate.
41:53 Yeah, it might not be accurate enough for sure.
41:55 And ODE, ordinary differential equations for people out there listening.
41:59 You got it right.
42:00 Thank you.
42:00 Ordinary differential equation.
42:02 And so, you know, Python has, you know, SciPy.
42:05 SciPy has several functions that will solve differential equations for you.
42:10 And so we're kind of, we're sneaking up on that.
42:12 Yeah.
42:12 Okay.
42:13 It is interesting that you can say, yeah, sure.
42:15 It's a differential equation.
42:16 And those might sound scary and hard to solve and all those kinds of things.
42:20 But you can subtract two numbers.
42:22 You can do a simple thing.
42:24 And looping is good.
42:25 And so if you just make your loop have small enough increments, you're kind of doing the
42:29 same thing that, you know, taking the limit to get to calculus does anyway, right?
42:33 Yeah.
42:33 We're kind of, we're short circuiting what I think is a really unnecessary loop, which
42:38 is there's a lot of physical modeling where you take a system, you write a differential
42:44 equation, but then you can't actually do anything with that differential equation.
42:49 You can't solve it.
42:50 And so you're going to have to use numerical methods anyway.
42:53 And if you look at what the numerical method is doing, it's basically Euler's method.
42:58 It's, you know, they're more complicated versions, but it's the same idea.
43:02 We're going to take time.
43:03 We're going to break it up into discrete steps.
43:05 And we're basically simulating the system.
43:09 So what we do in the book is cut out the middle and go straight to simulation.
43:14 There's almost no reason to write a differential equation if you can't solve it.
43:19 You might as well just start with a simulation.
43:21 So what's the story with the coffee?
43:23 How should I approach this?
43:24 I'm not going to give it away.
43:25 People got to earn it.
43:28 They got to come figure it out, huh?
43:30 You do have at the end.
43:31 So one of the big challenges here is not like, how soon in my trip should I get the coffee?
43:36 How long should I let it sit or any those kinds of things?
43:38 It's one of the important parts is you have milk or cream you want to put into the coffee.
43:43 You should decide if you put it into the hot coffee, the cold cream right away, that starts
43:49 at somewhere other than if you maybe wait till you get to the office and then mix the cream.
43:53 So people can come back and solve that about the milk.
43:56 Right.
43:57 Here's a question.
43:58 This came up.
43:59 One of the people I chat with on Twitter posed this question.
44:03 It's a variation of this.
44:04 He said he was disagreeing with his wife about using an electric kettle.
44:08 The question is, let's say that you heat up a kettle full of water.
44:13 You use half of it.
44:15 And now the other half is there.
44:17 You have a stay warm feature where you can set the kettle so that it keeps the water at,
44:23 let's say, tea making temperature for you.
44:25 Or you can shut it off, let it cool down.
44:28 And then later on, when you want to make tea, heat it up again.
44:31 Now, let's leave out of it for now that the time that it would take to heat up again.
44:36 Let's say you don't care about that.
44:37 You just want to know about energy consumption.
44:39 Is it better to keep the water hot or let it cool down and then you have to use all that
44:45 energy to heat it up again?
44:46 Do you want to get in on this?
44:48 Yeah.
44:48 My guess is it's better to let it cool down because the wider temperature gradient you
44:54 keep between the ambient air and the water, the higher rate of loss of temperature, which
45:00 you actually had a really interesting piece, tidbit of information here.
45:05 You said, okay, if the coffee cools from, you know, cooking temperature down to drinking temperature,
45:10 that's a ton of energy.
45:11 It says to give you a sense, if you're able to harness all of that heat to do work, which
45:16 you can't because of inefficiencies of engines.
45:18 But if somehow you had a magic levitating engine that converted a heat energy to potential
45:24 energy, you could use this lost energy to lift the cup of coffee from sea level to 8,500
45:31 meters just under the height of Mount Everest.
45:33 That's an insane amount of energy when you think about it.
45:36 That is.
45:36 And honestly, I did this calculation 10 times and I'm still not sure.
45:41 It's got to be wrong.
45:42 No, it's awesome.
45:43 I love it.
45:44 I believe that this is true.
45:47 But if someone contradicts me, I would be grateful because I just want to know.
45:51 But at least according to the calculation I did, the difference between mechanical energy
45:56 and heat energy is just, it defies your intuition.
46:00 And it's really, it's thermodynamics that is the difference because to take something from
46:06 sea level up to the top of Mount Everest is organized energy and heat is disorganized energy.
46:13 And what that means is, you know, you can have, you can have quite a lot of heat and
46:17 not be able to do much work with it because it's disorganized.
46:20 Yeah.
46:20 Okay.
46:21 Excellent.
46:21 Before we move on this one, I remember you were, I can't remember where I said, I think
46:25 it might've also been Scientific American, but there was a debate about coffee of whether
46:29 blowing on it, if it was the cool air hitting the water that would cool it, if it was just
46:35 the evaporation.
46:36 And someone did an experiment where they, they put a fan on it with cool background air
46:41 and they put a hairdryer with hot air blowing on it.
46:45 And it's still, it's the evaporation.
46:46 It's like these state changes and the, this energy of this heat loss.
46:50 It's, it's pretty powerful.
46:51 Yeah.
46:51 The latent heat of vaporization is, is a huge number, which is good because that's what
46:56 keeps us cool.
46:56 That's why sweat works.
46:58 That's right.
46:58 That's right.
46:58 It's good.
46:59 We're coming up on summer.
47:00 So we're going to appreciate that.
47:01 I'm sure.
47:01 All right.
47:02 Onto the next one limits to growth.
47:05 Tell me about this one.
47:06 Yeah.
47:06 So this is related to the population growth that we were talking about earlier.
47:11 And this is developing the logistic growth model, but then trying to figure out, is that
47:17 really what's going on?
47:19 Is, is human population leveling off because we are hitting resource limits?
47:24 Like, are we running out of food or, or other resources?
47:28 The answer for now is no.
47:30 I mean, we can certainly look at places in the world where resources are scarce, but
47:35 that's not what's limiting growth.
47:36 Interestingly, it's almost the opposite.
47:38 It is the places that are most economically developed, where resources are most available,
47:44 where fertility rates are the fastest.
47:47 Okay.
47:47 And, and it's not being driven by death rate.
47:49 That's the other thing.
47:50 I think the other reason that we know that what we're seeing is not a resource limit because
47:56 that would drive up the death rate.
47:58 Yeah.
47:59 And that's not the case.
48:00 The death rate is dropping at all ages in all places.
48:03 Well, with a few exceptions.
48:05 Yeah.
48:06 Yeah.
48:06 Of course.
48:07 So this one's kind of about finding that equilibrium.
48:09 Yeah.
48:10 This is taking the model to its limit and saying, okay, if we use the logistic model, even though
48:17 we think physically, this isn't exactly what's happening.
48:19 Can we make a prediction about where we think world population will level off and possibly
48:25 even start to fall?
48:26 And one thing that surprised me is that even though this model is very simple and not realistic,
48:32 the predictions that come out of it are not wildly different from what we're getting from
48:38 real demographers.
48:39 So the UN and the US census both have projections for world population out to about 2100.
48:47 And they predict world population will probably level off around 2100 at somewhere between 9 and 11 billion people.
48:56 And this very simple model is not too far off from that.
49:00 Yeah.
49:00 Okay.
49:01 That's a pretty wide range.
49:02 You know, a lot of things can happen.
49:04 Yeah, sure.
49:05 A lot of assumptions and current equilibrium might change, right?
49:10 Like, for example, climate change.
49:11 Who knows what that does?
49:12 Yep.
49:12 That's big.
49:13 But right now, the biggest drivers are the indices of world development.
49:19 If you look at things like health and especially child mortality, when child mortality is low,
49:25 fertility goes down.
49:27 And it's counterintuitive.
49:29 But to some extent, people are having, let's say, enough children.
49:34 If your children have a very high chance of survival, enough is a smaller number.
49:40 It's a funny way I'm looking at it.
49:41 But that's, so health, economic opportunity, human rights is one of the other big driving
49:47 forces.
49:48 Right.
49:48 Autonomy.
49:48 Yeah.
49:49 Freedom to make reproductive decisions and education.
49:52 That's the other big one.
49:54 Yep.
49:54 Yep.
49:55 Okay.
49:55 Another one from the health area, glucose and insulin.
49:59 Yeah.
50:00 What's the problem we're solving here?
50:01 So this is a model of the system in our bodies and actually, I think all mammals to regulate
50:08 blood sugar.
50:09 And it's the interaction of glucose or blood sugar and the hormones that cause blood sugar
50:14 to go up and down.
50:15 The primary one being insulin.
50:17 And there's a model that's called the minimal model.
50:20 And it was proposed by researchers who were trying to describe, you know, what's the minimum
50:26 set of interactions that we need in order to have a model that fits the data pretty well.
50:32 This is an example that I liked partly because the discussion of modeling was so explicit that
50:38 there are some quotes from these papers where they are more open about their thinking than
50:45 usual.
50:46 It seems like people kind of hide the models.
50:48 And these guys were really thinking about what do we need to include and what can we leave
50:54 out?
50:55 And how do we evaluate whether the model is good enough?
50:58 And the way they did good enough is they actually had data from studies of blood sugar and diabetes
51:05 where people have a challenge test.
51:09 They are actually injected with glucose solution and then they monitor their insulin levels and blood sugar levels over three hours with measurements every two minutes.
51:22 And so you can see blood sugar goes up and then insulin goes up and then glucose comes down and then insulin comes down.
51:29 And then you eventually get back, if everything works, to your steady state base levels where you started.
51:36 I see.
51:36 So if you don't have diabetes, your body should react that way.
51:40 But maybe if you do, like it can't produce the insulin to counterbalance that or something like this, right?
51:46 So I think I've heard of that as a test for seeing if you have either have diabetes or maybe are pre-diabetic, right?
51:53 Yep, exactly.
51:54 And there are two things.
51:55 Okay.
51:55 You might not be producing enough insulin or your cells might be insensitive to it.
52:01 So there are kind of two ways that that can go wrong.
52:03 Okay.
52:03 So I think, I don't remember which one that you did this on here.
52:07 There's all, all these come with great plots over time and, you know, running the simulation and seeing how it evolves over time.
52:15 And those kinds of things.
52:16 But at least one of these you used SimPy, right?
52:20 Yes.
52:21 SimPy is pretty interesting.
52:23 Yeah.
52:23 So this is symbolic computation and it allows you to solve systems equations, nonlinear equations, differential equations, at least for the ones that have an analytic solution.
52:35 SimPy will often find it for you.
52:37 And when I say find a solution, it's not a numerical approximation.
52:42 It's a symbolic representation of the function.
52:45 Right.
52:45 That's why I thought it was so interesting as a thing.
52:47 Because so everything we've been talking about so far are like these Euler type solutions.
52:52 We're like, okay, well, if we just approximate, if the gap is small enough, it's like calculus, but it's a loop, you know?
52:59 Whereas this says, actually, the integral of this differential equation is this other formula, right?
53:06 Like you would learn in, you know, calculus or something.
53:08 Yeah.
53:09 And so what you get is this object that represents the function and you can render it as LaTeX.
53:15 So you can kind of see it, you know, with the nice integral symbols and infinity symbols and all that.
53:21 And you can also, from that, generate Python code.
53:24 So you could have, you know, solve your differential equation and then evaluate the result as a numerical computation.
53:32 Right.
53:32 And the answer, instead of being 3.14, whatever, is just the letter pi.
53:37 Right.
53:37 Right.
53:37 It's like, here, you gave me a formula.
53:39 Here's the actual symbolic solution to it as a number, right?
53:43 Yep.
53:43 Yeah.
53:43 Pretty cool.
53:44 So you did, I believe you used that in some of your simulations or some of your models, right?
53:49 There were a couple of examples where we did both.
53:51 We would do the numerical solver and then the symbolic computation and then compare them.
53:58 And then a couple of places where there's an analysis that you can do, like the SIR model,
54:04 where the, you could do the analysis by hand and certainly in lots of science and math classes,
54:09 that's what you would do.
54:10 But I really wanted to show people how to do this symbolically because I think it separates two parts of the activity.
54:17 There's the low level activity of actually, you know, writing all the symbols on paper
54:22 and being very careful not to leave off the minus signs and the two, you know, factor of two and all that.
54:28 And then there's the high level, keeping track, what am I doing?
54:31 What's my goal?
54:32 What are the steps I'm following?
54:33 To get there.
54:34 And I think symbolic computation has a lot of potential to separate those two,
54:39 where I think people could come away with a much better understanding of that high level stuff
54:44 if they are freed from so much of their attention being on the low level stuff.
54:50 Yeah.
54:50 Yeah.
54:51 Just the grind of factoring polynomials or taking the derivative or whatever, right?
54:57 Yep.
54:57 Yeah.
54:58 Or you see, you know, mechanical systems, if you're working with physical vectors,
55:02 you just, you have a page that's just full of signs and cosines.
55:06 And it's, in some sense, what that, what that is, is a failure of notation because that page full of
55:13 signs and cosines is really telling you that you have not represented the computation in an effective
55:19 way.
55:20 That the signs and cosines are a consequence of not using vector arithmetic.
55:25 Right.
55:26 Which you do make a big use of with pandas and things like that, right?
55:30 Right.
55:31 We get to it.
55:32 And this is, I think, where I started to reach the limits of the current tools.
55:37 Because ideally, if you have vector quantities, like position and velocity and acceleration,
55:44 you should represent them as vectors.
55:46 And so when you add two vectors, you're not converting them to their coordinates, adding the coordinates,
55:53 and then putting the result back into a vector.
55:55 You just think of vector addition as a fundamental operation.
56:00 But in the same way, we would like to be able to do differentiation and numerical solution to these methods,
56:08 also using vectors as primitive objects.
56:11 And we're not quite there.
56:13 The SciPy libraries don't really do that.
56:16 So I end up doing a lot of packing and unpacking, where I start with vectors, but then to do the computation,
56:23 I have to break them down into coordinates.
56:25 And then when I get the result, I have to stuff it back into vectors.
56:28 I think the next generation of scientific computing, we need vectors as basic types,
56:35 and we need computation with units.
56:37 Yeah, right, which is something that's also often missing.
56:41 To my knowledge, this does not exist in Python or any other programming language that's not.
56:46 At least it is mainstream.
56:47 There are probably some engineering ones.
56:48 But we have things like Pint, right?
56:50 Yeah.
56:51 Which is a pretty neat library.
56:52 It's very neat, and it's very close to what I want.
56:56 AstroPy is the other library I'm aware of that does a really good job with units.
57:01 And I've played around with each of them enough to be excited for the potential, but also to have hit a wall of, I still can't quite do what I want.
57:11 Ideally, it should be end-to-end.
57:13 I should be able to start with the parameters of my system and the initial state described using vectors with units,
57:21 And then run the whole computation so that at the end, my result is in the form of vectors with units.
57:29 Yeah.
57:30 And that's still, that's not easy yet.
57:32 Yeah, not yet.
57:33 Okay.
57:33 You know, the SimPy stuff is a little like that in the sense that the thing you get back is like kind of a function in the mathematical sense,
57:42 like f of x equals, you know, e to the x.
57:45 And you can compose them and pass them around, right?
57:48 And sort of use them a little bit more than just, well, I got an answer out of this, and then I feed the answer there, right, numerically.
57:54 Yes.
57:55 So SimPy is end-to-end in this way, that you start with symbols and you end with symbols.
58:01 There's no like in-between where you have to break it down into numerical methods and then build it up again.
58:07 So yeah, I think SimPy has achieved this goal and we're still, I think, working on vectors and units and scientific computation.
58:16 Yeah, absolutely.
58:17 All right.
58:17 Well, we're pretty close to out of time, but I think maybe let's just touch on one more kind of fun.
58:23 And that is the, people can go and play with this.
58:26 That's the bungee dunk.
58:29 Do you want to tell people what kind of insanity a bungee dunk is?
58:32 And then you can just talk about this modeling problem.
58:34 As a way to say, some human being put their body in jeopardy to test this theory, right?
58:40 Tell us about this.
58:41 Yes.
58:42 Okay.
58:42 So this was partly prompted by this video, which shows a person doing a bungee jump.
58:47 So they're jumping off a crane.
58:49 They have a bungee cord attached to their ankles.
58:52 And when the cord is stretched out and fully extended, they are about four feet from the ground and they can reach out.
59:01 And the person jumping has a cookie or a biscuit because they're in the UK.
59:05 And they dunk the cookie into a cup of tea that is on a dock at the bottom of this.
59:11 And I forget the number.
59:13 Was it 30 meters?
59:14 But it was a roll round.
59:15 Yeah.
59:15 Something like that.
59:17 Yeah.
59:17 It was way too far for a person to do that with their body.
59:20 Now, part of this is that the bungee-
59:21 The video shows them literally they come to a complete stop because the way the springs work.
59:27 And they are right at where they literally do dunk this biscuit into the tea and then shoot back up for the back and forth oscillation by Hook's Law of the bungee, right?
59:37 You got it.
59:38 Right.
59:39 Now, the margin of error here is low.
59:41 Most people want to do a bungee jump to not do this because if it just turns out that he had extended about two meters more than he expected to, he would have at least hit the plank.
59:54 And he was over a body of water.
59:56 So maybe it's not a catastrophe, but it was a risky thing to do.
01:00:00 At a minimum, it's going to hurt.
01:00:01 Yes.
01:00:03 Yeah.
01:00:03 So basically, you go through the idea of like, well, if you wanted to try, the record was 70 meters.
01:00:10 Oh, okay.
01:00:11 Oh, that is way up there.
01:00:13 So that's way up there.
01:00:16 So if you wanted to say, you know what, guy with a cool beard that currently holds the Guinness Book of World Records, we have pandas, we have notebooks, we're going to beat this.
01:00:25 Right.
01:00:26 You could go through and model all the details out.
01:00:29 And you talk through some of the assumptions like the bungee will not apply a slowing force to you until it fully extends the slack length of the bungee.
01:00:38 And then it is a perfect spring and on and on, right?
01:00:41 Right.
01:00:41 But here's where there is some interesting physics.
01:00:44 So here is the other motivation for this problem.
01:00:47 Remember, thinking about modeling decisions.
01:00:49 What can you leave out and what do you have to include in order to get a precise answer?
01:00:55 So in this scenario, like air resistance is definitely a factor.
01:00:59 And the stretch of the spring and its restoring force is definitely a factor.
01:01:04 But here's the interesting part.
01:01:05 During the first phase of the jump, while the bungee cord is not yet stretching, but it is uncoiling because it starts out in a great big U shape.
01:01:15 It's dangling down and it has to unravel or, you know, unwrap itself as you are falling.
01:01:22 The first model that you probably think of is that it's just free fall, that you are being pulled by the force of gravity and the bungee cord is being pulled by the force of gravity.
01:01:32 And so there's no net interaction between the two.
01:01:35 And so you would think it would be just your acceleration would be equal to G, you know, 9.8 meters per second square.
01:01:41 And that's what turns out not to be true.
01:01:43 And it's not at all obvious, but there is an interaction with the cord.
01:01:47 It is transferring momentum from the cord to you.
01:01:50 It's analogous to a whip action.
01:01:53 And the net effect is that you accelerate faster than gravity because the cord is actually pulling you down.
01:01:59 It turns out that the difference you would be off by, if you ignore this effect, you would be off by about two meters.
01:02:06 And that's going to be a problem.
01:02:09 That was your margin of error.
01:02:11 Right.
01:02:12 So there's a nice physics paper that explains this.
01:02:15 And there's a really nice Veritasium video that explains the phenomenon and does a really compelling demonstration that shows that it's true.
01:02:25 Veritasium is fantastic for this kind of stuff.
01:02:28 It's a YouTube channel that does these kinds of experiments.
01:02:31 A little bit like the Discovery Show, but way better.
01:02:34 They're really good.
01:02:35 Yeah.
01:02:35 Did you see the downwind sort of sailboat, but a sail car?
01:02:39 No, I don't.
01:02:40 Oh, maybe I did actually see that.
01:02:42 Yeah.
01:02:42 I think I did.
01:02:43 That one's very good.
01:02:44 It's been a while.
01:02:44 Yeah.
01:02:45 I'll see if I can find the channel and put it up in the show notes for people.
01:02:49 Yeah.
01:02:49 All right, Al.
01:02:49 I think with that, we probably should call it for time, but very interesting.
01:02:54 People don't actually recommend you go try to break the bungee dunk record.
01:02:59 Yeah, no.
01:03:00 Do something else.
01:03:01 But if you do, it is fun to watch.
01:03:03 Yeah.
01:03:03 Make a good model.
01:03:04 Exactly.
01:03:05 Make a good model and let us know.
01:03:08 We'll share it, but we don't recommend it.
01:03:10 All right.
01:03:11 Final two questions before we get out of here, Alan.
01:03:14 You're going to write some Python code.
01:03:15 What editor do you use?
01:03:16 I'm using mostly Jupyter Notebooks, but also a little bit of VS Code.
01:03:22 Okay.
01:03:22 For Notebooks, is it straight Jupyter?
01:03:24 Is it JupyterLab?
01:03:25 I just had JupyterLab 4.0 come out, which is a big update.
01:03:28 I know.
01:03:28 And every time JupyterLab gets better, I think now's the time for me to make the switch, but I have
01:03:34 not.
01:03:34 And partly it's familiarity and partly as a teaching environment.
01:03:38 I prefer a simple environment with the minimum distraction.
01:03:41 Sure.
01:03:42 That's certainly valid.
01:03:43 All right.
01:03:44 Then notable PyPI package, or Conda package, if you prefer.
01:03:48 Right.
01:03:49 Well, I have to say the SciPy, NumPy, Pandas, those were the primary things I was using
01:03:55 for this book.
01:03:57 And then maybe a shout out to Pint, which I, you know, as I said, I think it's not quite
01:04:01 doing everything I want, but I think it's a really great tool.
01:04:05 Excellent.
01:04:05 Yeah, I agree.
01:04:06 All right.
01:04:06 People are interested.
01:04:07 They want to check out your book.
01:04:08 I'll put the link in the show notes.
01:04:11 There's Jupyter Notebooks up on Google CoLab.
01:04:14 If you're feeling brave, you can create your own virtual environment, install them locally
01:04:18 and run them there as well.
01:04:19 That works too.
01:04:20 Anything else you want to say?
01:04:21 How people get started with this book?
01:04:23 The idea is to just get you into it.
01:04:25 There are some case studies and a lot of chances to take whatever system you're interested in
01:04:30 and apply these tools.
01:04:32 So I hope people enjoy it.
01:04:34 And if you do anything interesting with it, let me know.
01:04:37 Sounds good.
01:04:37 Well, thank you for being here.
01:04:39 And thanks to everyone for listening.
01:04:40 Thank you.
01:04:41 This has been another episode of Talk Python to Me.
01:04:44 Thank you to our sponsors.
01:04:46 Be sure to check out what they're offering.
01:04:48 It really helps support the show.
01:04:50 InfluxData encourages you to try InfluxDB.
01:04:53 InfluxDB is a database purpose-built for handling time series data at a massive scale for real-time
01:05:00 analytics.
01:05:00 Try it for free at talkpython.fm/InfluxDB.
01:05:04 Are you ready to level up your Python career?
01:05:08 And could you use a little bit of personal and individualized guidance to do so?
01:05:13 Check out the PyBytes Python Developer Mindset Program at talkpython.fm/PDM.
01:05:20 Want to level up your Python?
01:05:22 We have one of the largest catalogs of Python video courses over at Talk Python.
01:05:26 Our content ranges from true beginners to deeply advanced topics like memory and async.
01:05:31 And best of all, there's not a subscription in sight.
01:05:34 Check it out for yourself at training.talkpython.fm.
01:05:37 Be sure to subscribe to the show.
01:05:38 Open your favorite podcast app and search for Python.
01:05:41 We should be right at the top.
01:05:43 You can also find the iTunes feed at /itunes, the Google Play feed at /play,
01:05:48 and the direct RSS feed at /rss on talkpython.fm.
01:05:52 We're live streaming most of our recordings these days.
01:05:55 If you want to be part of the show and have your comments featured on the air,
01:05:59 be sure to subscribe to our YouTube channel at talkpython.fm/youtube.
01:06:03 This is your host, Michael Kennedy.
01:06:05 Thanks so much for listening.
01:06:06 I really appreciate it.
01:06:07 Now get out there and write some Python code.
01:06:09 I really appreciate it.
01:06:30 Thank you.