Expoint - all jobs in one place

The point where experts and best companies meet

Limitless High-tech career opportunities - Expoint

Qualcomm Senior Machine Learning Compiler & Performance Engineer 
Canada, Ontario, Markham 
398132874

29.03.2024

Job Area:

Engineering Group, Engineering Group > Machine Learning Engineering

Job Purpose & Responsibilities

As a member of Qualcomm’s ML Systems Team, you will participate in two activities:

  • Development and evolution of ML/AI compilers (production and exploratory versions) for efficient mappings of ML/AI algorithms on existing and future HW

  • Analysis of ML/AI algorithms and workloads to drive future features in Qualcomm’s ML HW/SW offerings

Key Responsibilities:

  • Contributing to the development and evolution of ML/AI compilers within Qualcomm

  • Defining and implementing algorithms for mapping ML/AI workloads to Qualcomm HW

  • Understanding trends in ML network design, through customer engagements and latest academic research, and how this affects both SW and HW design

  • Creation of performance-driven simulation components (using C++, Python) for analysis and design of high-performance HW/SW algorithms on future SoCs

  • Exploration and analysis of performance/area/power trade-offs for future HW and SW ML algorithms

  • Pre-Silicon prediction of performance for various ML algorithms

  • Running, debugging and analyzing performance simulations to suggest enhancements to Qualcomm hardware and software to tackle compute and system memory-related bottlenecks

· Successful applications will work in cross-site, cross-functional teams.

Minimum Qualifications:

• Bachelor's degree in Computer Science, Engineering, Information Systems, or related field and 2+ years of Hardware Engineering, Software Engineering, Systems Engineering, or related work experience.

Master's degree in Computer Science, Engineering, Information Systems, or related field and 1+ year of Hardware Engineering, Software Engineering, Systems Engineering, or related work experience.

PhD in Computer Science, Engineering, Information Systems, or related field.

Requirements:

  • Demonstrated ability to learn, think and adapt in fast changing environment

  • Detail-oriented with strong problem-solving, analytical and debugging skills

  • Strong communication skills (written and verbal)

  • Strong background in algorithm development and performance analysis is essential

The following experiences would be significant assets:

  • Strong object-oriented design principles

  • Strong knowledge of C++ Strong knowledge of Python

  • Experience in compiler design and development

  • Knowledge of network model formats/platforms (eg. Pytorch, Tensorflow, ONNX) is an asset.

  • On-silicon debug skills of high-performance compute algorithms · Knowledge of algorithms and data structures

  • Knowledge of software development processes (revision control, CD/CI, etc.) · Familiarity with tools such as git, Jenkins, Docker, clang/MSVC

  • Knowledge of computer architecture, digital circuits and event-driven transactional models/simulators

Qualcomm expects its employees to abide by all applicable policies and procedures, including but not limited to security and other requirements regarding protection of Company confidential information and other confidential and/or proprietary information, to the extent those requirements are permissible under applicable law.