At a Glance
- Tasks: Design and maintain robust test infrastructure for complex ML software.
- Company: Join Graphcore, a leader in AI compute backed by SoftBank.
- Benefits: Flexible working, generous leave, private medical insurance, and more.
- Other info: Inclusive environment with excellent career growth and mentoring opportunities.
- Why this job: Make an impact on the future of AI while working with cutting-edge technology.
- Qualifications: Experience in software engineering, strong Python skills, and familiarity with ML frameworks.
The predicted salary is between 60000 - 80000 £ per year.
At Graphcore, we’re building the future of AI compute. We’re a team of semiconductor, software and AI experts, with deep experience in creating the complete AI compute stack - from silicon and software to infrastructure at datacentre scale. As part of the SoftBank Group, backed by significant long-term investment, we are delivering key technology into the fast-growing SoftBank AI ecosystem. To meet the vast and exciting AI opportunity, Graphcore is expanding its teams around the world. We are bringing together the brightest minds to solve the toughest problems, in a place where everyone has the opportunity to make an impact on the company, our products and the future of artificial intelligence.
Job Summary
Applicants for this role should have strong experience designing, developing, and maintaining high-quality software systems. The role focuses on testing and validating a complex machine learning software stack, with particular emphasis on software architecture, automation, and engineering best practices. The ideal candidate is an experienced software engineer who values code quality, testability, and long-term maintainability, and enjoys building systems that other engineers rely on. This person will be comfortable working across large codebases, contributing to CI/CD infrastructure, and shaping technical direction through thoughtful design and mentoring in a technically demanding environment spanning ML frameworks, infrastructure, and AI accelerator hardware.
The Team
The ML QA team is composed of highly skilled software engineers with a strong focus on automation, software quality, and data-driven validation. The team works closely with industry-standard machine learning frameworks and models, contributing to upstream open-source projects and collaborating across the wider software organization. Operating in a fast-paced environment, the team plays a critical role in ensuring reliability, performance, and maintainability across the ML software stack, helping to deliver robust and high-quality products to customers.
Responsibilities and Duties
- Design, implement, and maintain robust test infrastructure and automation for a complex ML software stack.
- Architect and evolve test frameworks and tooling with a focus on scalability, maintainability, and developer experience.
- Build and maintain CI/CD pipelines targeting simulators, emulators (e.g. QEMU), and physical hardware.
- Create representative ML workloads and gain insights from their execution (Numerical accuracy, performance analysis and benchmarking).
- Work closely with all Software development teams, supporting a culture of quality, security and maintainability.
- Review code and designs, setting a high bar for software engineering best practices.
- Mentor and support junior engineers, helping raise the overall technical capability of the team.
- Evaluate existing test strategies and infrastructure, identifying gaps and driving improvements aligned with team and organizational goals.
Candidate Profile
- Experience in production-quality software engineering roles.
- Strong software design and architecture skills, with experience working on large or complex systems.
- Strong proficiency in Python, including experience building and maintaining production codebases.
- Solid experience with CI/CD systems and automated testing (preferably GitHub-based workflows).
- Experience working in Linux environments.
- Familiarity with C or C++, with the ability to read, debug, and reason about low-level code when needed.
- Proven ability to mentor junior engineers and influence engineering practices within a team.
- Strong problem-solving skills and a proactive, self-directed approach to work.
- Bachelor/Master's/PhD or equivalent experience in Computer Science, Maths, Machine Learning, Data Science, or related field.
- Exposure to machine learning frameworks such as PyTorch, JAX, Triton, TensorFlow.
- Experience with distributed workload management systems such as Kubernetes, VLLM, Keras or MLOps pipelines.
- Experience working with hardware simulators or emulators (e.g. QEMU).
- Experience developing for or working with FPGA-based systems.
- Experience with people management or mentoring.
In addition to a competitive salary, Graphcore offers flexible working, a generous annual leave policy, private medical insurance and health cash plan, a dental plan, pension (matched up to 5%), life assurance and income protection. We have a generous parental leave policy and an employee assistance programme (which includes health, mental wellbeing, and bereavement support). We offer a range of healthy food and snacks at our central Bristol office and have our own barista bar! We welcome people of different backgrounds and experiences; we’re committed to building an inclusive work environment that makes Graphcore a great home for everyone. We offer an equal opportunity process and understand that there are visible and invisible differences in all of us. We can provide a flexible approach to interview and encourage you to chat to us if you require any reasonable adjustments. Applicants for this position must hold the right to work in the UK. Unfortunately at this time, we are unable to provide visa sponsorship or support for visa applications.
Staff Software Engineer (ML QA) New Cambridge, UK employer: graphcore
Graphcore is an exceptional employer, offering a dynamic work environment in Cambridge where innovation thrives. With a strong focus on employee growth, we provide opportunities for mentorship and collaboration within a diverse team of experts, alongside competitive benefits such as flexible working, generous leave policies, and comprehensive health plans. Our commitment to inclusivity and a supportive culture makes Graphcore a fantastic place for those looking to make a meaningful impact in the AI industry.
StudySmarter Expert Advice🤫
We think this is how you could land Staff Software Engineer (ML QA) New Cambridge, UK
✨Tip Number 1
Network like a pro! Reach out to current employees at Graphcore on LinkedIn or other platforms. A friendly chat can give you insider info and might even lead to a referral, which is always a bonus!
✨Tip Number 2
Prepare for the technical interview by brushing up on your coding skills and understanding ML frameworks. Practice common algorithms and system design questions, as they’re likely to come up. We want you to shine!
✨Tip Number 3
Showcase your passion for AI and software engineering during interviews. Share your personal projects or contributions to open-source. It’s a great way to demonstrate your skills and enthusiasm for the field!
✨Tip Number 4
Don’t forget to apply through our website! It’s the best way to ensure your application gets seen. Plus, it shows you’re genuinely interested in joining the Graphcore team. Let’s get you that job!
We think you need these skills to ace Staff Software Engineer (ML QA) New Cambridge, UK
Some tips for your application 🫡
Tailor Your Application:Make sure to customise your CV and cover letter for the Staff Software Engineer role. Highlight your experience with ML frameworks, CI/CD systems, and any relevant projects that showcase your skills in software design and architecture.
Showcase Your Code Quality:Since we value code quality and maintainability, include examples of your work that demonstrate your commitment to these principles. If you have contributions to open-source projects or personal projects, don’t hesitate to share them!
Be Clear and Concise:When writing your application, keep it clear and to the point. Use bullet points where possible to make it easy for us to see your key achievements and skills at a glance. We appreciate straightforward communication!
Apply Through Our Website:We encourage you to apply directly through our website. This way, your application will be processed more efficiently, and you'll be one step closer to joining our amazing team at Graphcore!
How to prepare for a job interview at graphcore
✨Know Your Stuff
Make sure you brush up on your knowledge of machine learning frameworks like PyTorch and TensorFlow. Be ready to discuss your experience with CI/CD systems and how you've implemented automated testing in past projects.
✨Showcase Your Problem-Solving Skills
Prepare to share specific examples of complex problems you've tackled in software engineering. Highlight your approach to debugging and how you’ve improved code quality and maintainability in previous roles.
✨Emphasise Collaboration
Graphcore values teamwork, so be ready to talk about how you've worked with other engineers to enhance software quality. Discuss any mentoring experiences you have, as this role involves supporting junior engineers.
✨Ask Insightful Questions
Prepare thoughtful questions about the team’s current challenges or the technologies they use. This shows your genuine interest in the role and helps you understand how you can contribute to their goals.