Google Software Engineer, Compiler Optimization and Scheduling, Silicon

Job is more than three months old.

Job Details

Posted date: Aug 01, 2024

Location: Bellevue, WA

Level: Senior

Estimated salary: $168,000
Range: $136,000 - $200,000


Description

Work as part of the EdgeTPU compiler team, including analyzing and improving the compiler quality and performance on optimization decisions, correctness, and compilation time.

Develop parallelization and scheduling algorithms to optimize compute and data movement costs to execute Machine Learning workloads on the EdgeTPU.

Work on efficient mapping of generative AI models and other key workloads into EdgeTPU instructions through the compiler.

Work with EdgeTPU architects to design the hardware/software interface and co-optimizations of the next generation EdgeTPU architectures.

Work with product managers, researchers in identifying key Machine Learning trends, future use cases, etc.

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.

In this role, you will work on the core optimization and scheduling algorithms of the next-generation EdgeTPU compiler. Featuring an MLIR-based compiler framework serving both production and hardware/software codesign needs for EdgeTPU, the core algorithms are critical to deliver the best AI/ML performance of the silicon to our end users.

Together with the EdgeTPU team, whether software engineers or architects, you will design and implement novel optimization algorithms and compiler transformation frameworks to enable production-quality compilation and optimization of workloads. You will be able to make an impact on holistic hardware/software co-optimization of AI/ML use cases for current and future generations of Google devices, including the latest generative AI models.

Google's mission is to organize the world's information and make it universally accessible and useful. Our team combines the best of Google AI, Software, and Hardware to create radically helpful experiences. We research, design, and develop new technologies and hardware to make computing faster, seamless, and more powerful. We aim to make people's lives better through technology.

The US base salary range for this full-time position is $136,000-$200,000 + bonus + equity + benefits. Our salary ranges are determined by role, level, and location. The range displayed on each job posting reflects the minimum and maximum target salaries for the position across all US locations. Within the range, individual pay is determined by work location and additional factors, including job-related skills, experience, and relevant education or training. Your recruiter can share more about the specific salary range for your preferred location during the hiring process.

Please note that the compensation details listed in US role postings reflect the base salary only, and do not include bonus, equity, or benefits. Learn more about benefits at Google.



Qualifications

Minimum qualifications: Bachelor’s degree or equivalent practical experience.

2 years of experience with software development in one or more programming languages (e.g., C++), or 1 year of experience with an advanced degree.

2 years of experience with data structures or algorithms.

2 years of experience working with compilers (compiler optimizations, parallelization, etc.).

Preferred qualifications: Master's degree or PhD in Computer Science or related technical fields.

Experience with compiler development in the context of accelerator-based architectures.

Experience with machine-learning and generative AI architectures.

Experience developing accessible technologies.

Experience with C++ or Python.

Experience in Multi-Level IR (MLIR) or Low Level Virtual Machine (LLVM).

Extended Qualifications

Bachelor’s degree or equivalent practical experience.

2 years of experience with software development in one or more programming languages (e.g., C++), or 1 year of experience with an advanced degree.

2 years of experience with data structures or algorithms.

2 years of experience working with compilers (compiler optimizations, parallelization, etc.).



Check out other jobs at Google.