Skip to main content

Résumé

Miguel (Yáñez-)Barreto
Author
Miguel (Yáñez-)Barreto

Location: Based in Brooklyn, NY 🗽 — Relocation is not an option.

Senior Software Engineer with more than 10 years’ experience in large tech companies (9+ at Google, 1.5 at Twitter, ~1.5 at Apple, now at Duolingo); I have worked there in the backend (batch data processing, features, optimization and system reliability) and on Android (application features and performance).

💻 Tech Stack
#

  • Programming languages: Kotlin, Scala, Java, C++, Python, Rust
  • Data processing using MapReduce, Scalding, Beam, Scio, Dataflow and BigQuery
  • Build Systems: Bazel/Blaze, Pants, Gradle
  • CI/CD environments: Circle CI, Travis CI, and Twitter-, Google- and Apple-internal alternatives
  • PostgreSQL, DynamoDB, Redis, Spanner & Bigtable/Cassandra-like Databases
  • Significant experience with monitoring, alerting, and profiling tools.

🏢 Software Engineering Experience
#

— Duolingo – Senior Software Engineer (December 2024 - Present)
#

  • I just joined the Experiments (A/B testing) team!

— Apple Pay Later – Senior Software Engineer (March 2022 - December 2024)
#

  • Led the redefinition of automated issuer disputes for credit card network rule violations
    • This led to a reduction of 95% of automated disputes which were causing real user-pain
  • Took ownership of some testing frameworks and added new code-generation features which simplified org-wide testing practices

Twitter - Senior Software Engineer (March 2021 - November 2022)
#

— Geo team
#

  • Redesigned and implemented data import and processing pipelines to account for new compliance requirements
  • Designed a dataset classification framework and associated permissions for the Geo and User Signals teams to guarantee the principle of least privilege for data access
  • Designed and implemented two live dataset migrations
  • Designed and wrote integration of Geo data into ML Training ingestion pipelines

— User Signals team
#

  • Co-Led the process of ownership transfer from a research team to our Engineering team of a pipeline to analyze user behavior at scale
  • Dove through user feedback to identify pain points for internal customers of our pipelines to prioritize next steps
  • Co-authored a design to modernize the pipeline, migrating it to GCP while prioritizing user privacy and compliance
  • Productionized ML model trainings to generate privacy-preserving User Embeddings using Kubeflow and BigGraph

Google - Software Engineer (July 2011 - March 2021)
#

Cloud Binary Authorization Infrastructure (2017 - March 2021)
#

  • Deployed and regionalized the entire backend for this project, and all release processes
  • Led the partnership with Site Reliability Engineering, resulting in an extremely functional relationship between the Dev and SRE teams
  • Designed the monitoring and alerting strategies
  • Debugged and prioritized latency issues to reach stable high SLO compliance
  • Got to 0-pages in a year through my reliability efforts
  • Implemented features to simplify image attestation management by end users
  • Designed and implemented two seamless database migrations with zero downtime, one to support features that were incompatible with the previous data model and a second for increased resiliency to outages

— Material Design Android (2016 - 2017)
#

material-foundation/material-remixer-android

Remixer for Android. Live adjustment of app variables.

Java
774
54
  • Designed and built Remixer for Android which was one of the first Android UX experimentation frameworks
  • Used Java annotations to quickly generate necessary code to integrate Remixer
  • Built a firebase-integration feature that allowed for live-remote-updating of the UI
  • Developed Open Source-first and then imported into the Google internal repository
    • Designed the cross-platform build so it worked across both Gradle and Bazel
material-components/material-components-android

Modular and customizable Material Design UI components for Android

Java
16470
3095
  • Designed the cross-platform build system from a Bazel-first world to also compile and test successfully in Gradle.
  • Built significant tooling around Gradle’s dependency system’s limitations so the Blaze-first code could compile and test on Gradle’s less granular dependencies
  • Wrote the first version of the BackLayerLayout, now renamed to Backdrop in Material Components

— Google Docs / Slides / Sheets – Android Common Infrastructure (2014 - 2016)
#

  • Replaced the dependency injection system with major gains on start-up performance
  • Cleaned up build dependencies for up to 50% faster builds
  • Developed the Android version of Docs / Slides / Sheets templates
  • Redesigned and developed a new version of Comments with assignable tasks
  • Refactored the Comments codebase in Android in the process to improve maintainability
  • Diagnosed important internationalization bugs, documented a long-term plan to fix them
  • Improved accessibility of the apps specifically for visually impaired users

— Google Maps – Data Infrastructure (July 2011 - 2014)
#

  • Worked on the multi-year redesign and subsequent implementation of the entry-point to the Maps Data Processing pipeline
    • Focused on maintainability, code health and data-corruption prevention
  • Maintained the entry point to the Maps Data Processing pipeline until a smooth migration with no downtime was finished
  • Migrated and owned a large component of this pipeline that was passed off to my team from a separate team, I documented and maintained it until its End-of-Life, when I deprecated and deleted it safely
  • Improved code health through refactors, large testing infrastructure changes, and improved monitoring/logging that would help diagnose issues more easily

🎓 Education
#

B.Eng. “Systems and Computer Engineering” – Universidad de los Andes, March 2009