Hacker News new | past | comments | ask | show | jobs | submit login
Gen AI will increase demand for software engineers (roarepally.com)
49 points by ro_arepally 7 months ago | hide | past | favorite | 60 comments



AI isn't about to become capable of doing the job of a software developer any time soon, not least because two of it's major weaknesses - extremely limited reasoning ability and extremely limited learning ability (in-context only) are the two things that software developers most heavily lean on. It's not clear whether these are things that can really be addressed without major architectural change.

There's still massive hype and group think about LLMs and what people project they will soon be able to do (or even what they can currently do - Dwarkesh's insider friends surprised it fails on Chollet's simple ARC tests!). A large part of this seems to be based on how new the tech is, and how capable it is, but people seem to be forgetting that the capability is based on brute force training time gradient descent. There is no runtime gradient descent or any alternative runtime learning method ... just limited in-context learning by example.


What kind of time frame is "any time soon"?

If you're thinking over the next 3-5 years, then AI is a novelty in most cases, a useful tool in some cases, and something truly disruptive in a fairly narrow set of cases.

If you expand the time frame to 10-20 years, then AI is poised to become something that truly upsets most of the economy. Obviously, nothing can be said for certain, there could be black swan events, etc. But on the current trajectory of cheaper, more powerful compute and better understanding of the engineering around getting useful results out of AI, you'd be foolish to think any white collar profession won't be deeply affected by the technological shift that's coming.


> If you expand the time frame to 10-20 years

This feels like a lot of "20 years away" type predictions. There needs to be some sort of step change in the technology, and perhaps more than one or on more than one front to make this possible but its far enough away that 20 years feels like a safe bet.

When people say this about LLM based AIs, I wonder how they imagine text prediction making those step changes. Is your thinking that text prediction is generalization enough that doing more of it better, faster, and on scaled hardware is sufficient to hit a tipping point?


I think the idea behind the "10-20 year" timeframe is that that's how long current technological changes will take to propagate into social & economic changes, like how HTTP was invented in 1989 but we didn't get e-commerce until 1995 or social networking until 2002.

LLMs dramatically reduce the price of bullshit. It follows that they'll likely reduce the value of bullshit too, but we don't know to what extent or how that'll affect the organization of the economy until entrepreneurs generate vast bullshit factories and counterparties start adjusting their behavior to adapt to it. A huge swath of the economy runs on bullshit, from media to PR to sales to venture capital to politics. How these industries are structured will likely change when writing vast quantities of truthy-enough-to-be-convincing text becomes insanely cheap.


> If you expand the time frame to 10-20 years, then AI is poised to become something that truly upsets most of the economy. Obviously, nothing can be said for certain, there could be black swan events, etc. But on the current trajectory [...]

This is an interesting framing that I think exposes a key difference between people who view AI dominance as inevitable and those who don't. You view the progress of AI slowing down as a black swan event, something that's extremely unlikely. I, on the other hand, view it as inevitable.

Technology has never progressed along a single axis linearly or exponentially for very long. Technology progresses in bursts—there's a major breakthrough that leads to a huge amount of interest and progress which leads to rapid growth in a particular area until it saturates. After a few years we start to see diminishing returns as the area opened by the breakthrough becomes fully explored, and eventually progress becomes very slow indeed until the next major breakthrough.

Given this general pattern of progress in technology, it would be very foolish indeed to predict the next 20 years' trajectory of AI less than 2 years after ChatGPT was released.


You worded your comment much better than I did, and you touch on the key point in all of this which is the assumption that chatGPT etc will continue to get noticeably better at regular intervals. It’s entirely possible that openAI has reached a local maximum with the data, compute, and model structure they have available.

The data is tapped out for the most part. They already probably acquired 80% of the available text training data.

Compute is now heavily cost constrained. This is obvious because even GPTs responses have gotten worse over the last 6 months, especially with image generation tasks. Likely because they’re throttling compute.

Model structure: OpenAI has admitted that they cannot understand why chatGPT has generated a given output. If you can’t explain your model you can’t improve it either. And more compute won’t help you that much here if I had to guess.


I also think human level (and beyond) AGI is inevitable, but that in of itself says nothing about the time frame in which it will be achieved. People have been predicting AI/AGI ever since the advent of computers over 70 years ago, and estimates have always been way over-optimistic.

It's perhaps relevant to note that the reason estimates have always been off seems to be that people have always thought that the technology of the day was sufficient, and that it was just a matter of applying it. So far we've had procedural programming (SHRLDU), expert systems (CYC), general-purpose problem solvers (SOAR), PDP/connectionist approaches, modern neural nets, LLMs...

I do think we're getting closer, and that neural nets will get us there (maybe not with gradient descent as the learning method though). There have been lots of valuable lessons and insights learned from various neural net architecture, not least of which is the confirmation by LLMs that prediction seems to be the basis (or at least one of major pillars) of intelligence.

And yet, I can't help but feel that there is still a long way to go ...


> What kind of time frame is "any time soon"

I'm guessing that solving run-time learning may well require a different approach, and it's not clear that reasoning (in general form - ability to dynamically synthesize a problem-specific solution) can be just added to LLMs either (e.g. by adding tree search). There are also other missing components such as working memory that seem simpler to solve.

Coming up with brand new architectures and learning approaches is likely to take time. There have been attempts to find alternatives to gradient descent, but none very successful despite a lot of effort.

Perhaps it's just a reflection of people chasing the low hanging fruit (and as Chollet says, LLMs "sucking all the oxygen out of the room"), but architectural advance post-LLM has been minimal. In 7 years we've basically just gone from transformer paper to big pre-trained transformers.

Even when workable architectural approaches to run-time learning and reasoning have been developed, they will also need to be scaled up (another 7 years?), and will also be competing with LLMs for mindshare and dev. resources as long as scaling LLMs continues to be seen as profitable.

The timescale for coming up with new architectures and approaches is hard to predict. AGI prediction timeframes have always been wrong, and the transformer was really one of history's accidental discoveries. Who'd have guessed that a better seq-to-seq model would create such capabilities!

If I had to guess, I'd say human-level AGI (human-level in terms of both capability and generality) is still 15-20 years away at least. 7 years to go from small transformers to big transformers doesn't make me optimistic that architectural innovation is going to happen very quickly, and anyways this is an unpredictable research problem, not an engineering one.


But even now the LLMs absolutely have limited problem solving capability.

For example, yesterday I asked GPT-4o to write multiple alternate endings to the short story "The Last Equation". They weren't dramatically compelling, but they were logical and functional.

How is that not problem solving? And so help me, before anyone tells me it's just stringing together the next most likely tokens - I don't care. Clearly that is at least a primitive form of intelligence. Actually it's not even apparent to me that that isn't exactly what human intelligence is doing...


I would define intelligence as "degree of ability to use past experience to predict future outcomes" (which includes reasoning, aka problem solving ability, via repeated what-if prediction, then backtracking/learning on failure etc).

So, intelligence exists on a spectrum - some things are easier to predict given a set of learnt facts and methods than others. The easiest things to predict (the most basic form of intelligence) is "next time will be the same as last time", which is basically memorization and pattern matching, which is mostly what LLMs are able to do thanks to brute-force pattern/rule extraction via gradient descent.

Going beyond "next time will be the same as last time" is where reasoning comes in - where you have the tools (experience) to solve a problem, but it requires a problem-specific decomposition into sub-problems and trial-and-error planning/testing to apply learnt techniques to make progress on the problem...

Certainly a lot of human behavior (applied intelligence) is of the shallow "system 1" pattern matching variety, but I think this is over stated. Not only is "system 2" problem-solving needed for on-the-job training, but I think we're using it all the time when we're doing anything more than reacting to the current situation in mindless fashion.

So, sure, LLMs have limited intelligence, but it's only "system 1" shallow intelligence, gestalt pattern recognition, based on training-time gradient descent learning. What they are missing is run-time "system 2" problem-solving.


There are a lot of assumptions built into your statement that AI will “upset” most of the economy in 20 years. Impact? Sure. But your argument seems to be implying AGI will be achieved (at scale, no less) in 20 years. This is an extraordinary claim even if Altman likes to throw out 5 year timelines for AGI. Similar to how musk (who is also a VC not an engineer or scientist) has been saying self driving teslas were right around the corner for the last ~7 years.

AI today is not even close to replicating the brain’s ability to perform multiple tasks together without suddenly hallucinating a totally different task at multiple points in the project. LLMs are good at regurgitating text, I would hope so after they just memorized all available text data. I can feel the chill of the next AI winter right around the corner, personally.


What is "AI"?

Definitions vary, but all definitions I have heard seem to boil down to one thing: AI is little more than a set of fancy programming languages. Which means you still always need a human to be the programmer. Nothing really can change for the white collar so long as you still have to provide instruction. That's what white collar people do.

"AGI" draws a distinction – where the machines start to be able to act as completely independent agents without needing a human to give instruction. Is this, perhaps, what you are envisioning in 10-20 years?


This article feels like stating an opinion. I suppose the autopilot analogy is at the heart of their argument but the argument as of now feels a bit too flat. There are definitely some jobs that technology completely displaced, and there are some that merely made something more accessible. For example, grinding grain with the advent of modern milling equipment vs microwaves. Milling machines make hand driven milling something of a niche whereas microwaves arguable have displaced no jobs in cooking and food preparation. We need more of an argument as to why GenAI will be more of a microwave technology vs a mill.

Anyway, I actually am more towards this is a hype cycle that will pass, it's just the article itself didn't really drive home the argument in my opinion.


> Milling machines make hand driven milling something of a niche whereas microwaves arguable have displaced no jobs in cooking and food preparation.

I would argue that generative AI in the hands of an already skilled developer is equivalent to the mill scenario. One person's expertise leveraged by way of this tool can allow for output that is orders of magnitude greater. The mere inertia of the "machine" encourages more productivity than otherwise. It is almost as if it is pulling you forward when you use it properly. Knowing when not to use it is also very important.

The concerns over hallucinatory output do not seem as relevant to me in this scenario of highly-skilled milling machine operator. You expose yourself to something for 10k+ hours and you will immediately recognize when it does something funny. Novices will cause trouble in any domain regardless of quirks in their tools. I don't think lack of experience should be conflated with hallucinations when evaluating the impact these tools might have at large.


It's like having a team of hyperactive interns at your disposal.

They'll fetch you all the latest libs, best practices, code samples, etc.

But they have no idea how to apply it to the business case at hand, how to secure the code, what real world edge cases to protect against.

And half the time their code is suboptimal or doesn't quite compile ... and wait till they try complex async ...

It's a force-multiplier for good/experienced engineers, but it's going to devastate the market for white-collar sweatshops.


I've worked as a developer with developers for 10+ years, and I sure as hell don't always recognize when they start doing something funny... Not sure I'd be able to keep up with monitoring thousands of lines of generated code beyond simple boiler plate stuff.


> This article feels like stating an opinion

You nailed it. This kind of thing should be saved for a personal blog and not printed in a scientific journal.


It literally says "my personal blog" at the top


I could publish a peer-reviewed paper on how that was the joke.


save it for your personal blog


wait, is Your Personal Blog a new peer-reviewed scientific journal?


He's not arguing that no jobs will be displaced, he's arguing that jobs will change, engineering may become more reliable, new types of software jobs may be created.


Not for RAG and Automation applications But for Fixing Hallucinated code that written by Non Software Engineers.


It's frustrating just how shit AI is at coding. The new gpt model seems even worse, splurging out a load of guff that makes it even more difficult to see the bullshit it's produced.

AI a threat to humanity, my ass.


Weird, I find that I get very good results with GPT-4 and GPT-4o. It helps to be in a position where you can communicate very explicit instructions on what and how to build. Use it like you’re planning what to code each step but just letting this mechanism do the typing. General writing and technical communication skills are a must so I can understand why some developers struggle with LLMs.


> General writing and technical communication skills are a must

Perhaps that is what he is trying to get at? I am sure my communication skills are poor, but I found utility in using these tools a year or so ago. Whatever gibberish I was able to give it often produced a good result. These days I can't seem to get anything usable out of them. It does seem, like the parent suggests, that they have gotten worse.

It may very well be that said tools are no worse, if even better, where communication ability is stronger. However, if we have chosen to optimize these systems for those who are great at communicating, at the cost of those who are not, that doesn't help with the topic at hand. The non-software engineers – implying Average Joe – are almost certainly not going to be great technical writers.


Human engineers of course never make mistakes, which is why we don't have PRs or unit or integration tests and canary deploys or anything that would catch mistakes before going to production because that would be a waste of time.


That is completely contingent on if present the day SWEs stop working on trying to eliminate the hallucinations.


The fundamental technology of LLMs *is* statistical hallucination. What's the probability of a sequence of tokens given a context? That's what LLMs answer.

I am not one to talk in absolutes but the basic circumstances of current LLMs have hallucination at their core and can likely not be guaranteed fact based. It's just an expression of likelihood where you rely on your training data to contain truths.

This is why OpenAI gives more weight to Wikipedia than Reddit comments - the model contains no reasoning mechanism.

It ought to be treated more as a fallible human rather than a superintelligent lookup resource based on fact checked data.


I'm curious as to what engineering solutions you think are available to solve this problem?

All the solutions I've heard up until now is "we just need more data" which isn't particularly sustainable or something a SWE would be in charge of doing


It’s not my expertise. However, if it’s a barrier to adoption it’s a problem to solve and will be.

AI is exponentially improving and there is no reason to believe that this won’t continue.


That's not how technology typically advances. Technology advances in waves. There's an initial breakthrough that leads to rapid progress in certain areas. But after some time there are diminishing returns as the the applications of that breakthrough are fully explored, and progress slows or stops until the next breakthrough. Predicting that the trajectory of progress for the next 20 years will match the progress that has been made in the first 2 years after the LLM breakthrough seems naive at best.

I would also disagree with the idea that LLM tech is "exponentially improving" now. There was the initial release of ChatGPT which was an enormous step forward, but since then its been small iterations on the same fundamental technology. We are already seeing significantly diminishing returns in our ability to improve these models. Most available training data has already has already been fed in, 10xing the compute results in only marginal improvements in performance, etc.


I guess we will see, but I can tell you after nearly 40 years of being in technology, I have never seen us go backwards, only forward and in the last 5 years forwards faster than ever.

And with that experience I am advising my grandkids to look at trades for their future careers. Because there is zero doubt in my mind that nearly every job that requires a college education today is going to be gone in 20 years.


> AI is exponentially improving

Not for the last two years at least. Over the last year it's been obvious that there are diminishing returns already...

We increase the computational power by a factor of ten, and see a factor of 1.5 improvement.


> AI is exponentially improving

The theoretical research may have improved exponentially. Implementations available for use seem to be on the decline – at best, stagnant. I find less and less utility as time goes on. Things LLMs shined at a couple of years ago now produce garbage. And for creative work, the output is much too formulaic, which was all well and good initially while still novel, but one has to keep pushing new boundaries and the current crop of tools really seems to struggle with that.


Or just getting it below the base rate of human software programmers. Humans hallucinate all the time; we've just built the systems around ourselves to tolerate a bit of silliness.


What is the definition of a hallucination in the context of LLM?


> But for Fixing Hallucinated code that written by Non Software Engineers.

And for testing to find those inconsistencies.


This sounds like hell, tbh.


Sounds like basically the same hell as reviewing code of junior SWEs.


And for reviewing failed tests that were hallucinated by LLM testing software. And for fixing the consequences of LMM testing giving false negatives.


Does RAG mean Retrieval-Augmented Generation? I've never heard of this term.


Yes, but it will strongly decrease demand for new ideas. AI is a "win more" technology for current software architecture incumbents. The more popular a tech is, the more content there is about it, the more capable an LLM is of giving a usable answer. A programmer who relies on LLMs for coding assistance will be far less likely to try something new, and it will have a chilling effect on the adoption of all new tools, architectures, and libraries.


If there is a way for LLMs to always suggest the best practices for a given task (e.g. upsampling on those tasks), then SE devs won't make trivial errors. So the knife can cut both ways. In fact it can become a source of uptodate information if augmented properly.


I can kind of see that argument but it reminds me of when a new programming language comes out and there's no IDE support for it.

That definitely stops some developers from considering it, others are happy to use just a standard editor without intellisense, etc.


Gen AI increases the demand for software engineers, but software engineers increase the demand for AI for code assistance. You are right, of course, but the number of programmers not using AI code assist will asymptotically approach some very low minimum, thanks for the productivity boost. I keep hearing "3x" and that feels about right to me. The same could not be said for intellisense, or at least is harder to quantify.


GenAI will indeed drop the cost of software creation and therefore increase demand for more software.

Things that formerly were prohibitively expensive are now cheap enough to be doable. Which increases the market for software engineers that can get things done with the help of AI and other tools. These won't be the type of software engineers that specialize in things that should be automated but the type of engineers that can build a lot of stuff that formerly would have required them to delegate a lot of work to other engineers.

This is how the software developer community has historically grown actually. It used to be that software engineers were faffing about with punch cards, assembly code, etc. Working months to produce a few kb worth of software. No libraries or anything. It all ran on bare metal. These days what engineers build is the tip of the iceberg because it all runs on frameworks, libraries, operating systems, etc. that do all of the heavy lifting. Which makes them way more productive than their colleagues from half a century ago.


I'm writing a book about building mobile apps[1]. I've worked on it for over two years (I have a day job). When I started taking preorders, it coincided with the AI gold rush. I thought, "Fark, now people can just use AI instead of reading my book". But my sales are actually quite good (for a nobody).

Thankfully, AI is still not there yet to make "professional" (as most people would define it) apps—unless maybe when people start feeding my book contents into GenAI, ha! (I guess it's a compliment?)

Also, AI is like DB. Sure, you can use DBeaver or something to access it "raw", but 90% of us programmers are still hired to write a CRUD wrapper. Same thing with AI. It's more useful to have an app supercharged with AI wherever it makes sense.

[1] https://opinionatedlaunch.com


It’s weird that there’s people who seem to be “against” AI assisted programming.

That’s like being against IDEs or git.

It’s like writers who were brought up on typewriters being against word processors.


One way to think about ai programming is that it's another step on the continual ladder up from writing machine code to writing more in more 'human readable' programming languages. It's essentially a non-deterministic compiler from natural language to an intermediate representation like python. Even assuming it was able to near perfectly translate intent to code, that doesn't mean it will replace programmers, necessarily.

The way to think about the impact on employment is comparative advantage. https://www.investopedia.com/terms/c/comparativeadvantage.as... Even if AIs are better than humans at every programming task, there is still a limited amount of compute in the world and unlimited amount of potential work to do, so there will always be tasks available for humans to work on. If the cost of writing code becomes cheaper, there will be tasks to automate that aren't worth the effort to automate now, that will _become_ worth the effort to automate in the future.


There are different reasons.

Some people are against a technology which isn't mature enough. I don't know about word processors, but take digital photography for example. Some people stuck with film photography even after digital became cool because it was superior in some regards (such as dynamic range). Once digital improved in every way over film, those people moved too.

Another reason is job security. Why would someone support something that will leave him homeless and destitute just because the software will be superior?

Personally, I think that software engineering jobs will go up while AI assisted programming is perfected (10-20 years), and afterwards there will be a huge decline (10x shrinkage) once the tools won't need people anymore.


IDEs can be useful, but can also weaken developers. People get used to the IDE keeping track of bloated, overly complex interfaces. Autocompletion also leads to a style of development where every term must be defined before it can be used in any code. That may seem to make sense at first, but in practice means that it becomes impossible to freely sketch out code paths without first defining all terms. Depending on context this may all be appropriate and valuable, but it is worth keeping in mind that IDE saturated development has particular characteristics and may potentially amount to a crutch or even an impediment.


I for one used to hire people outside Germany for smaller projects, doing data analysis, writing interfaces, migrating data. With all the new tools I don't do this anymore. I can come up with solutions that are good enough, and I don't have the overhead with back and forth emailing, writing requirements, getting a result, giving feedback, etc. This is me, n=1.


And now that your time and resources are freed up from working with data analysts, presumably you will shift that towards software engineers who can deliver new value to your customers.

If not, your competition will.


Eh, it's only a matter of time until new nvidia clusters are in production and we start seeing what hardware designed for training massive models (roughly 100x bigger than anything we know of at least) can do.

With some additional architectural changes we might start seeing some sparks of real human stupidity.


Maybe 4x, 100x is many years away.

The exponential graph people are posting is just to pump the stock price.


The exponential graph, to the extent it is measuring anything, is measuring progress on LLM benchmarks, which are based on tasks that LLMs can tackle and show progress on.

The set of benchmarks used to measure LLMs do not include things that require significant run-time learning or reasoning (e.g. Chollet's ARC test, although frankly that's a pretty simple test).

This exponential progress will flatten once LLMs can no longer improve along that LLM-benchmark axis (maybe they score 100% on all LLM benchmarks), but this "100% achieved on all tests" won't mean "mission accomplished - AGI achieved!", it'll just mean it's time for a new set of more challenging benchmarks, one step closer to what humans are capable of.


That's incorrect, it isn't that better than h100s


They chain a lot better and have much lower software complexity while also being able to share memory between two different nodes.

Also the latency is much lower. (Also I'm sort of mocking LLM's here)


GenAI is a pipe dream.




Consider applying for YC's Spring batch! Applications are open till Feb 11.

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: