A Practical Guide to 'Vibe Coding' with Claude and MCP Tools

…Or: How I learned to stop worrying and love Skynet

Introduction: The Philosophical Foundations of Human-Computer Interaction, and It's Consequences

"Everyone designs who devises courses of action aimed at changing existing situations into preferred ones."

Herbert A. Simon

In 1945, as World War II drew to a close, Vannevar Bush (no relation) published his landmark essay "As We May Think". Vannevar had just witnessed a fundamental shift in warfare with the advent of atomic weaponry; academics, mathematicians, scientists were now responsible for delivering the most unimaginable physical power to humanity in the form of two bombs dropped on populated cities in Japan. I don't mention this for dramatic effect, but because I really want to believe that sometimes a nightmarish event compells us to dream of better things.

Bush envisioned technology's alternate path—not as a tool of war, but as an extension of human cognition. *"Man has piled up a staggering body of knowledge—so staggering, in fact, that men of learning have great difficulty in finding and using the parts they want. It is the task of science to make this store of knowledge more available, to aid the human memory."

Bush's vision of the "memex," a desk-sized mechanical device for storing and retrieving information through associative trails rather than hierarchical indexing, recognized that "the human mind operates by association" (Lemelson-MIT, 2015). This fundamental insight—that technology should complement human cognitive patterns rather than forcing humans to adapt to machine logic—planted the seed for what would become a revolution in human-computer interaction. And to at least some degree, what we're seeing today are the realizations of these dreams in the form of the internet and AI.

And, I think we're in big trouble.

Today, nearly 80 years later, in 2025 I read this headline:

Trump Accused of Using ChatGPT to Create Tariff Plan After AI Leads Users to Same Formula: 'So AI is Running the Country'

'Guys, they're setting U.S. trade policy based on a bad ChatGPT question that got it totally wrong,' a former journalist posted

So, now that we're potentially entering into the AI dystopia, I thought I might share some thoughts about a more positive vision for the future, and how we can use AI more responsibly that this. The bar is fucking low, apparently.

*PLEASE NOTE: I cannot guarantee that the advice I offer in this post won't also result in a global financial meltdown, or wipe out $2.5 trillion in a single day. I could be getting a lot of things wrong, and there are many people who are way smarter than me who could probably tear up a lot of what I say here.

Fifteen years after Bush's essay, J.C.R. Licklider built upon that foundation with "Man-Computer Symbiosis" (1960), arguing for "very close coupling between the human and the electronic members of the partnership" (Licklider, 1960). His vision wasn't merely technical but aspirational: "human brains and computing machines will be coupled together very tightly, and that the resulting partnership will think as no human brain has ever thought" (Licklider, 1960).

Licklider outlined two primary aims: "to bring the computing machine effectively into the formulation parts of technical problems" and "to bring computing machines effectively into processes of thinking that must go on in 'real time'". His vision was not of machines replacing humans, but of machines complementing human capabilities—handling the "routinizable work" while humans set goals, formulate hypotheses, and perform evaluations.

Douglas Engelbart crystallized these ideas in his 1962 report "Augmenting Human Intellect: A Conceptual Framework" for the Air Force Office of Scientific Research. Rather than proposing a specific technical solution, Engelbart offered "a new way of thinking, communicating, collaborating and learning inside the relationship between human and computer machines". For Engelbart, the true potential lay not in isolated human-computer interactions but in networked systems enhancing "human collective capability to solve complex tasks and handling information".

These pioneering thinkers shared a common thread: the recognition that human intelligence has biological limitations that computation can extend—not replace—through enhanced storage, calculation, transmission, and repetition capabilities. Their work established the intellectual foundation for what we now call human-computer interaction (HCI), a field dedicated to designing systems that complement human cognition rather than competing with it.

Today, with the rise of AI, we find ourselves revisiting these foundational ideas. The revolutionary aspect of AI is its potential to reduce the latency between "I want a computer to do a thing" and "A computer is now doing a thing." As Ray Kurzweil argues in "The Singularity Is Nearer", this reduction in latency brings us closer to an explosion of intelligence—not by replacing human thought, but by amplifying it.

At its core, AI serves as a communication bridge—a translator of human intent into machine action. This isn't a revolutionary concept so much as the next logical evolution in a lineage that stretches from punch cards to command lines to graphical interfaces. Each iteration has attempted to solve the same fundamental problem: how do we communicate our intentions to these glorified calculators in a way that doesn't make us want to throw them out the window? How can I get to a point where this "clock with benefits" is useful to my specific situation?

There's a delicious irony that after more than 40 years of GUI-based computing—all those pretty icons and windows designed to shield us from the arcane incantations beneath—AI interfaces are dragging us back to text-based interaction. It's like watching fashion cycles repeat; suddenly command lines are vintage chic again, only now they understand plain English instead of cryptic Unix commands. Who knew 1980s HCI would go come back into style?

Programmers, of course, never abandoned the keyboard altar. They've spent decades perfecting the art of text-based intent transmission, sacrificing their wrists and social lives to the god of syntax. This might explain their skepticism toward AI coding assistants—imagine spending years learning this incredibly difficult skill, only to see low-effort 'Vibe Coders' come out of the woodwork with their projects compiling and running successfully, and not even being able to explain why it works, but being happy with the results. The nerve!

For those who sacrificed so much—spending maybe years or more of their one precious life oscillating in and out of goblin mode, debugging weird recursion problems only to find out that the root cause is because a bracket got misplaced ten steps back—of course this can naturally feel really unfair. I empathize deeply with this feeling. Growing up in Utah in the 1990s, I was constantly reminded of the sacrifices of the pioneer Mormons: who braved the west plains toward the Salt Lake valley, leaving everything behind, taking only what they could carry. Many died along the way. Imagine if one day those same people woke up to the roaring noise of a passenger jet flying overhead on its way to Los Angeles.

Right now, at thirty-thousand feet of altitude and a speed of more than 500 miles an hour, some little brat with an iPad is mindlessly crushing virtual candy while eating a snack, complaining about the six hour flight. We never really know how good we have it.

For non-programmers, however, this shift represents nothing short of liberation. The barriers to entry—learning syntax, memorizing libraries, understanding design patterns handed down like sacred scrolls—have been dramatically lowered. It's the difference between needing to be fluent in Japanese to visit Tokyo versus having a really good translator in your pocket. Suddenly anyone can say "build me a website that looks like this" without first sacrificing a decade to the craft.

Late last year I began experimenting with "Vibe Coding" using Claude and MCP Tools, I've explored this new frontier of human-computer collaboration, where the most critical skill hasn't been mastering syntax or memorizing APIs, but communicating clearly and logically in an ongoing dialog with an LLM. Though this process, I've seen how these tools fulfill the vision that Bush, Licklider, and Engelbart articulated decades ago—not by making humans obsolete, but by extending our inherent capabilities through partnership with machines.

How to Get Started

Why Claude?

You might be wondering why, in this golden age of AI assistants—where new models pop up faster than coffee shops in gentrifying neighborhoods—I'm specifically recommending Anthropic's Claude. This isn't a brand loyalty thing, but the results of an embarrassingly long stretch of experimentation with other models. I've done the digital equivalent of speed-dating and Claude is the one that I'm considering moving in with. It's been the most fruitful relationship by far.

In all seriousness, Claude stands out for two critical reasons. First, its reasoning capabilities are genuinely impressive—it doesn't just hallucinate wildly when faced with complex coding tasks, which is refreshing. Their latest model (Sonnet 3.7) is a fantastic thought partner and has a generous context window and output length.

Second, and perhaps most importantly for our "Vibe Coding" adventures, Claude has embraced the Model Context Protocol (MCP), an open standard that allows Claude to interact directly with your development environment and file system. This isn't just a luxury or a minor convenience bump—it's revolutionary. Imagine having an eager (but occasionally confused) software developer who can not only advise you on code structure, libraries, frameworks, and best practices, but who will actually read and modify files in your project for you. Oh, and this developer types at over 200 wpm. That's what MCP Tools bring to the table: an invitation to have Claude to take the driver's seat and make changes to your project.

Installing the Claude Desktop App

Step one is getting Claude installed on your computer. Claude's desktop installation is refreshingly straightforward if you're using Windows or macOS:

  1. Visit Claude's download page to grab the latest version for your operating system. The desktop app is free, and a paid plan is highly recommended.

  2. Double-click the installer file you've downloaded.

  3. Follow the prompts, and setup your anthropic account if you haven't already.

  4. Launch Claude from your Applications folder or Start menu.

  5. Sign in with your Anthropic account (or create one if you haven't already joined).

Once installed, Claude sits in your system but doesn't really do anything you couldn't just as easily do in a browser: you can chat with it. You can share files, etc., but that's about it. Adding MCP Tools is the justification for having the app, so this is still necessary and important.

Setting Up MCP Tools

MCP (Model Context Protocol) is the digital glue that connects Claude's brain to your computer without the friction of manually copy/pasting back and forth, or having to share individual files. While working at General Motors, we often spoke with admiration for Toyota's scientific approach to manufacturing and their concept of the “Eight Wastes” of Lean, where transportation and motion are two types: • Transportation waste = unnecessary movement of materials/products. • Motion waste = unnecessary movement by people (walking, reaching, searching).

Likewise, a lot of time is wasted with AI coding when you constantly have to spoonfeed snips of code to an AI assistant. With MCP Tools, you drastically reduce these two forms of waste (searching for a particular file or line of code in a file, copying and commenting, pasting back, fixing problems caused by inserting revisions and making line edits).

The genius of MCP lies in its server-based architecture. Each "MCP Server" is a specialized tool that gives Claude access to specific capabilities—like reading your filesystem, controlling a web browser, or even manipulating your code directly in VS Code.

To get started, we should thank Ani Betts, the "Margot Tenenbaum as software developer" who created a wonderfully simple way to install MCP servers right from within Claude's own chat interface. Her mcp-installer is the Swiss Army knife we all needed but didn't know to ask for.

Here's how to get it running:

  1. Configure Claude for MCP:

    • Locate your Claude Desktop configuration folder:

      • On macOS: ~/Library/Application Support/Claude/

      • On Windows: %AppData%\Claude Desktop\

    • Create or edit the file claude_desktop_config.json

    • Add the following configuration (this installs Ani's MCP installer):

    {
      "mcpServers": {
        "mcp-installer": {
          "command": "npx",
          "args": [ "@anaisbetts/mcp-installer" ]
        }
      }
    }
    
  2. Restart Claude Desktop to apply the changes.

  3. Install the Filesystem Server: Once Claude Desktop is running with the MCP installer configured, you can simply ask Claude to install more servers. Start with the filesystem server:

    Hey Claude, could you please install the @modelcontextprotocol/server-filesystem package as an MCP server? Use ['/Users/myusername/Documents', '/Users/myusername/Projects'] for the arguments.
    

Replace the paths with directories you want Claude to have access to; on macOS it should look something like this:

    "server-filesystem": {
      "command": "npx",
      "args": [
        "@modelcontextprotocol/server-filesystem",
        "/Users/your_username/your_project_directory"
      ]
    },

Claude will use the MCP installer to download and configure the filesystem server, giving it access to read and modify files in the directories you specified ModelContextProtocol, 2025.

Once you've set up these basic tools, you've officially entered the "Vibe Coding" ecosystem. You can now ask Claude to examine your code, create new files, modify existing ones, and generally act as your digital coding partner.

But before you unleash Claude on your precious codebase, let's talk about giving it some guidance. After all, even the most brilliant assistant needs direction to be truly effective.

The MCP Tools Ten Commandments

Let's get one thing perfectly clear: Claude is a technological marvel, but it's still an AI. And like that one friend who's brilliant but insists they code better after a couple of beers, Claude sometimes needs guardrails to prevent it from going off on spectacular but utterly unhelpful tangents.

Claude Sonnet 3.7 is genuinely impressive at understanding and generating code—it can draft entire applications, debug complex issues, and even write tests that actually work (a minor miracle in itself). But when given access to your filesystem through MCP Tools, Claude transforms from "helpful chat buddy" to "enthusiastic intern with admin privileges to your production server." What could possibly go wrong?

See, Claude has this charming tendency to make confident assumptions about your project structure that bear absolutely no resemblance to reality. It might decide that your meticulously crafted React application would really shine if it were suddenly rewritten as a Django project. Or perhaps it'll helpfully create a new file in a directory that doesn't exist, then stare at you with the digital equivalent of a puppy that's just shredded your tax documents.

Before you dive into project modifications with Claude, establish clear boundaries through proper communication. This isn't just polite—it's self-preservation. Spend time discussing your goals, the overall architecture, and specific changes you want to make. Get Claude's buy-in on the approach, listen to its suggestions (which can be surprisingly insightful), and only then proceed to actual file modifications.

But here's where the real magic happens: I've developed a set of instructions I call "The MCP Tools Ten Commandments." When it's time for Claude to make actual changes to your codebase, simply paste these commandments into your conversation. They serve as the digital equivalent of those safety briefings before skydiving—a reminder that while this experience could be amazing, certain protocols must be followed to avoid becoming a cautionary tale.

Without further ado, here are The Ten Commandments that will transform Claude from a well-meaning chaos agent into your most productive coding partner:

****The MCP Tools Ten Commandments:****

1. When using MCP Tools to make changes to the project, always adhere to these commandments.

2. ALWAYS use directory_tree, search_files, list_directory and get a detailed understanding of all relevant files and directories before attempting to write_file at path. Avoid assumptions, verify and know the project's actual contents.

3. NEVER attempt to use write_file or edit_file without first verifying the destination path exists. When it is necessary to create a new directory, use create_directory. This MUST be done before creating a file at destination path.

4. MCP Tools allows line edits with edit_file. Whenever practical, make line-based edits. Each edit replaces exact line sequences with new content. Returns a git-style diff showing the changes made. When editing a file, make sure the code is still complete. NEVER use placeholders.

5. ALWAYS check and verify if a file already exists before attempting to write or edit a file. If file exists, use read_file to read the complete contents of a file. For files that include "import" or otherwise reference other files, use read_multiple_files to read the contents of multiple files simultaneously. This is more efficient than reading files one by one when you need to analyze or compare multiple files.

6. If write_file is being used, the entire file's contents must be written. ALWAYS write complete code and NEVER use placeholders.  

7. When updating CHANGELOG.md always use edit_file.

8. When updating other documentation (e.g., README.md) always use edit_file.

9. When important decisions about architecture, design, dependencies, or frameworks need to be made, please discuss options with me first. Weight the pros and cons and then tell me which option you believe is best and the reason why.

10. If and when command lines need to be entered into VS Code terminal, please provide the full path as well as the exact commands to execute. Wait for me to share back the response before proceeding.

These commandments aren't just arbitrary rules—they're hard-won wisdom from countless hours of watching Claude confidently delete entire directories or create files in the wrong place while maintaining the cheerful demeanor of someone who thinks they're helping. Every time this sort of thing happened, I would pause our collaboration and ask: "Tell me, why do you think you made this mistake?" and then follow up with "What could I have told you beforhand that would have prevented that mistake? What rule should you have followed?"

This strange loop of critical analysis sharpened Claude's abilities and reduced the chances of reverting changes outright—often after wasting tens of thousands of tokens.

The commandments address the most common pitfalls:

  • Claude's tendency to write files without checking if the directory exists

  • Its habit of using placeholder comments rather than complete implementations

  • And its enthusiasm for making architectural decisions without consultation

By enforcing these simple rules, you transform Claude from a chaotic neutral force in your development process to a reliable partner that actually accelerates your workflow rather than generating new tickets for your backlog.

Consider adding the Ten Commandments to your project as a text file so that Claude can easily reference them in context during your conversations. And don't be shy about reminding Claude about them—despite its impressive capabilities, it still sometimes acts as though it has the short-term memory of a goldfish, or seems to no longer feel the rules matter. Like religious indoctrinication and ritual, repetition is key.

With these guidelines in place, you're ready to start your Vibe Coding journey in earnest. But there are a few more considerations that can help you make the most of this new workflow.

Other Considerations

Sharing your project structure with Claude is essential, but efficiency matters too. Don't dump your entire directory tree if it contains thousands of files and folders that Claude doesn't need to see. Instead, prune it to the essentials: tree -I "*.log|node_modules|data" -L 8 > project-tree.txt will create a manageable snapshot that excludes irrelevant files while providing enough context for Claude to understand your project organization.

Claude's strengths lie in understanding the big picture and implementing specific solutions, but it can still make mistakes. Commit your changes often, and favor small, incremental improvements over ambitious feature implementations. This approach not only makes it easier to track and revert changes if needed but also aligns with sound software development practices regardless of whether you're working with AI or human collaborators.

Documentation becomes even more important when working with AI. Claude can help generate and maintain it, but you need to explicitly request this. When starting a new task, ask Claude to review your existing project documentation first:

Using MCP Tools, please review the following:

/Users/project/CHANGELOG.md
/Users/project/project-overview.md
/Users/project/README.md

Context is King: How to Actually Talk to Claude

Let's be honest, Claude isn't a mind reader (though it sometimes pretends to be). Without proper context, it is directionless but dedicated—it will eventually pick an arbitrary direction and go HARD at top speed. This is because Claude operates in a strange liminal space where it simultaneously knows nearly everything about programming and absolutely nothing about your specific project or intent. I've found that this problem is slightly worse with Sonnet 3.7, but your mileage may vary.

Here's where most people screw up gloriously: they drop a vague request like, "Fix the login bug, the error message says (BLAH, BLAH, BLAH,...)" into Claude's lap and then act shocked—SHOCKED I TELL YOU—when Claude generates a solution for an entirely different authentication system than the one they're using. This is the digital equivalent of rolling your car into the auto-shop yelling "IT MAKES A FUNNY NOISE!" and then feeling swindled by the mechanic when the funny noise still isn't fixed.

If you want Claude to be your coding co-pilot, then be specific and don't leave much to guessing. Here's what you should explicitly cover:

What Are You Actually Trying to Do Here?

Start by clearly articulating your goals. Are you building a new feature? Fixing a bug? Refactoring legacy code? Claude needs to know the desired outcome, not just the immediate task. This helps it make decisions that align with your broader objectives rather than just slapping a band-aid on whatever problem is directly in front of it.

For example, don't just say "I need a login page." Instead, try: "I'm building an enterprise SaaS application that requires secure authentication. The login page needs to support SSO via Google Workspace and Microsoft Entra ID, with fallback to email/password authentication."

What Have You Already Done (or Tried)?

Nothing exists in a vacuum—except, you know, the actual vacuum of space—or the void in the heart of man. Claude needs to understand what you've already built or attempted. This provides crucial context that prevents it from either reinventing the wheel or building a solution that's incompatible with your existing work.

Be specific about previous approaches you've tried: "I already implemented JWT authentication but ran into issues with token expiration handling across browser tabs. Here's the current implementation/documentation: [file path]"

Where Are You Stuck (a.k.a. Your Spectacular Failures)?

Your failures are Claude's treasure map. Detailing where you've run into issues (and why) helps Claude avoid the same pitfalls. This isn't just about the technical errors—explain your conceptual struggles too.

"I'm having trouble with the state management approach. When a user navigates between pages, the authentication token is preserved, but their selected preferences are reset. I suspect it's related to how I'm structuring the Redux store, but I'm not sure."

What's Your Tech Stack Prison Cell?

Nothing cripples Claude's helpfulness faster than generating a beautiful solution in a technology you can't or won't use. Are you committed to specific frameworks, libraries, or architectural patterns? Does your boss have an irrational hatred of certain technologies? Is your team allergic to functional programming?

"This needs to work within our existing React/TypeScript frontend and Express.js backend. We're using PostgreSQL for data storage and have standardized on Tailwind for styling. No jQuery allowed—the last developer who tried to that quit last year."

CURRENT STATE vs. DESIRED STATE: The Before and After Glow-Up

Returning to that quote at the top by Herbert Simon:

"Everyone designs who devises courses of action aimed at changing existing situations into preferred ones."

Emphasis mine.

One of the most effective ways to communicate with Claude is to clearly define the current state versus the desired state. This concrete framing gives Claude a precise understanding of the transformation you're seeking.

"CURRENT STATE: Our application requires users to re-authenticate every 2 hours, disrupting their workflow and generating support tickets.

DESIRED STATE: Authentication tokens refresh automatically in the background, maintaining the user's session for up to 8 hours of activity without visible interruption."

Ask Dumb Questions (Yes, Really)

Channel your inner five-year-old and ask questions that seem embarrassingly obvious. "What exactly is JWT authentication?" "How does React handle component re-rendering?" "Why is maintaining state across page refreshes challenging?"

This Socratic approach forces Claude to articulate fundamental truths and assumptions that might otherwise go unstated. It's not just about getting answers—it's about establishing a common understanding. Plus, if Claude can't explain a concept clearly, that's a red flag that it might not fully understand the domain, which is valuable information for you.

The beauty of this approach is that it creates a sort of dialectic—Claude might respond with its own questions or observations that lead you both to insights neither of you would have reached alone. It's like pair programming, except your partner never needs coffee breaks or insists on telling you about their weekend rock climbing adventure when you're trying to debug a critical production issue.

Remember: Claude would rather have too much information than too little. Your meticulously detailed context won't annoy it—it doesn't have feelings to hurt or attention to waste. So go ahead, overexplain.

This entire approach to "Vibe Coding" represents a profound shift in how we interact with computers. We're no longer adapting our thoughts to the rigid syntax of programming languages; instead, we're expressing our intentions in natural language and letting AI bridge the gap to executable code. In doing so, we're finally realizing the vision that Bush, Licklider, and Engelbart laid out decades ago: a true partnership between human creativity and machine capability.

Final thoughts

Stepping back and looking at the implications of AI assisted coding, here are the things I've learned at a high-level:

  1. For the rest of your life, the current state of AI is the most primitive it will ever be.

  2. This is still an emerging field, and what's true right now might not be in the next few months or years at most. (I'm excited to think about how irrelevant this post will be by 2030, assuming that we don't see total collapse in the next 5-ish years, that is.)

  3. Be patient with the technology and with yourself as you learn to communicate effectively with your AI partner. I don't want to come across as overly sentimental, but I do regard this interaction as being a form of a relationship—but not in the same sense as in the 2013 film, Her. Cultivate the relationship through introspection and outward curiousity. Learn about how your own communication flaws are impacting the two of you, and seek understanding. Just like in a marriage, the skills you develop—clear communication, systems thinking, and pragmatic problem-solving—will serve you well regardless of how AI tools evolve in the coming years.

Resources

Week 15: Final Project Update

This will be my final update for the Studio II project. I feel a complex blend of emotions as I write this. I am relieved to be done. I am also sad to know that my time with this team has come to an end. I consider myself incredibly lucky to have spent so much time working with some truly amazing designers. I don’t know if I will ever experience anything like this again, but I hope so.

Remote collaboration has few perks, and I was lucky to be working with folks who helped to make this experience so much fun

Remote collaboration has few perks, and I was lucky to be working with folks who helped to make this experience so much fun

The work we have done this week feels different for many reasons. We had to prepare something for a large and diverse audience, not all of which knew or were familiar with the context of our work. Additionally, we also needed to use this time to tie up remaining loose ends—we needed to reach an end state where our process could feel somewhat conclusive.

Our efforts were just as collaborative as ever, as we divided up the labor of our remaining tasks. I was incredibly reassuring to know my team members strengths and capabilities. Knowing who was working on a particular task was reassuring. For my part, I was busy scrubbing through a timeline in After Effects, rapidly assembling visual representations and edited footage to make a convincing newscast from the future. Considering the constraints of remote collaboration, I’m very pleased with the final product.

I have continued to ruminate about over this notion that the future is something we cannot predict, but rather something we build through imperfect knowledge. I question the power our team has to influence this process, not because I lack the confidence in our shared abilities —as I said earlier and often, I’ve been working with an amazing team— but more of a concern around consequences of inspiration. Our process was far from perfect. The vagaries of a pandemic distorted every effort. The educators we sought to connect with were terribly busy. Our own team suffered from fatigue and sleeplessness as we juggled future careers and other academic expectations. The complexity of this topic is well beyond the scope of fifteen weeks of diligent inquiry.

I cannot speak for the entire team, but I know that for me personally our exploratory research was the most intimidating phase. It was immediately clear that we were engaging in a very difficult problem. Education intersects with so many other areas of study. It is a problem of policy, culture, funding, methodologies, and it is weighed down by a history of systemic inequality and racism. Generative research methods were the biggest surprise. I was astonished by what could be gleaned through a participatory process. Including educators in the generation of concepts was exciting, and I wish we had more time to engage in this work.

Our final concepts are a reflection of many perspectives and early prototypes generated by K-12 educators

Our final concepts are a reflection of many perspectives and early prototypes generated by K-12 educators

Every phase also felt too short. We needed to move on before we could fully digest what we were learning. Nevertheless, I stand behind the work we have done, because I know it represents the best we had to offer. I’ve known that design is a messy process long before my time at CMU, but I now have a much clearer sense of what it means to engage with that mess and to assemble something coherent. This work is not easy, and it is never, ever truly complete. The deadlines for a design project function like the layers of silt in a fossil record. The strata of every layer represents a progression with no clear ending or beginning. We can always dig deeper.

I hope these artifacts will inspire others as they have inspired us.

Screen Shot 2021-05-14 at 8.14.32 PM.png

Our team has assembled a project homepage. There you will find more comprehensive information about this work, the final outcome and documentation. Check it out!

Week 11: qualitative evaluation of concepts

Our online survey is now underway, and while this virtual format isn’t exactly like so-called “speed dating,” we are hoping that it will be able to serve a similar purpose for our research. Creating a meaningful online experience for our participants was a tall order, especially with such tight constrains. There are many risks when created a fully automated and hands-off system. Not being there to clarify or to address questions or concerns in realtime was something we needed to accept as a trade-off. In exchange, we have a dozen unique participants ranging from 2 years to 27 years of experience, and from various districts around the country.

So far, the majority of responses have been from an online community of English teachers, so our data is skewed toward this perspective. On the plus side, English teachers provide excellent written responses. To avoid the pitfalls of statistics and quantitative analysis, we designed an online survey with open text fields, and we framed our questions around hypothetical scenarios. This would provide us with reflection and insights into how teachers imagine these concepts for themselves, and what perceived deficiencies come up for them in thinking about these systems in action.

Screenshot of survey responses, exported into a CSV file

Screenshot of survey responses, exported into a CSV file

The last 24 hours in particular have been very exciting, as we finally gained access to online educator communities. This process has been slower than wanted, but we first needed to fully develop our survey before we could deploy it. This process in and of itself was a design challenge. 

Last weekend, we decided to use the Tripetto platform. This gave us the same logic capabilities as TypeForm, but without any additional costs. It became clear almost immediately that we would need to prototype and refine our survey before receiving teacher feedback, and this effort was highly collaborative.

With multiple teammates, it was possible to divide this task into several areas that could be worked on independently and in parallel. We first decided on a basic structure  and strategized the division of labor. Carol worked on the text/content based on a logic diagram we crafted together. While Carol crafted this outline, I created a mockup version in Tripetto. Without access to finalized concept sketches, I took some poetic license.

Screenshot of 2nd iteration prototype survey

Screenshot of 2nd iteration prototype survey

As Carol and I worked together to refine the text copy, Cat and Chris worked together to create images and descriptive text for our participants. Once all of this content was ready for Tripetto, we began doing test runs, trying to break the experiences. This revealed some quirks with Tripetto’s logic functions and some of the less apparent features.

There are a few honorable mentions; Tripetto has a lot of subtle features that we often take for granted in other online experiences. Things like placeholder text, required fields, multiple choice radio buttons, checkboxes, multi and single-line text boxes. During the refinement phase, these features became essential and it was exciting to discover them—only after they were deemed essential enough to be worth the effort.

The minimalist UI of Tripetto made these features less evident, but not too hard to locate or execute. From start to finish, this experience felt a little shaky and uncertain but viable.

TripettoPrototypeFinal.png

I often found myself this week grinding away on the platform, slipping into a state of mind that Mihaly Csikszentmihalyi describes as “flow.” In other words, creating a survey on Tripetto wasn’t easy to use, but just challenging enough to keep me interested in working through obstacles. I think that what helped support this effort the most was building models within platforms where everyone on the team is already fluent. For us, this was primarily Miro, Google Docs, and Sheets.

Screenshot of two representations of the survey, carried across platforms (Miro and Sheets)

Screenshot of two representations of the survey, carried across platforms (Miro and Sheets)

First impressions matter, and we didn’t want to put out anything that wasn’t necessarily a work in progress. Even with this in mind, we did have a few last minute tweaks as we adapted our survey to maximize pulling power with other social media environments.

Arnold Wasserman’s desk critique was incredibly valuable for our team, as his feedback helped us to consider the importance of our survey as a communication tool. He recommended that we make the implicit, explicit, to directly communicate to our participants what we expected and why. We were encouraged to explain what questions we were asking, and to share this openly. This kind of transparency can be tedious, especially in text-based systems. I took this to task and simplified statements throughout the entire experience.

This gave the survey a personality all its own; like a casual and curious friend, we asked about specifics but with little pressure. We kept things open.

Open data cannot be calculated, it must be evaluated for patterns. Next week will be a scramble to synthesize patterns and new insights as we work to finalize system concepts into well defined parameters. We hope that through this process we will also identify opportunities to produce relevant and compelling artifacts (our final output/deliverable).

It still feels like a risk to be so far into a process and to still not have a clear idea of what it is we are making. We instead draw our assurances from what we have already made: an index of relevant articles, interview notes, countless diagrams and visual representations of high-level abstract concepts and maps at almost every level of visual fidelity imaginable, hundreds of presentation slides, dozens of pages of reflective text, and months worth of slack messages, shared links, and drafted emails. We created interactive digital workshop spaces and protocols for our participants, and archives with 256-bit encryption.

When looking at the collective volume of effort from this team, it’s difficult to imagine that we wouldn’t make something meaningful in the end. Is that too optimistic? Ask me in a month.