I’m doing Advent of Code 2022, and Day 16 was - in the parlance of our time - a doozy. The problem presents a cyclic graph with each edge costing 1 second (weight of 1), and nodes have state (on or off), it takes 1 second to turn the node from off to on (default off), and when a node is on it contributes a certain amount of benefit each following second. You have 30 seconds to get as much benefit as possible (function maximization).
AWS Lambdas are some of the original “serverless computing” implementations. These little bits of code run when you hit an API endpoint, taking whatever inputs you provide and returning the output. They can be written in many programming languages, including my favorite: Python 3.
So I wondered - could I use this to build a simple little proxy at a URL? Why not, right? They can run any Python code… If I wanted to, I could use the result to evade perimeter firewalls that might be blocking many arbitrary destination hosts, but not AWS assets. It’s not uncommon for enterprises to block sites based on host or URL, but most still need users to be able to get work done. AWS is infrastructure that powers many other sites - so I suspect that most organizations have to let it get through.
I’m teaching a Python class which acts as an introduction to programming, for most of the students there. This is an awesome experience - for me personally because I enjoy this, and for my resume. I hope to do this full-time someday, but today I’ve just got 3 sections of the same class.
We’re doing a lot of cool things that I should write about some other time - one of them is using a free, open source textbook called, Runestone - How to Think Like a Computer Scientist. It’s interactive for students, so not only is it free for them but it’s also a better resource.
File "asdf.py", line 2
print("Result is: {}".format(result))
^
SyntaxError: invalid syntax
result = ((5*10) +15print("Result is: {}".format(result))
Two lines of code… Syntax error on the print line, evidently. But where? That line looks so simple and correct! And pointing directly at the t?
Well - it’s not really on the print line. Folks who have done any amount of programming will look at the preceeding line fairly quickly and notice the missing parenthesis.
META: Part 1 describes the problem I’m trying to solve here.
I need a way to monitor water flow through my water filter over several days, and I don’t want to sit and watch it.
So - I took a Raspberry Pi I’ve got and a little Python and hacked a solution together. The basic idea was that I’d position a plastic cup below the output stream of the waste water, I’d put two wires into the cup, I’d put a voltage on one wire and attempt to see the voltage on the other. I’d use the Raspberry Pi to check for the voltage once per minute and log the status to a file with a timestamp. Later, I could graph the state of the voltage - DETECTED or NOT DETECTED - over time, and produce a graph showing when the waste water was running. With that I could even get an approximate flow rate waste water, if I wanted, by measuring how long it takes to output a liter of waste water and multiplying by run time.
I’ve been writing a lot of Python lately, and there are some things I love about it, some things I’m uncomfortable with, but nothing I hate. The super() builtin function makes life a lot easier when you’re using Python for object oriented code and have some inheritance going on. This blog post describes the best way I’ve seen it used so far.
First of all, in Python3 you no longer need to write “super(CurrentClass, self).foo”, “super().foo” does the right thing generally. This is great, because it’s easier to change class names, or copy a line of code, without breaking everything.