Awesome
MatGPT - MATLAB® app to access ChatGPT API from OpenAI™
MatGPT is a MATLAB app that allows you to easily access OpenAI's ChatGPT API. With the app, you can load a list of prompts for specific use cases and engage in conversations with ease. If you're new to ChatGPT and prompt engineering, MatGPT is a great way to learn.
The app simply serves as an interface to the ChatGPT API. You should be familiar with the limitations and risks associated with using this technology as well as with OpenAI terms and policies. You are responsible for any fees OpenAI may charge for the use of their API.
MatGPT requires 'Large Language Models (LLMs) with MATLAB' library maintained by MathWorks.
MATLAB AI Chat Playground is a great alternative to MatGPT on MATLAB Central.
What's New
- MatGPT supports GPT-4o mini as the default model, which delivers higher performance at a lower cost than GPT-3.5 Turbo.
- MatGPT loads 'LLMs with MATLAB' library as a submodule.
- MatGPT stores your API in MATLAB Vault on R2024a or later. The stored API will persist from session to session. (Not supported on MATLAB Online).
- MatGPT supports streaming API where response tokens are displayed as they come in.
- MatGPT detects a URL included in a prompt, and retrieves its web content into the chat.
- MatGPT lets you import a .m, .mlx, .csv or .txt file into the chat. PDF files are also supported if Text Analytics Toolbox is available.
- MatGPT supports GPT-4 Turbo with Vision. You can pass the URL to an image, or a local image file path ask questions about the image.
- MatGPT lets you generate an image via DALL·E 3 API.
- MatGPT supports voice chat via Whisper API.
Please note that:
- If you have a previous version of MatGPT, you may need to reinstall it in order to get the updated submodule required for GPT-4o mini support.
- imported content will be truncated if it exceeds the context window limit.
- Streaming must be disabled to use image generation via DALL·E 3.
Requirements
- Submodule: 'Large Language Models (LLMs) with MATLAB
- MathWorks Products (https://www.mathworks.com): Use MatGPT to run on MATLAB Online that comes with the most commonly used toolboxes. To use it on desktop, you must have MATLAB R2023a or later installed on your computer.
- OpenAI API Key: Additionally, you will need your own API key from https://platform.openai.com/api-keys. If you don’t want to set up an API access with OpenAI, MATLAB AI Chat Playground is a better option.
- GPT-4 models are available to all API users who have a history of successful payments. If you have not made any payment to OpenAI, the GPT-4 models are not accessible.
Installation
MATLAB Online
To use MatGPT on MATLAB Online, simply click MATLAB Online pulls the content of this repo, including "LLMS with MATLAB" submodule.
Please note that "Open in MATLAB Online" button on the File Exchange doesn't pull the submodule. You will need to pull LLMs with MATLAB separately and add it to the 'LLMs with MATLAB' folder in the helpers folder.
MATLAB Desktop
Use Git commands to clone the repo to your local directory, and then clone the submodules. This will ensure you get the 'LLMs with MATLAB' library.
git clone https://github.com/toshiakit/MatGPT.git
git submodule update --init
If you download MatGPT as a Zip file, the zip file will not contain the submodule. You need to download 'LLMs with MATLAB' separately and unzip into the 'LLMs with MATLAB' folder in the helpers folder.
How to use: MatGPT app
- Click on
+ New Chat
in the left nav to add a new chat. This opens theSettings
tab. - In the
Settings
tab, either choose a preset to populate the settings or customize on your own. Once you have completed the settings, clickStart New Chat
to initiate a chat. This will take you back to theMain
tab.
- Presets are loaded from Presets.csv - feel free to customize your prompts.
- In the
Main
tab, a sample prompt is already provided based on the preset you selected, but feel free to replace it with your own. When you clickSend
button, the response will be shown in the 'Chat' tab.
- The paperclip button lets you include the content of a m-file, live script file or csv file in the chat.
- If the prompt contains a URL, MatGPT ask you to confirm that you want to open the page.
- The
Send
button and Paperclip button are disabled until a chat is configured in theSettings
tab. - If you want suggestion for follow-up questions in the response, check
Suggest follow-up questions
checkbox. Suggested questions appear as clickable buttons. You can copy a suggested question to the prompt box by clicking it. - If your prompt is intended to generate MATLAB code, check
Test Generated MATLAB Code
checkbox to test the returned code. - The
Usage
tab shows the number of tokens used in the current chat session. - Add stop sequences in
Advanced
tab to specify the sequences where the API will stop generating further tokens.
- Continue the conversation by keep adding more prompts and clicking
Send
. - You can right-click or double-click a chat in the left navigation panel to rename, delete, or save the chat to a text file.
- When you close the app, the chat will be saved and will be reloaded into the left nav when you relaunch the app.
Note:
- You can increase the connection timeout in the
Settings
. You can add proxy via Web Preferences in MATLAB. - Streaming is enabled by default, but you can turn it off in the
Settings
tab. Usage data is not available in streaming mode.
What happened to chatGPT class?
chatGPT class was replaced by the framework provided via the 'Large Language Models (LLMs) with MATLAB' repo. The new framework supports function calling and other latest features. Please refer to the documentation in the repo to learn how to use it.
Acknowledgements
This code is adapted from this MATLAB Answers comment by Hans Scharler and uses Brian Buechel's CodeChecker and other great contributions. The video shown above was created by Angel Gonzalez Llacer.
License
The license for MatGPT is available in the LICENSE.txt file in this GitHub repository.