Machine Learning Compiler Software Engineer, TPU Horizontal Scaling

2 Hours ago • 2-2 Years

About the job

SummaryBy Outscal

About the job:
Google is looking for a Machine Learning Compiler Software Engineer to join their TPU Horizontal Scaling team. This team develops the Accelerated Linear Algebra (XLA) TPU/GPU parallelizing compiler used to partition, optimize, and run large-scale machine learning models across multiple TPU/GPU accelerators. The XLA Horizontal Scaling team's software stack includes the XLA Single Program Multiple Data (SPMD) partitioner, collective and scheduling optimizations, and code generation. Responsibilities include writing product or system development code, participating in design reviews, contributing to the compiler, conducting static and runtime performance analysis, designing and implementing performance optimizations, and increasing the velocity of important production teams.
Must have:
  • Bachelor's degree or equivalent practical experience
  • 2 years of experience with software development in one or more programming languages
  • 2 years of experience with data structures or algorithms
Good to have:
  • Master's degree or PhD in Computer Science
  • Experience in Machine Learning and High Performance Computing (HPC)
  • Experience optimizing programs at distributed scale
  • Experience in C++
  • Experience in compilers
  • Ability to debug and program concurrent/parallel computations

Minimum qualifications:

  • Bachelor’s degree or equivalent practical experience.
  • Candidates will typically have 2 years of experience with software development in one or more programming languages, or 1 year of experience with an advanced degree.
  • Candidates will typically have 2 years of experience with data structures or algorithms.

Preferred qualifications:

  • Master's degree or PhD in Computer Science, or a related technical field.
  • Experience in Machine Learning and High Performance Computing (HPC).
  • Experience optimizing programs at distributed scale.
  • Experience in C++.
  • Experience in compilers.
  • Ability to debug and program concurrent/parallel computations.

About the job

Google's software engineers develop the next-generation technologies that change how billions of users connect, explore, and interact with information and one another. Our products need to handle information at massive scale, and extend well beyond web search. We're looking for engineers who bring fresh ideas from all areas, including information retrieval, distributed computing, large-scale system design, networking and data storage, security, artificial intelligence, natural language processing, UI design and mobile; the list goes on and is growing every day. As a software engineer, you will work on a specific project critical to Google’s needs with opportunities to switch teams and projects as you and our fast-paced business grow and evolve. We need our engineers to be versatile, display leadership qualities and be enthusiastic to take on new problems across the full-stack as we continue to push technology forward.

With your technical expertise you will manage project priorities, deadlines, and deliverables. You will design, develop, test, deploy, maintain, and enhance software solutions.

Our team develops the Accelerated Linear Algebra (XLA) TPU/GPU parallelizing compiler used to partition, optimize, and run large-scale machine learning models across multiple TPU/GPU accelerators for internal and external customers. The XLA Horizontal Scaling team’s software stack includes the XLA Single Program Multiple Data (SPMD) partitioner, collective and scheduling optimizations, and code generation.

Google Cloud accelerates every organization’s ability to digitally transform its business and industry. We deliver enterprise-grade solutions that leverage Google’s cutting-edge technology, and tools that help developers build more sustainably. Customers in more than 200 countries and territories turn to Google Cloud as their trusted partner to enable growth and solve their most critical business problems.

Responsibilities

  • Write product or system development code.
  • Participate in, or lead design reviews with peers and stakeholders to decide amongst available technologies.
  • Contribute to a compiler which scales-out machine learning models across accelerators such as Tensor Processing Unit (TPU)/Graphics Processing Unit (GPU) at Google and Cloud. 
  • Conduct static and runtime performance analysis of important large-scale production models.
  • Design and implement performance optimizations and critical features, which increase the velocity of important production teams.
View Full Job Description

About The Company

A problem isn't truly solved until it's solved for all. Googlers build products that help create opportunities for everyone, whether down the street or across the globe. Bring your insight, imagination and a healthy disregard for the impossible. Bring everything that makes you unique. Together, we can build for everyone.

Michigan, United States (On-Site)

Illinois, United States (On-Site)

California, United States (On-Site)

New York, United States (On-Site)

Illinois, United States (On-Site)

New York, United States (On-Site)

View All Jobs

Level Up Your Career in Game Development!

Transform Your Passion into Profession with Our Comprehensive Courses for Aspiring Game Developers.

Job Common Plug