Using OpenAI Without Function Calling
In this section, we will generate responses using the GPT-3.5-Turbo model without function calling to see if we get consistent output or not.
Before installing the OpenAI Python API, you must obtain an API key and set it up on your local system. Follow the GPT-3.5 and GPT-4 via the OpenAI API in Python tutorial to learn how to get the API key and set it up. The tutorial also includes examples of setting up environment variables in DataLab, DataCamp's AI-enabled data notebook.
For further assistance, check out the code in OpenAI Function Calling workbook on DataLab.
Upgrade the OpenAI Python API to V1 using:
pip install --upgrade openai -q
After that, initiate the OpenAI client using the API key.
import os from openai import OpenAI client = OpenAI( api_key=os.environ['OPENAI_API_KEY'], )
Note: OpenAI no longer offers free credits to new users, so you have to buy them to use the API.
We will write a random student description. Either you can come up with your own text or use ChatGPT to generate one for you.
student_1_description = "David Nguyen is a sophomore majoring in computer science at Stanford University. He is Asian American and has a 3.8 GPA. David is known for his programming skills and is an active member of the university's Robotics Club. He hopes to pursue a career in artificial intelligence after graduating."
In the next part, we will write a prompt to extract student information from the text and return the output as a JSON object. We will extract the name, major, school, grades, and clubs in the student description.
# A simple prompt to extract information from "student_description" in a JSON format. prompt1 = f''' Please extract the following information from the given text and return it as a JSON object: name major school grades club This is the body of text to extract the information from: {student_1_description} '''
Add the prompt to the OpenAI API chat completion module to generate the response.
# Generating response back from gpt-3.5-turbo openai_response = client.chat.completions.create( model = 'gpt-3.5-turbo', messages = [{'role': 'user', 'content': prompt_1}] ) openai_response.choices[0].message.content
The response is quite good. Let’s convert it into JSON to understand it better.
'{\n "name": "David Nguyen",\n "major": "computer science",\n "school": "Stanford University",\n "grades": "3.8 GPA",\n "club": "Robotics Club"\n}'
We will use the `json` library to convert the text into a JSON object.
import json # Loading the response as a JSON object json_response = json.loads(openai_response.choices[0].message.content) json_response
The final result is pretty much perfect. So, why do we need Function Calling?
{'name': 'David Nguyen', 'major': 'computer science', 'school': 'Stanford University', 'grades': '3.8 GPA', 'club': 'Robotics Club'}
Let’s try the same prompt, but using a different student description.
student_2_description="Ravi Patel is a sophomore majoring in computer science at the University of Michigan. He is South Asian Indian American and has a 3.7 GPA. Ravi is an active member of the university's Chess Club and the South Asian Student Association. He hopes to pursue a career in software engineering after graduating."
We will just change the student description text in the prompt.
prompt2 = f''' Please extract the following information from the given text and return it as a JSON object: name major school grades club This is the body of text to extract the information from: {student_2_description} '''
And, run the chat completion function using the second prompt.
# Generating response back from gpt-3.5-turbo openai_response = client.chat.completions.create( model = 'gpt-3.5-turbo', messages = [{'role': 'user', 'content': prompt_2}] ) # Loading the response as a JSON object json_response = json.loads(openai_response.choices[0].message.content) json_response
As you can see, it is not consistent. Instead of returning one club, it has returned the list of clubs joined by Ravi. It is also different from the first student.
{'name': 'Ravi Patel', 'major': 'computer science', 'school': 'University of Michigan', 'grades': '3.7 GPA', 'club': ['Chess Club', 'South Asian Student Association']}
OpenAI Function Calling Example
To resolve this issue, we will now use a recently introduced feature called Function Calling. It is essential to create a custom function to add necessary information to a list of dictionaries so that the OpenAI API can understand its functionality.
- name: write the Python function name that you have recently created.
- description: the functionality of the function.
- parameters: within the “properties”, we will write the name of the arguments, type, and description. It will help OpenAI API to identify the world that we are looking for.
Note: Make sure you are following the correct pattern. Learn more about function calling by reading the official documentation.
pip install --upgrade openai -q
Next, we will generate responses for two student descriptions using a custom function added to the "functions" argument. After that, we will convert the text response into a JSON object and print it.
import os from openai import OpenAI client = OpenAI( api_key=os.environ['OPENAI_API_KEY'], )
As we can see, we got uniform output. We even got grades in numeric instead of string. Consistent output is essential for creating bug-free AI applications.
student_1_description = "David Nguyen is a sophomore majoring in computer science at Stanford University. He is Asian American and has a 3.8 GPA. David is known for his programming skills and is an active member of the university's Robotics Club. He hopes to pursue a career in artificial intelligence after graduating."
Multiple Custom Functions
You can add multiple custom functions to the chat completion function. In this section, we will see the magical capabilities of OpenAI API and how it automatically selects the correct function and returns the right arguments.
In the Python list of the dictionary, we will add another function called “extract_school_info,” which will help us extract university information from the text.
To achieve this, you have to add another dictionary of a function with name, description, and parameters.
# A simple prompt to extract information from "student_description" in a JSON format. prompt1 = f''' Please extract the following information from the given text and return it as a JSON object: name major school grades club This is the body of text to extract the information from: {student_1_description} '''
We will generate a “Stanford University” description using ChatGPT to test our function.
# Generating response back from gpt-3.5-turbo openai_response = client.chat.completions.create( model = 'gpt-3.5-turbo', messages = [{'role': 'user', 'content': prompt_1}] ) openai_response.choices[0].message.content
Create the list of student and school descriptions and pass it through the OpenAI chat completion function to generate the response. Make sure you have provided the updated custom function.
'{\n "name": "David Nguyen",\n "major": "computer science",\n "school": "Stanford University",\n "grades": "3.8 GPA",\n "club": "Robotics Club"\n}'
The GPT-3.5-Turbo model has automatically selected the correct function for different description types. We get perfect JSON output for the student and the school.
import json # Loading the response as a JSON object json_response = json.loads(openai_response.choices[0].message.content) json_response
We can even look under the name that the repose is generated using the “extract_school_info” function.
Applications of Function Calling
In this section, we will build a stable text summarizer that will summarize the school and student information in a certain way.
First, we will create two Python functions, extract_student_info and extract_school_info, that take the arguments from function calling and return a summarized string.
pip install --upgrade openai -q
- Create the Python list, which consists of student one description, random prompt, and school one description. The random prompt is added to validate the automatic function calling mechanic.
- We will generate the response using each text in the `descriptions` list.
- If a function call is used, we will get the name of the function and, based on it, apply the relevant arguments to the function using the response. Otherwise, return the normal response.
- Print the outputs of all three samples.
import os from openai import OpenAI client = OpenAI( api_key=os.environ['OPENAI_API_KEY'], )
- Sample#1: The GPT model has selected “extract_student_info,” and we got a short summary about the student.
- Sample#2: The GPT model has not selected any function and treated the prompt as a regular question, and as a result, we got the biography of Abraham Lincoln.
- Sample#3: The GPT model has selected “extract_school_info,” and we got a short summary about Stanford University.
student_1_description = "David Nguyen is a sophomore majoring in computer science at Stanford University. He is Asian American and has a 3.8 GPA. David is known for his programming skills and is an active member of the university's Robotics Club. He hopes to pursue a career in artificial intelligence after graduating."
Conclusion
In this tutorial, we learned about OpenAI's function calling. We also learned how to use it to generate consistent outputs, create multiple functions, and build a reliable text summarizer.
If you want to learn more about the OpenAI API, consider taking the Working with OpenAI API course and using the OpenAI API in Python cheat sheet to create your first AI-powered project.
FAQs
How does OpenAI function calling handle complex nested JSON outputs?
OpenAI function calling allows you to define nested JSON structures in the function schema. By specifying the hierarchical relationships within the parameters property, you can ensure the model generates properly nested and structured JSON outputs for complex data requirements.
Can OpenAI function calling be used with external APIs or databases?
Yes, OpenAI function calling can be integrated with external APIs or databases by creating custom functions that execute API calls or database queries based on the arguments passed from the model. This enables dynamic interactions with external systems while maintaining consistent and structured responses.
What happens if the model’s function call doesn’t match any defined functions?
If the model’s function call doesn’t match a defined function or the provided schema, the function call is not triggered, and the model treats the input as a standard text-based prompt, returning a typical text-based response instead. This ensures flexibility in handling varied input types.
Earn a Top AI Certification
Demonstrate you can effectively and responsibly use AI.Get Certified, Get HiredThe above is the detailed content of OpenAI Function Calling Tutorial: Generate Structured Output. For more information, please follow other related articles on the PHP Chinese website!

This article explores the growing concern of "AI agency decay"—the gradual decline in our ability to think and decide independently. This is especially crucial for business leaders navigating the increasingly automated world while retainin

Ever wondered how AI agents like Siri and Alexa work? These intelligent systems are becoming more important in our daily lives. This article introduces the ReAct pattern, a method that enhances AI agents by combining reasoning an

"I think AI tools are changing the learning opportunities for college students. We believe in developing students in core courses, but more and more people also want to get a perspective of computational and statistical thinking," said University of Chicago President Paul Alivisatos in an interview with Deloitte Nitin Mittal at the Davos Forum in January. He believes that people will have to become creators and co-creators of AI, which means that learning and other aspects need to adapt to some major changes. Digital intelligence and critical thinking Professor Alexa Joubin of George Washington University described artificial intelligence as a “heuristic tool” in the humanities and explores how it changes

LangChain is a powerful toolkit for building sophisticated AI applications. Its agent architecture is particularly noteworthy, allowing developers to create intelligent systems capable of independent reasoning, decision-making, and action. This expl

Radial Basis Function Neural Networks (RBFNNs): A Comprehensive Guide Radial Basis Function Neural Networks (RBFNNs) are a powerful type of neural network architecture that leverages radial basis functions for activation. Their unique structure make

Brain-computer interfaces (BCIs) directly link the brain to external devices, translating brain impulses into actions without physical movement. This technology utilizes implanted sensors to capture brain signals, converting them into digital comman

This "Leading with Data" episode features Ines Montani, co-founder and CEO of Explosion AI, and co-developer of spaCy and Prodigy. Ines offers expert insights into the evolution of these tools, Explosion's unique business model, and the tr

This article explores Retrieval Augmented Generation (RAG) systems and how AI agents can enhance their capabilities. Traditional RAG systems, while useful for leveraging custom enterprise data, suffer from limitations such as a lack of real-time dat


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment