We live in a time when everyone knows how to program, or perhaps everyone thinks they should know how to program. I don’t fully disagree, programming is a wonderful tool for efficiency in a digital medium. And I don’t fully agree - not everyone is suited by temperament or interest for programming. Just as there are many kinds of artists and many kinds of scholars, good “programming” is founded on solid logic, intuitive design, and an understanding of needs and requirements. Not everyone is interested in those things - some people simply want tools that work.

I've worked with a lot of picked-it-up-one-weekend programmers, the first-idea-is-best programmers. I've dug into their code and rewritten it to be readable (sometimes), or extensible (often), or sane (on a truly good day). I've led conversations on requirements and user and developer needs and feasible versus ideal solutions. Along that road, I’ve found that I’m passionate about solutions and code and tools being good for goodness’ sake. I suppose I’ve found that I consider technology to be its own art form.

So if you were trying to define my style, you could say I'm not a particularly impulsive coder. You could say I like to look before I leap, or that I like to understand a problem before I solve it. I guess, if you want, you could say I'm not like everyone who picks up a little coding along the way.

In real life, neither style is always right - or always wrong. Some situations call for more speed and decisiveness, some more careful planning, some a balance between complete and done. Many technical people I know understand this intuitively and deeply and then will argue away about the precise tradeoffs of one or the other. My interest in aesthetic philosophy aside, this page is to explain a little more about my programming skills, interests, and experiences.

Technical Direction at Animation/VFX Studios

All of the large scale projects are behind NDAs, of course. So I won’t post them on the internet, sorry. Movie and VFX Studios are understandably protective of creative and intellectual property.

To get a snapshot of life as a TD, I thought I’d share examples of the kinds of projects a TD at a largish studio might solve.

On any given day, a TD will need to:

  • Debug a Render - the image the artist is trying to produce could just look wrong, or could be failing all together. This could involve verifying data from multiple departments, searching logs for mysterious error statements (many of which are ignorable), trying multiple versions of multiple pieces of software, trying to reproduce in a simple case a problem for other engineers, searching a bug database for things that sound similar, or lastly, branching code to find an error. Since images are the primary deliverable of all departments, these are usually time-sensitive, high pressure tasks, involving a quick patch, a working fix, a long term solution, and a judgement call on which is most appropriate.

  • Add a Feature - in large studios, nearly all of the technology is proprietary. Every film pushes the envelope of what's possible, and every team has a preference for how they would like to work. Adding a feature in such a place could involve everything from identifying who is responsible for the tool, logging a request and representing artist's needs and wishes to engineers and testing and verifying the feature is delivered as expected. It could also involve creating a lightweight workaround for a particular pain point from scratch, or designing the feature, getting approval and implementing it and managing artist expectations. It could involve knowing enough about the tool to suggest and teach a more effective workflow, and not adding a feature at all.

  • Fix a Bug - similar to the first two, the scope of fixing bugs as a TD is wildly variant. One day it's an obvious typo in a barely source-controlled script, another it's an inherent flaw in a core tool used by several departments or films. What, how, and who are all judgment calls of the TD, balancing the needs of the user against the risks and benefits of a fix.

  • Make a Tool - among my favorites, making a tool is just that. Diving deep into an artist or department's workflow and needs, and design and build something that makes their work smoother or easier, with both them and everyone who will need to add to or fix the tool in the future. The trick with making the tool is never just saying yes and starting, it's always deciding whether a tool is right or a feature on another is sufficient. 'Tools' are everything from one page scripts that run on a command line to full-fledged GUI's that integrate with existing packages to workflows that span departments and the tools to support them.

Other Projects

After several years working primarily on python scripts in vim, I missed IDEs, modern problems, and I was curious about modern libraries. I did some work to help update an iPhone app to iPad, and worked on another in my spare time. 

School Projects

  • Computer Vision (C++)

    • panorama stitching

    • (rudimentary) facial recognition

    • photo editing (painting and filtering)

  • Graphics projects - hierarchies, transforms, basic effects (C++)

  • Data Structures - splay trees, heaps, etc. (Java)

  • Programming languages (mL, Scheme/Lisp, Ruby)

  • Introductory programming - small projects, but I was also a TA so I did them several times, taught, tutored, and graded them as well.