The is ipsum dolor sit amet consectetur adipiscing elit. Fusce eleifend porta arcu In hac habitasse the is platea augue thelorem turpoi dictumst. In lacus libero faucibus at malesuada sagittis placerat eros sed istincidunt augue ac ante rutrum sed the is so
Read this before panicking about an LLM Pair Programmer taking away your job. We often stress the importance of the HITL (Human in The Loop) in any AI solution process. As we take baby steps playing around with the capabilities of LLMs (Large Language Models) to generate and debug code snippets, I realise there is some ground to cover. The mastermind behind the architecture deciding the cohesion among software application modules must be us, the humans.
Sometimes, the pair programmer has been more of a nuisance to me than help. I would have been better off starting coding from scratch and following the flow of thoughts. The last thing one would like to do is fix AI-generated codes rather than one’s own. This does not mean I am nay-saying. I am just suggesting having the human in HITL in the uppercase. There is a heavy reliance on the human programmer to verify the generated code and ensure it fits the context of the application and the intended use. The copilots, codestrals, and codegemmas of the world do an excellent job generating codes for GUI than for complex nested functionalities. They are competent at debugging syntax errors as well.
The human user should be adept at asking the right questions and framing the missing links for the code generator. Prompt engineering and smart application building would be required to get the most out of our pair programmers. The following snippet of a poem says it all. “I say the future, I cut the clutter / Feed me historical data, I am hungry / Feed me stale data I am angry / Use your intuition, I serve you well / Trust me blind, I make you fail / Thus, says the LLM genial”.
LLM pair programmers are also used for specific tasks beyond coding. They help explain a piece of code or the complete source code, aiding the human programmer in understanding what lies before them. They are also efficient at documenting. For example, they can be used for writing release notes. This helps reduce a software program’s technical debt, which is the additional effort necessary to maintain bad source code or rework poorly written ones. They can also be fantastic at generating exhaustive test cases for unit, system integration, and user acceptance tests.
Most pair programmers are available as tools that can be integrated with the source code editor itself. This makes our lives easier than entering the code snippet and the question on the LLM provider’s page. If the request is not precise or necessary boundaries are not mentioned, they hallucinate. Their creativity goes to the extent of inventing method names that never existed. Remember to set the temperature hyperparameter to a low value (for example, 0.2) if you use LLMs for code generation. This is one of the instances where creativity might be harmful. If you are generating a story or a poem, be my guest and set the temperature to 0.9 if that helps. Refrain from asking code-related questions to foundational LLMs that are not fine-tuned with vast volumes of code repositories. Certain fine-tuned LLMs are meant to generate code in specific programming languages. Look at the LLM’s documentation. One might handle Python programs better, while the other might be with C.
Our best bet for building an effective pair programmer is not to use LLM code generators directly. Instead, develop an application using two LLMs: one instruction-tuned LLM and a code-tuned LLM. The former understands our requests well, while the latter specialises in the coding task. We must not expect one of them to be efficient in both tasks.