Benjamin Geck


The Goal

I recently started diving into machine learning and in particular how I can use some of the new work in the field of style transfer to make cool pictures! I love cool pictures!

Anyway, I come from a Javascript background and in particular a Node.js / NPM background so I'm used to things like package.json being able to have specific versions of libraries on a per project level.

As I started looking into machine learning, I realized that a lot of the really high-quality work being done on this front is done in Python. I haven't worked with Python a ton, but am always looking to grow my general coding skills so I went about figuring out how to have the same type of tooling setup as I do in Javascript based projects.

What I Figured Out

The main thing I learned, in my quest for a nice clean "package system" for Python was that Python has a similar system to packages using virtual environments to separate project code.

After setting this up you can create specific virtual environments that have their own set of libraries installed for just that environment, and then define in the project which environment to use. You can also create a requirements.txt file that works very similarly to package.json and lets you define libraries to be installed as dependencies for a project and install them with a few simple commands.

My Setup

I use Visual studio code to do most coding these days. It's got all kinds of great tools for improving the quality and organization of your code.

Tool 1: Visual Studio Code Command Line

After installation, launch VS Code. Then open the Command Palette (F1 or ⇧⌘P on Mac) and type shell command to find the Shell Command: Install 'code' command in PATH command.

Tool 2: Homebrew

For me on a Mac, Homebrew is a must have tool for coding. Standing on the shoulders of giants, I don't have to figufe out how to port things from linux manually. Getting most common programming tools is as easy as

1brew install [a thing]

Tool 3: Fish Shell with Oh My Fish! extension

I use the Fish shell instead of Bash because it brings more joy into my life to see the little fish at the prompt! Also it has some nice autocompletion features and history bits that are nice and time-saving.

1brew install fish2curl -L | fish

Ok, now on to the meat and potatoes! After the tools were installed, this is how I setup Python.

Install pyenv

1brew install pyenv2brew install pyenv-virtualenv3code ~/.config/fish/

Add some lines to

1export PATH="/usr/local/sbin:$PATH"2export PIP_FORMAT=columns3status --is-interactive; and source (pyenv init -|psub)4status --is-interactive; and source (pyenv virtualenv-init -|psub)

And that's about it. Now with some simple commands you can do all the things! The main commands to remember are as follows:

New super powers!

Install a version of Python you want to use.

pyenv install 3.6.2

Make a virtual "copy" of that version of Python to use with just a specific project.

pyenv virtualenv 3.6.2 machine-learning-3.6.2

In project folders Set a .python-version file which will tell your system to automatically switch to your project Python version whenever you are in that folder.

pyenv local machine-learning-3.6.2

Grab any libraries you've installed with pip and create the equivalent of a "package.json".

pip freeze > requirements.txt

Then whenever you want to share the project, someone else can do the same setup, and run a command to the equivalent of NPM install.

pip install -r requirements.txt

Copyright © 2023 Benjamin Geck