On Creativity in Software Engineering and the Role of Generative AI
If one were to ask people on the street to name creative jobs, I would not expect software development to be mentioned very often. On the other hand, there are many tasks and activities in the daily work of a software developer that seem very creative to me. I would also describe myself as creative and developing software can be an outlet for this creativity.
In this article I want to explore if software engineering is creative. But this is not only a question of categorization. I want to use this exploration to get a deeper understanding of what creativity is. And I also want to think about the effect of GenAI on the work of software engineers and their creativity.
What is creativity?
A very basic definition of creativity involves originality and effectiveness1. So, being creative means coming up with something new that is effective towards a goal. For example, a random process could come up with something original. But this would then not be considered creative because it is not effective towards a given goal. For me this definition makes creativity already more graspable, moving it away from a mysterious property that only artists have towards something that could be useful when developing software.
In psychology this is a well-researched concept. Researchers often have the implicit or explicit goal of finding out how to improve people's creativity in order to solve big problems of our world. But before we investigate that, the definition above still feels somewhat simplistic and too broad to capture everything from Leonardo Da Vinci painting the Mona Lisa to me designing the logo for this blog. Kaufman and Beghetto propose a model to differentiate these2. They would call one of these Big-C creativity and the other one little-c. They also critique their field for focusing too narrowly: either on Big-C creativity by interviewing top creators in their fields, or on little-c creativity through studies on students and children in everyday contexts. That's why they introduce two additional forms of creativity: Mini-c, the
novel and personally meaningful interpretation of experiences, actions, and events3.
And Pro-c, which is the creativity of those that perform a task on a professional level. This concludes their Four C Model2:
- Big-C: Creativity of genius top-of-the-field artists.
- little-c: Everyday creativity necessary in daily activities.
- Mini-c: Personal and meaningful interpretation of experiences and learning.
- Pro-c: Professional-level creativity from experience in a specific domain.
For us, thinking about software engineering, this is very useful, because neither Big-C nor little-c seemed to fit what we are interested in. I think the type of creativity that works for engineers must be Pro-c. So, it is good to learn that psychology research had a bucket for the creativity of us engineers. But there is also research that explicitly looks at us.
Creativity in Software Engineering
A qualitative study interviewed engineers to clarify the role and extent of creativity in software engineering. The participants agree
that being creative is a requirement to successfully tackle complex problems4
But they also state, quoting another participant, that
‘Creativity is the means, not the goal.’4
Other authors also used interviews but go deeper in their analysis. They think about how creativity may be defined specifically in software engineering. They make the interesting observation on why the word creative is barely used in this context:
This is perhaps not because software isn’t creative but because creativity in software engineering might look different than in other domains5
And they identify three key themes of creativity in SWE:
- Collaboration fosters creativity
- Both individuals and teams do problem-solving by learning and exploration as basis for creativity
- Reuse and recombination of existing code5
These are interesting new aspects, that also help when thinking about how to increase creativity. Note that point 2 aligns with previously introduced Mini-c, indicating that my perceived relevance of Pro-c may not be the whole truth. Very central to that paper is the perception of creativity as reuse. This seems to be one of the ways creativity in SWE may look different from commonly perceived creativity.
Common Sense Understanding of Creativity
Using the background on creativity, I want to look at the initial confusion: Why do people generally not consider engineers to be creative?
What are occupations that are considered creative? I assume most of these actually relate to art and artists. My hypothesis is, that what people think of is primarily Big-C. And going back to Leonardo Da Vinci, while he was a brilliant engineer, the public primarily knows him for his paintings. But what is the difference between painting and programming? If both are considered creative, then—as we established—they must involve originality and effectiveness. And I think the biggest difference here lies in the effectiveness: While engineering effectiveness is measured against solving a concrete problem, the effectiveness in creative art is harder to grasp for me. How is art effective?
Firstly, there is an aesthetic aspect. Successful art is often considered beautiful by many. However, I doubt that a painting being merely pleasant to look at would achieve the same recognition as the Mona Lisa. That's why secondly, there is artistic expression. In my opinion, good art must be effective in the sense of conveying a message, evoking emotions or enabling reflection. Everything else is merely entertainment.
So, the most relevant difference between creativity in art, which is also the common understanding of creativity, and the creativity in software engineering is the goal. And with different goals, the effectiveness of the art is measured differently. While the goal in art is self-expression and beauty, the goal in engineering is solving problems. This is why in the public; creativity is often associated with art and with a degree of self-expression.
What Creativity Looks Like in Software Engineering
In the previously quoted paper, the special nature of creativity in SWE was identified as recombination of existing solutions. I think that this is an important aspect but doubt that it explains the core of this confusion. However, leaning into this idea, the recombination of existing solutions becomes particularly interesting in the context of open source software. If innovation is sped up through open source software6, and reuse is central to creativity in SWE, then usage of open source enables innovation through creative reuse. So, reuse and recombination are central aspects of creativity in SWE.
But I am skeptical that it can explain the difference to creativity in art, though. If we for example consider improvisation in jazz, then recombination of existing themes, phrases and what's called licks is crucial. While a jazz performance can seem random at first sight, it is always a clever recombination and variation of that what others have played before. This concept is not too different from a software engineer using libraries and implementing pre-defined algorithms to accomplish a specific technical goal. For example, Adorno sees the strength of technology in its contrast to the humanities: technology draws from a predefined set of existing techniques, whereas the humanities lack such a set of typical solutions7.
So, to summarize, while I agree that recombination is an important aspect of creativity in SWE, it is not the main difference to creativity in other fields or in common sense understanding of the phrase. The lack of common-sense identification for engineering as creative comes from
- Most people thinking of creativity predominantly as Big-C, the creativity of genius top-of-the-field artists.
- And from different goals: Artistic creativity follows the goal of aesthetics and self-expression while engineering follows the goal of problem-solving.
Nevertheless, both are creative when considering the typical definition involving originality and effectiveness. And the fact that the public does not consider software engineers to be creative may say more about them not knowing an awful lot about what we do than this question. This may also be the reason that many people think that all of us will be replaced by AI soon. While, GenAI undoubtedly has a huge impact on our work, this topic deserves a closer look.
The Influence of Generative Artificial Intelligence on Creativity in SWE
A lot has been said about the impact of GenAI on art89. And I very much share the feeling that AI doing creative tasks is the wrong direction, because I would much prefer to be creative and have AI take over the chores10. But is this also true for the use in SWE? Are we at the risk of having GenAI take all the joy out of programming? From my personal experience, at least with current tools, the opposite is true. For example, Copilot in Vscode is quite good at the boring parts of programming. If I make some change to one variable, it can extend that for the remaining variables.
On the other hand, it is quite bad at seeing the bigger picture of a software architecture or reason pros and cons about a used implementation. Reminding ourselves that creativity in SWE involves combining existing solutions, GenAI is good at coming up with a simple implementation using a popular library for one problem. But it is bad at deliberating what the best tool for given job is or how a given approach could be improved when this involves seeing the bigger picture.
There is also research exploring the potential impact of GenAI on creativity in SWE. The paper11 I want to look at primarily combines two models:
- The 4P framework of creativity that looks at four components to the creative process: Person, Product, Process and Press (the environment). It explains how these components influence creativity, where Person refers to the individual being creative, Product looks at the outcome or artifact, Process considers the methods and techniques used and Press is the wider environment including social, cultural, economic, and physical aspects12.
- The McLuhan tetrad, designed to think about potential impacts of a new technology using 4 questions on how that technology: (a) enhances, (b) makes obsolete, (c) retrieves from obsolescence, and (d) reverses into when pushed to extremes13.
The paper then combines these two models in what we engineers would call a cartesian product. The authors use these sixteen scenarios for brainstorming possible effects. The resulting consideration fields are all very interesting and allow for a deep and wide consideration of the impacts of GenAI on SWE and I recommend everyone to read the paper11. But in the context of this discussion most interesting are:
-
The 4P field person looked at through the retrieves question:
Creative Work Today, creativity often takes a backseat to productivity. With GenAI taking the burden of writing code, developers will have more time to engage in fun, creative work.11
(italic formatting by the authors)
This goes in the direction that I indicated above, that GenAI can help programmers with those parts of the job that are mundane, the second quote hints at potential risks of self-reinforced patterns:
-
The 4P field product looked at through the reverses into question:
Echo Chamber The more new products resemble common products that GenAI "understands", the more GenAI's suggestions could become self-reinforcing, thereby limiting exposure to truly novel ideas.11
(italic formatting by the authors)
Considering that these tools today are presumably trained a lot on code that is open source, these same tools help produce new open source code, and the cycle continues. But this is just one of the risks that the increased use of GenAI in SWE has. However, at least for current tools, it seems to me like the creativity of individual programmers could even gain in relevance. And I don't expect us to be replaced by an LLM generating code on our behalf any time soon.
Key Takeaways
In this article I tried to shed some light on creativity in software engineering. The key points are:
- Creativity requires originality and effectiveness.
- In SWE, creativity involves a lot of reuse and recombination of components, but it is creativity, nonetheless.
- The public probably thinks about creativity more in terms of art.
- Despite the rise of GenAI, the unique creativity of software engineers in problem-solving and innovation remains irreplaceable for now.
-
Runco, Mark A., and Garrett J. Jaeger. 2012. “The Standard Definition of Creativity.” Creativity Research Journal 24 (1): 92–96. https://doi.org/10.1080/10400419.2012.650092. ↩
-
Kaufman, James C., and Ronald A. Beghetto. 2009. “Beyond Big and Little: The Four C Model of Creativity.” Review of General Psychology 13 (1): 1–12. https://doi.org/10.1037/a0013688. ↩↩
-
Beghetto, Ronald A., and James C. Kaufman. 2007. “Toward a Broader Conception of Creativity: A Case for" Mini-c" Creativity.” Psychology of Aesthetics, Creativity, and the Arts 1 (2): 73. https://doi.org/10.1037/1931-3896.1.2.73. ↩
-
Groeneveld, Wouter, Laurens Luyten, Joost Vennekens, and Kris Aerts. 2021. “Exploring the Role of Creativity in Software Engineering.” arXiv. https://doi.org/10.48550/arXiv.2101.00837. ↩↩
-
Inman, Sarah, Sarah D’Angelo, and Bogdan Vasilescu. 2024. “Developer Productivity for Humans, Part 8: Creativity in Software Engineering.” IEEE Software 41 (2): 11–16. https://doi.org/10.1109/MS.2023.3340831. ↩↩
-
Henkel, Christian. 2025. “How Do Personal and Company Identities Shape Open Source Contributions?” Thinkoneering. https://thinkoneering.com/thinkoneering/25\01\oss\identity/. ↩
-
Theodor W Adorno. 1953. “Über Technik Und Humanismus.” In Technik Und Ethik. Reclam. ↩
-
Claudia Baxter. 2024. “AI Art: The End of Creativity or the Start of a New Movement?” BBC. https://www.bbc.com/future/article/20241018-ai-art-the-end-of-creativity-or-a-new-movement. ↩
-
Duncan Crabtree-Ireland. 2025. “How AI Can Empower, Not Replace, Human Creativity.” World Economic Forum. https://www.weforum.org/stories/2025/01/artificial-intelligence-must-serve-human-creativity-not-replace-it/. ↩
-
Maciejewska, Joanna. 2024. “You Know What the Biggest Problem with Pushing All-Things-AI Is? ...” Tweet. Twitter. https://x.com/AuthorJMac/status/1773679197631701238. ↩
-
Jackson, Victoria, Bogdan Vasilescu, Daniel Russo, Paul Ralph, Maliheh Izadi, Rafael Prikladnicki, Sarah D’Angelo, Sarah Inman, Anielle Lisboa, and Andre van der Hoek. 2024. “Creativity, Generative AI, and Software Development: A Research Agenda.” arXiv. https://doi.org/10.48550/arXiv.2406.01966. ↩↩↩↩
-
Rhodes, Mel. 1961. “An Analysis of Creativity.” The Phi Delta Kappan 42 (7): 305–10. https://www.jstor.org/stable/20342603. ↩
-
McLuhan, Marshall. 1977. “Laws of the Media.” ETC: A Review of General Semantics 34 (2): 173–79. https://www.jstor.org/stable/42575246. ↩