19

[Discussion] Machine Learning Interview tips

Profile picture
Machine Learning Engineer at Taro Community7 months ago

I've done about 25 ML interviews in the last 3 months. Here's my tips

  1. HM interviews are super common. KNOW YOUR WORK IN DEPTH. This is the single biggest tip I can give
    1. Be able to talk for atleast 5-10 minutes about the ML models you choose. You cant just give a high level description
    2. Understand the tradeoffs with the ML model you choose
    3. I think depth is just everything. You need to understand deeply the frameworks you use, the models you choose, the evaluation methods, deployment strategy. How it works under the hood
  2. DSA is a must. It's hard to cram DSA, but you get really really far with just a bit everyday. About 30% of interviews have a DSA round onsite. Another 30% might have DSA screening (hackerrank/codesignal). I'm not saying grind leetcode 6 hrs a day but even 1-2 problems consistently everyday adds up a lot! and you dont want to be caught unprepared if u get a DSA interview, you cant push back interviews for a month right now
  3. Takehomes/timed take homes are common. Make sure you clearly document and your code is easily reproducible and no steps are missing. e.g. if you did some data preprocessing but its not documented/shown thats bad. The conversion rate on takehomes is pretty high for me so do well on them and treat them seriously. In this interview cycle I've gotten first round interviews for all 6 takehomes i submitted
  4. Interviews are 80% luck and 20% skills in this market. Sometimes you just cant help it they might want a golang developer and even if youre a 200IQ java developer they dont care. Transferrable skills are not the same in this market. Sometimes theres just not a fit and dont beat yourself up. You can do everything right and still fail interviews
  5. Lower Pay/Lower presitge != Easier Interview. They're just different interviews looking for different things. Don't think that just because an interview is for a less prestigious company it will be easier. I've passed first rounds for roles that pay 3x more and 2 levels higher than ones ive failed.
  6. Make sure to go through the JD and note the skills theyre looking for and spend 30 mins being able to insert talking points to highlight those skills

Any other tips anyone would like to add?

715
5

Discussion

(5 comments)
  • 5
    Profile picture
    Tech Lead @ Robinhood, Meta, Course Hero
    7 months ago

    I'm not a machine learning engineer, so I just want to say I'm really grateful that you started this thread - Thank you! It's good to know that a lot of the interviewing fundamentals apply to MLE interviews as well (know your experience inside and out, be thorough with take-homes, be ready for DSA as it's sort of everywhere).

    For folks reading this who want to dive deeper into MLE, here's another great thread: "How to build depth as a machine learning engineer?"

  • 4
    Profile picture
    Tech Lead/Manager at Meta, Pinterest, Kosei
    7 months ago

    Such valuable insights here! One thing I want to comment on:

    Takehomes/timed take homes are common

    Do you think this is more common for ML interviews compared to normal SWE roles?

    I don't like doing take-home tests, so my general advice is that you can simply ask the recruiter to have a technical phone screen instead. You'll be surprised how often you get what you want simply by asking.

    • 1
      Profile picture
      Machine Learning Engineer [OP]
      Taro Community
      7 months ago

      tbh im not sure as I havent done a ton of SWE interviews. I will say that the key difference is that ML interviews have multiple rounds but each interview is a different round. Can be any combination of -- SQL, System Design, ML Theory, Pair programming, DSA, case study, behavioral

      To be honest I'm not really good at leetcode and I was able to get by without leetcode so far as a junior so I would likely have failed if it was a live DSA round. Both the on-sites were directly after completing the OA/take home so they did treat it similar to a first round

      The take home tests were generally similar to what you'll be doing on the job so you dont need to prepare for it at all. I passed my take homes without prep

      But the take home took me 2-4 hours per company and I preferred the take home but its definitely good to know that you can ask for a technical round instead!!

  • 2
    Profile picture
    Head of Machine Learning, ex-Meta Staff SWE, ex-Adobe
    2 months ago

    Great points, thanks for sharing!

    As someone who helps a couple dozen MLEs every month, I have some additional insights I can share:

    • To your point #5, I find that those interviews are usually harder and much more variable. Big Tech has very standardized interviews with people who are (usually) really knowledgable about ML.
    • Depth and breadth both matter a lot. The best way to show depth is by talking about tradeoffs. I was a staff MLE at Meta and my whole job was to understand tradeoffs of various ML and data techniques.
    • Relative importance of various rounds depends a lot on your level with behavioral and system design becoming much more important at higher levels. You still need to do DSA/ML Fundamentals, but they are less important. Having said that, failing any round will result in not getting an offer.

    While the patterns of interviews are different among different companies here is what you will generally be asked for MLE:

    • DSA (very common everywhere)
    • ML System Design (very common everywhere)
    • Behavioral (very common everywhere. This can take form of "Project Deep Dive" too, think of that as a technically-focused behavioral, and like you mentioned know the why behind every choice)
    • ML Fundamentals (very common at smaller companies)
    • ML Coding (starting to become common in tier 2-3 like Cruise and Reddit)
    • Distributed system design (becoming less and less common for ML roles)

    To end on a hopeful note, I am seeing a lot more hiring since October from multiple companies for ML roles.

    • 1
      Profile picture
      Head of Machine Learning, ex-Meta Staff SWE, ex-Adobe
      a month ago

      Just to quickly add to this:

      If you are driving the interview you can pick where to show tradeoffs. For example, in modern models with multiple modalities (text and image) early vs late fusion between modalities is a tradeoff that comes up often. Here you can demonstrate both:

      • The technical signal (modularity and flexibility of late fusion vs better cross-modal representations of early fusion) and
      • The leadership component (which complexity is harder for the team to manage, which will depend on the problem here)

      The other quick clarification is level signaling and for this you need to understand the roles:

      • Jr Engineer's job is to do the work they are provided. This means you would naturally have more questions, need more guidance, and will likely propose one idea that you think to be the best instead of discussing tradeoffs of multiple approaches.
      • Staff Engineer's job is to "find scope": determine what is worth working on and how to set up the team for success. If you spend a lot of time on things that matter very little, that's a negative signal at this level. Knowing what to prioritize and not being stuck on one solution is key here.