LLM Programming

LLM Programming

We are almost at the one year anniversary of OpenAI's introduction of ChatGPT - November 30th, 2022. There is an earlier date that is equally important - June 11, 2020 when GPT-3 was first released. That was the moment when OpenAI became the first company to release a foundation model which was actually useful. There were certainly some early researchers impressed enough about a year earlier (February 2019) when OpenAI released GPT-2 to point out that this new model had enormous promise (GPT-2 is not as dangerous as OpenAI thought it might be as a reminder of what smart people were saying just a few years ago...)

Indisputably though, the November 30th release awakened the world to the potential of this new technology. While there were improvements in the model itself (and the company acknowledged this by calling it version "3.5") the biggest change from GPT-3 was in the way users accessed the model - a conversational interface. While this made GPT technology accessible, it also framed the way to use the technology too narrowly with most people only thinking of it in this conversational mode.

Ethan Mollick wrote about this in early November, "Working with AI: Two paths to prompting" and the goal of my article will be to push that thinking a bit further. If you are looking to use LLMs in enterprise use cases, you will want to take the second path, which Ethan calls "structured prompting"

First let's summarize the difference between these two approaches to using an LLM (with thanks to Ethan Mollick's excellent longer discussion linked above). Conversational prompting and structured prompting represent two distinct approaches to interacting with AI systems:

Conversational Prompting:

  • Nature: Informal, intuitive, and akin to a casual conversation with a human.
  • Method: Users engage with the AI in a conversational manner, providing context and explaining their needs in a free-flowing format.
  • Flexibility: Highly adaptable to varied topics and questions without requiring specific structures.
  • Context Sensitivity: Effective use requires providing contextual information to guide the AI towards more relevant and specialized responses.
  • Strengths: Ideal for exploring ideas, brainstorming, and receiving general information.
  • Limitations: May lead to less precise or focused responses due to its open-ended nature.

Structured Prompting:

  • Nature: Methodical, structured, and designed to elicit specific, task-oriented responses.
  • Method: Involves crafting prompts with clear goals, step-by-step instructions, and defined roles/goals for the AI.
  • Precision: More likely to produce consistent and targeted outputs, as it narrows down the AI's response scope.
  • Components: Includes role/goal definition, explicit instructions, constraints, personalization, and sometimes few-shot examples.
  • Strengths: Useful for specialized tasks, complex problem-solving, and when precision is critical.
  • Limitations: Requires more effort and expertise to create effective prompts and may be less flexible in handling varied queries.

In essence, conversational prompting is akin to a fluid, exploratory dialogue, while structured prompting is like giving the AI a detailed blueprint to follow for a specific task. Correctly configuring a structured use case is effectively a programming task. One of the reasons people struggle to understand the applicability of generative AI to business problems is that they are trapped in thinking about only a conversational approach and they haven't considered the benefits of programming an LLM.

So how do you program an LLM? Here are several guidelines:

Be precise and unambiguous: The programming language you will use is English or French or whatever language you speak. A "natural language" -- one that evolved naturally through usage by humans. Contrast this with the programming languages we typically use which are logically designed with precise and unambiguous terms that follow strict syntax and structure rules. LLM programming benefits from using natural language in a precise and unambiguous manner.

Logical design: Writing a computer program requires a lot of planning -- what do you want to happen first, second, third... What do you do if X happens vs. Y happens. This same logical design should go into your LLM programming.

Multiple steps to accomplish a goal: Don't try to do too much all at once but rather consider how your desired outcome is a series of steps in a process. Then break up your LLM instructions into these steps where you have more control in creating a consistent output with each one. This will allow you to build your desired outcome through the series of steps, directing the LLM precisely through the process. This can require a whole series of requests, not just one, to the LLM.

Context management: Perhaps the most important topic of LLM programming is in the instructions that surround and create context for the specific direction that you are giving the LLM in a particular step. A simple example which OpenAI has built into their ChatGPT interface is called "custom instructions" (available as a setting when you are logged in). This feature lets you create an overarching context for any of your conversational prompts. "Always speak like a pirate in your answers" might be a silly context to use. But context can have many layers in a structured LLM usage and managing how these layers are used at each step is crucial to generating consistent and accurate results.

Hopefully this brief outline will give you a start on thinking about how to use LLMs in a completely different way from the conversational interaction of a ChatGPT!



Adarsh Panda

AI & Data Science Lead|GenAI|LLMOps | Cloud

11 个月

Great articulation ted, thanks. Engineering rigour around prompt management/controls is crucial for enterprise adaption as mentioned

Brian Collier PhD MBA

SVP & Portfolio Director @ Goods&Services | MBA

11 个月

Another great article Ted, which made me wonder; How are organizations preparing their teams for the shift from conversational to structured prompting in AI interactions? Given the precision and logical structuring required for effective use of structured prompts in enterprise applications, what training methodologies and best practices are being adopted to equip employees with the necessary skills? I’m particularly interested in hearing about innovative training approaches or success stories in seamlessly integrating this skill set into the professional development framework of businesses embracing AI technology.

Kami Adibi MD,

Physician Leader, AI enthusiast, Health Equity Advocate

11 个月

Very insightful.

回复

要查看或添加评论,请登录

Ted Shelton的更多文章

  • The Turing Dilemma

    The Turing Dilemma

    In The New Yorker's "Weekend Essay," the fabulous science fiction author Ted Chiang opines on "Why A.I.

    13 条评论
  • Possible futures

    Possible futures

    A little bit in the future "The risk of under investing is dramatically greater than the risk of over investing," said…

    10 条评论
  • Meta + Ray Ban

    Meta + Ray Ban

    (a guest post from my daughter Paloma Shelton) As I grab my everyday essentials when I’m leaving the house—phone, keys,…

    8 条评论
  • Containment

    Containment

    where we are now According to a recent article in "The Information" an unnamed employee at Meta has stated that they…

    26 条评论
  • Where it all began

    Where it all began

    (an entry in the "how we got here" category) I have written in the past a bit about Frank Rosenblatt, the Cornell…

    3 条评论
  • Access to the future

    Access to the future

    (a "where we are going" entry..

    4 条评论
  • Transforming business with AI

    Transforming business with AI

    About ten years ago, when I had one of the world's largest retailers as a client, I visited their headquarters building…

    6 条评论
  • Mustafa Suleyman

    Mustafa Suleyman

    In 1984 I graduated from high school and headed off to my first year of college. That was the same year that Mustafa…

    6 条评论
  • First look at a new world

    First look at a new world

    When I wrote my newsletter post last week announcing my decision to join an amazing group of re-founders at Inflection…

    12 条评论
  • An Inflection Point

    An Inflection Point

    Palo Alto, CA, March 8, 2023 - For all of computer history, we have had to learn the language of computers. With the…

    128 条评论

社区洞察

其他会员也浏览了