Skill Flow Builder (SFB)
Problem
Most Alexa games aren’t very fun. They are confusing to interact with and very buggy.
Discovery
First, I interviewed skill makers to learn more about what was hampering their productivity, collaboration, and iteration. I also interviewed game makers on other platforms to learn about their process. I prototyped various solutions and content formats (including CSV, word, and custom syntaxes). Then, I put the concepts in front of skill developers, testers, designers, and writers for feedback. I planned and executed individual feedback sessions, a hackathon, and a formal external beta program. I expanded the feature set and refined the syntax based on customer feedback and collected more feedback. I learned that:
I learned early on that the greatest impediment to productivity, collaboration, and iteration was that there was no one place where the holistic experience was defined. It was defined in abstract pieces, separated out into the interaction model, individual lines of content, and flow logic written in programming languages. It was near impossible to look at the code of a skill and understand what it was supposed to do. Therefore, the first step was to provide a high-level language where a user could define the whole experience in one place and then automated processes would abstract away the interaction model, content, and logic behind the scenes. We call this format Alexa Branched Content (or .abc files) which form the core language of Skill Flow Builder.
I interviewed select teams responsible for top Alexa Skills and learned that they tended to be multidisciplinary, including developer, writer, voice designer, visual designer, and QA roles. Each role wanted to be able to work on their own area of concern, without requiring assistance or blocking each other. Therefore, I designed a syntax that clearly separated each area of concern, while being simple enough to scan and understand the overall flow. A writer can just focus on the “say” sections, a visual designer can focus on the “show” sections, a voice designer can tune the “hear” sections, and a developer can build extensions to add complex functionality.
I also learned that there were many many opportunities to improve overall productivity in skill authoring. We added features such as snippets, voice model generation, and a testing framework to speed up overall skill development.
Finally, I learned that working in vs-code intimidated many designers and writers. They also needed flow diagrams and a simulator to aid in rapid iteration without needing to deploy. Therefore, I designed the SFB Editor application for Mac and PC. It is simple to install and empowers non-technical users to rapidly iterate on voice experiences with very little on-boarding.
Goal
Increase skill creator productivity and enable teammates of all technical ability to iterate rapidly on the holistic experience.
Solution
I designed a new domain specific markup and programming language for voice experiences. I iterated on the structure, syntax and core features with user feedback from hackathons and betas. Based on early feedback, I designed an editor application so that less technical users could onboard with minimal setup. I added a flow diagram and simulator to the application to aide in rapid iteration and QA.
REsult
80+ SFB authored Alexa Skills published as of Dec 2021 including Alexa COVID-19 Self-Checker, Starfinder, Choose Your Own Adventure, The Sims Stories, Cursed Painting, The 3% Challenge, Sherlock Holmes: The Great Game
Press: VentureBeat, VoiceBot.ai, MIT Technical Review
Awards: Best Software in Publishing by Digital Book World