EMILY C. CRUTCHER Technical UI Architect EDUCATION: 1999: MS, Computer Science, New York University, New York, NY 1997: BS, Computer Science, Wesleyan University, Middletown, CT HIGHLIGHTS: Architect for an SAP enterprise framework for UI creation using the GWT framework Architect for the gwt-incubator project, a Google sponsored project to bring in new features from the GWT community Designed and developed the 1.6 event system and the original internationalization system for the Google Web Toolkit (GWT) Contributed many core GWT widgets, such as the Grid, SuggestBox, PushButton, and DatePicker widgets. Created core GWT libraries in wide use throughout Google. Created, guided and encouraged the GWT incubator, an online community to create widgets and test new ideas for with the Google Web Toolkit Developed an Industrial Strength Optimization module for optimizing Java Code Compilation. Developed PHIN VADS, a national ontological system for CDC Developed state-of-the-art generational module extending a multi-threaded hybrid garbage collector EXPERIENCE: 2010-: Intelligent Systems Development, Market eyes product development Emily is creating a next generation Swing user interface for our investment oriented stealth mode startup. This nextgeneration UI will allow analysts to have a detailed conversation with their data and rapidly refine and enhance their strategies. 2009-2010: Intelligent Systems Development, SAP contract Emily was the UI architect for a multi-million dollar GWT project at SAP. She got the project back on track, advised them on the best way to use GWT, and created a UI architecture that was extensible, flexible, and ready for enterprise deployment. This architecture was used for three related GWT projects, where each project was staffed with a different mix of team members, each of which received a warm reception when presented to the SAP CEO and board of directors. This architecture was a contributing factor to SAP’s decision to transition away from Flash to HTML 5. Each of the projects (and the architecture development itself) had developers and stakeholders on several continents, with varying levels of technical skill and English proficiency. Emily coordinated with all of them with no major glitches or unexpected time slips on any of the projects. 2006-2009: Google Emily worked on the Google Web Toolkit (GWT), a Java-to-JavaScript compiler and UI framework that takes the compatibility headaches out of programming AJAX, and allows the user to program and debug web applications entirely in Java. Early on in the project, Emily created the internationalization system for GWT, allowing GWT to be used in applications which have to serve users in multiple languages. Emily developed and supported many of the core user widgets available in GWT, such as the table, date box, auto-suggest widgets. Emily was then the architect for the gwt-incubator project, and tended the open source community that drove the creation of new widgets therein. She helped support and guided the AdWords team at Google in their use of GWT. Emily also designed the new GWT event system. 2003-2006: STC As a Senior Software Engineer, Emily worked as the Technical lead of the PHIN VADS project for CDC, where PHIN VS is a versioned, provisioning, browsable ontological system for use by the CDC and other state health organizations. Previously at STC, she worked as the PDF Form Generator Technical Lead, where the PDF Form Generator translates xml representations of public health forms into fully web-enabled PDF forms. Emily also developed the Form Business Objects and Rules Engine for the CDC’s PHIN project. 2000-2002: TowerJ, Atlanta, GA Previously, as a Software Engineer, Emily implemented a Just-In-Time Java compiler module targeted to Linux assembly (4-person team.) She implemented a parallel generational copy-collector loosely based on Bartlett’s mostly conservative garbage collector and she was solely responsible for the generation system, large-object handling, and memory defragmentation strategies and implementation (4-person team.) Emily also designed and implemented a new automated system to capture, process, and compile custom-loaded Java classes, which is an integral part of Java AheadOf-Time processing. She also designed and implemented a new optimization system for Java with an SSA-based (static single assignment) internal representation. This included a modular, flexible, visitor-based system that allows each optimization to be run and tested separately, with a variety of high-level optimizations, for a significant performance gain over previous implementation (2-person team.) She modified current complier and runtime to allow it to be certified as JCK compliant. This involved significant upgrades of the previous system, as well as integration of Sun Java libraries, edge-case handling, and byte-code verification (7-person team.) Emily also successfully created a new text-based testsuite analysis tool to better process regression failures (2-person team.) 1997-2000: Courant Institute, NYU, New York, NY While a PhD Research Assistant, Emily designed an innovative alias-analysis technique to enhance software pipelining for EPIC class machines. She designed and implemented a recursive indexing system to index a collection of remote Web pages, searching for product pages. For each product page, an entry in a database is generated, after analyzing the page for attributes. When combined with a database and Web interface, it allows product searches/filters that are more sophisticated than anything offered today by e-commerce sites. Emily also designed and implemented MIRROR, an entirely reflective language that provides maximum power and flexibility to the user. MIRROR is functional and objectoriented, with multi-dispatch and dynamic typing. She designed and implemented MULTI, an object-oriented language with clean semantics, easy C linkage, and efficient multi-dispatch, as well as or-types, the compiler for MULTI generated efficient x86 assembly code. She designed a parallel server for Plinda. Plinda is a parallel variant of Yale Linda (a tuplespace system) augmented with transactions and distributed processing. The transactions allowed rollback in the event of client failure, but the server was not parallel or redundant. The task was to design a parallel-redundant server with good performance and no-single-point-of-failure. June 1999-August 1999 June 1998-August 1998: Bellcore, Morristown, NJ During these summers, Emily was a contract Programmer where she designed new-rules semantics for LAURE 5 (a high-level language for approximating solutions for NP-complete problems), which is simpler and more powerful than the current semantics. She proposed a new implementation for multi-methods based on the work with MULTI. Emily also implemented Java-like IO classes for use in the new release of LAURE, a hybrid of LAURE 4 and Java. She developed an experimental release of the RATER system, an Internet goods pricing program developed at Bellcore. In the experimental version, the iterative drive of RATER was replaced by a set of triggered axioms. She created a Larnlike game with an emphasis on the game system’s intelligence, as opposed to graphics for use as a demonstration of LAURE’s advanced features. June 1997-August 1997: Video Kitchen, Louisville, KY As a Programmer, Emily designed a scheduling program and customer database for use at the Video Kitchen. The system was designed for efficient employee management of customer data and to schedule equipment usage. Features included advanced search, automatic scheduling, and a direct manipulation user interface for scheduling. June 1996-August 1996: Dr. David Changaris, MD, Louisville, KY As a Programmer, Emily designed a full-service medical database program that tracks and cross-references patient information, insurance companies, and diagnosis and procedure codes for the purpose of tracking patients, automatically generating bills, and accounting.