Introduction
IBM India Systems Development Lab (ISDL) is a global development lab. Its leading IBM's server, storage and systems software. In addition it has System Integrators (SI) mission and works with industry leading SIs on go-to-market strategies, enablement, and partnerships. This is a key research and development lab based out of India, and develops new cutting-edge products around Machine learning, Deep Learning & Cloud technologies right from processor design and firmware all the way to operating system. This is a very strategic development lab for IBM as we are uniquely positioned to not just work with clients in India/South Asia but also Middle East & Africa, China and the rest of Asia Pacific countries. At ISDL, engineers get an opportunity to work with clients, on joint research programs with Universities and present at conferences.
Want more jobs like this?
Get Data and Analytics jobs in Bangalore, India delivered to your inbox every week.
Your Role and Responsibilities
This position is for an experienced Linux GNU/Open Source AI Library developer who has experience developing, optimizing and tuning code to a specified Hardware Architecture. While the target architecture of this work will be the IBM POWER architecture, experience tuning to x86 or ARM architectures will be directly applicable. As a developer on the Linux on Power team you will be responsible for:
Working with and interlocking with other internal teams and with the Open Source Community for defining, designing, developing and testing Linux on Power specific features in the various AI libraries and framework like OpenBlas, ONNXRuntime, Pytorch , Tensorflow, FAISS and Eigen. Ensuring that those features are accepted upstream and incorporated into the appropriate Linux distributions.
In addition to design and development work you will be responsible for working issues and defects including problem determination, problem recreation, providing fixes, validating fixes and getting fixes accepted by the Community. Developers in this position are required to assist with resolving customer critical situations, for assisting with or leading proof of concepts and for providing technical guidance and consulting for pre-sales and post sales engagements.
This role requires expertise with the POWER instruction architecture and Linux based OS. Familiarity with software builds, bring-up, test and performance analysis tools used by Linux on Power is desirable along with general hardware skills. Applicant will be engaged in performance analysis and tuning utilizing the POWER instruction profiling tools. Candidates must have the ability to work in a team based environment with global and remote team members.
Candidate should have experience with C/C++, scripting languages, assembler, familiarity with Bugzilla, GIT, open source development tools, simulation tools, performance analysis tools and working with mailing lists.
Required Technical and Professional Expertise
As an Open Source AI Library Developer you will, (Role responsibilities)
• Enhance, optimize & maintain open source Linux AI libraries for IBM Power processor (ppc64le) architecture
• Update open source libraries to enable new IBM Power processor functions and instructions
• Work with open source community to upstream code, enabling the ecosystem to leverage new generation IBM Power processor
• Resolve functional issues including recreation & analysis, proposing & validating fixes and working with the community to upstream fixes
• Assist resolving customer critical situations, lead proof of concepts and provide technical guidance & consulting for pre-sales and post sales engagements.
Preferred Technical and Professional Expertise
• Strong understanding of Computer Architecture, Operating Systems, Compilers, Runtimes, low level debugging and tracing
• Effective communication and collaboration skills
• 3+ years of experience developing in OS-level languages like C/ C++ and Python
• 1+ year experience in assembly language
• 1+ year experience in Open-source development and related tools such as Git, JIRA or Bugzilla
• Experience and exposure to Math knowledge like Linear Algebra, Linear regression, Eigen values
• Hands-on with AI Libraries development - OpenBlas, ONNXRuntime, Pytorch , Tensorflow, FAISS ( not limited to just usage of libs)
Nice-to-have Skills:
• Experience in low-level programming involving interaction with C++ runtime, OS, threads, memory management, and assemblers.
• Experience debugging, tracing, and profiling code for resolving functional and performance issues.
• Experience in IBM AIX, Linux on POWER and Z
• Experience working in the open software community projects as a contributor or committer
• Corelibs - Hands-on development experience with Glibc, libm, pmdk etc