About Elicit
Elicit is an AI research assistant that uses language models to help researchers figure out what’s true and make better decisions, starting with common research tasks like literature review.
What we're aiming for:
Elicit radically increases the amount of good reasoning in the world.
For experts, Elicit pushes the frontier forward.
For non-experts, Elicit makes good reasoning more affordable. People who don't have the tools, expertise, time, or mental energy to make well-reasoned decisions on their own can do so with Elicit.
Elicit is a scalable ML system based on human-understandable task decompositions, with supervision of process, not outcomes. This expands our collective understanding of safe AGI architectures.
Visit our Twitter to learn more about how Elicit is helping researchers and making progress on our mission.
What is an "AI Engineer"?
AI engineering is a new category of technical work. Its emergence is linked to the increasing availability of powerful new artificial intelligence tools: notably generative machine learning systems like large language models.
The term was suggested by swyx on the Latent Space podcast and we've written about it on our blog before.
Elicit predicted the rise of powerful ML systems even before GPT-1 was trained, and has the deepest experience of building trustworthy, capable, and transparent applications using these tools.
If you're a software engineer who relishes the more difficult parts of backend code—like concurrency, fault-tolerance, and distributed systems—you could be a great AI engineer.
Why we’re hiring for this role
Since launching the newest version of Elicit last fall, response has been strong. We introduced Elicit Plus, our monthly subscription plan, and added thousands of paying users in a matter of months as well as hundreds of thousands of new sign-ups. This has been energizing for our team, but we want to ship more useful functionality to our users even faster.
We believe that building great AI-powered products requires excellence across multiple parts of the tech stack: from frontend UX to infrastructure. But one of the crux areas is certainly how we prompt, invoke, respond to, and manage the suite of different ML models required to make Elicit work. This is what an AI engineer will be responsible for at Elicit.
Our tech stack
Backend: Node and Python (probably shifting more to Node over time).
Frontend: Next.js and TypeScript (we expect you to be 80+% focussed on backend work, however).
We like static type checking in Python and TypeScript
All infrastructure runs in Kubernetes across a couple of clouds
We use GitHub for code reviews and CI
Am I a good fit?
Consider the questions:
What's the difference between anyio
, trio
, and asyncio
?
What does the await
keyword do in JavaScript?
What is a Kubernetes pod, and how is it different from a container?
How would you manage state when using an LLM to power a conversation?
If you have a solid answer for these—without reference to documentation—then we should chat!
What you'll do
You'll own
Backend implementation of our "living document"
We believe that user interactions with language models should be much deeper than yet more chatbot interfaces.
We wrote about our living document approach which is one way in which users can have much richer LLM-powered product experiences.
You would work on, curate, extend, and improve the backend part of that technology. This is fascinating and challenging distributed systems work.
Building Elicit into a product researchers can’t live without
We ship useful, exciting features out to users on a weekly basis. Your focus will be on the code which exists between the BFF endpoints and the ML models we use.
You will work on a mix of known features / fixes, prototypes to validate ideas, and exploratory projects in between.
Our team is small, so we expect you to appreciate the user needs underlying everything you work on. You should be comfortable making decisions and trade-offs that help us fulfill users’ needs best.
Keeping Elicit’s bar for quality high
You’ll balance shipping features in the short term with building extensible and maintainable systems.
You will be responsible for your features in production: they need to be scalable, resilient, and easy to operate.
You’ll contribute to discussions around system design, performance evaluation, and architecture.
Projects you'll contribute to
You can view sample projects here.
Your first week
Your first month
Your first quarter
What you bring to the role
Strong technical aptitude that allows you to move comfortably around our back-end tech stack, with strong computer science fundamentals.
A genuine curiosity and enthusiasm for the capabilities of language models.
A defensive, fault-first mindset.
Above-average communication skills. Elicit is a small, highly-collaborative team, so you’ll frequently be tapped to communicate complex engineering topics with stakeholders across the company.
A sense of joy in what you do. One thing we love about our team at Elicit is that everybody’s a craftsperson who cares deeply about their field.
Who you’ll work with
This role will report directly to James, our Head of Engineering, and work very closely with the rest of the engineering team:
Luke (AI engineer, full-stack)
Panda (AI engineer, infra)
Justin (ML Engineer)
You'll also spend a lot of time collaborating with Kevin (Head of Product), and co-founders Jungwon & Andreas.
Compensation, benefits, and perks
In addition to working on important problems as part of a productive and positive team, we also offer great benefits (with some variation based on location):
Flexible work environment: work from our office in Oakland or remotely with time zone overlap (between GMT and GMT-8), as long as you’re comfortable traveling for in-person retreats and coworking events
Fully covered health, dental, vision, and life insurance for you, generous coverage for the rest of your family (FSA/HSA, too)
Flexible vacation policy, with a minimum recommendation of 20 days / year and plenty of company holidays
401K with a 6% employer match
$2,000 device budget to start, with more accumulating for each month of work
$500 / year personal development budget
A team administrative assistant who can help you with personal and work tasks
You can find more reasons to work with us in this thread!
For all roles at Elicit, we use a data-backed compensation framework to keep salaries market-competitive, equitable, and simple to understand.