Software Engineer II - AI
Role details
Job location
Tech stack
Job description
This is a role designed for a software engineer who's ready to go deeper. You've got a couple of years of professional experience, you've shipped real things, and you're excited about working on AI-powered products at a level beyond tutorials and side projects. Senior engineers will be around to pair with, learn from, and review your work - but increasingly, you'll be the one breaking down problems, proposing approaches, and owning features through to production. This is a remote position open to applicants authorized to work for any employer within the United States.
What You'll Learn We think the middle of your career is when the right environment matters most. Here's what working on this team looks like in practice:
You'll learn how production AI systems actually behave - not just the happy path, but the long tail of weird inputs, hallucinations, retrieval misses, and latency cliffs that you only encounter when real users hit your code. You'll see how senior engineers reason about LLM tradeoffs and bring you into those conversations. You'll write code that runs at the scale of millions of students, and you'll be responsible for operating it - with backup from teammates when things get tough. You'll get fast, specific feedback on your work, and you'll be expected to give the same in return. By the end of your first year, you'll have shipped features you can point to and say I built that.
What You'll Do
Build the services that deliver AI to users. Pick up work on our RAG pipelines, LLM orchestration layers, and the APIs that surface AI capabilities to users. You'll integrate with model providers (Azure OpenAI and others), wire up retrieval and routing logic, and build the production glue that turns research into shipped product. You'll start with well-scoped features and grow into owning them end-to-end as you ramp. Work across our backend stack. Most of your time will be in Python (FastAPI, async/await, Pydantic), with opportunities to contribute to Go services as you grow. You'll touch PostgreSQL, async task workers, and the integrations that connect our services together.
Ship with care. Write code that's tested, readable, and considerate of the people who'll maintain it after you. Participate in code reviews - both giving and receiving - and learn how your team thinks about quality, observability, and reliability.
Get good at AI engineering - the software side. You don't need to arrive as an expert. You do need to be the kind of person who reads the docs, runs the experiments, asks the awkward questions, and forms a real point of view about how to build with LLMs reliably - prompt design, retrieval quality, latency and cost tradeoffs, graceful failure modes. We'll invest in your growth here. (To be clear: the model science itself lives with our data science team. You'll partner with them, but you won't be doing their job.)
Collaborate broadly. You'll work with data scientists evaluating model outputs, product managers shaping features, designers thinking about UX, and other engineers across the org. Communicating clearly - in PRs, in design discussions, in Slack - is part of the job.
Grow into more. Over time, you'll start influencing design decisions on your team, mentoring engineers newer than you, and taking on larger pieces of work. We'll meet you where you are and help you get to where you want to go.
Requirements
A few years of building real things. Roughly 2-5 years of professional software development experience. You've shipped features that real people used, you've debugged production issues, and you've learned that "works on my machine" isn't a finished state.
Solid backend fundamentals. Comfort in any modern backend language - Python preferred, but if your background is heavier on Go, Java, Kotlin, or Node and you're confident you can ramp in Python, tell us about that. Experience building APIs and working with relational databases (PostgreSQL, MySQL, or similar) is the baseline.
Curiosity about AI, with some skin in the game. You don't need a list of production RAG systems on your resume. You do need to have engaged with this stuff as a software engineer - built something that calls an LLM, broken something, formed opinions about prompt design or retrieval quality, played with frameworks like LangChain or LlamaIndex. We're looking for engineers who want to build with AI, not researchers who want to build AI itself.
Good engineering instincts. You know when to ask for help and when to push through. You write tests because you've been burned by not writing tests. You read more code than you write, and you can explain why you made the choices you did.
Comfort with ambiguity at your level. Senior engineers will scope harder problems for you, but you'll increasingly be the one breaking down medium-sized features, identifying edge cases, and flagging risks early. You're past the stage of needing tasks handed to you in step-by-step form.
Clear communication. You can explain a tradeoff in writing without 14 paragraphs. You give code review feedback that's specific and kind. You ask questions in public channels because you've figured out that other people probably have the same question.
A "low-ego, high-ownership" disposition. You see a problem and want to fix it. You're more interested in the team shipping the right thing than in being the one who shipped it. You're willing to be wrong in public so you can learn faster.
Nice to have:
- Production experience with AWS or Azure
- Familiarity with frontend work (React or Angular) - you don't have to live there, but you can help when needed
- Experience with vector databases, embeddings, or RAG architectures
- Exposure to Go, or genuine willingness to learn it
- Familiarity with Kubernetes, Terraform, or modern CI/CD (GitHub Actions)
- Background in edtech, accessibility (WCAG 2.2 AA), or content-rich product domains
- Open-source contributions, technical writing, or teaching of any kind
Benefits & conditions
The pay range for this position is between $93,950 - $135,000 annually, however, base pay offered may vary depending on job-related knowledge, skills, experience, and location.An annual bonus plan may be provided as part of the compensation package, in addition to a full range of medical and/or other benefits, depending on the position offered. Click here to learn more about our benefit offerings.