Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/circlestarzero/EX-chatGPT

Let ChatGPT truly learn how to go online and call APIs! 'EX-ChatGPT' can rival and even surpass NewBing
https://github.com/circlestarzero/EX-chatGPT

Last synced: 2 months ago
JSON representation

Let ChatGPT truly learn how to go online and call APIs! 'EX-ChatGPT' can rival and even surpass NewBing

Awesome Lists containing this project

README

        

# Ex-ChatGPT - ChatGPT with ToolFormer

![language](https://img.shields.io/badge/language-python-blue) ![GitHub](https://img.shields.io/github/license/circlestarzero/EX-chatGPT) ![GitHub last commit](https://img.shields.io/github/last-commit/circlestarzero/EX-chatGPT) ![GitHub Repo stars](https://img.shields.io/github/stars/circlestarzero/EX-chatGPT?style=social)

[简体中文](./README.md) English / [Background](./BACKGROUND.md)

ChatGPT can act as a **tool former** without requiring adjustment, generating API requests for questions to assist in answering. Ex-ChatGPT enables ChatGPT to call external APIs, such as **WolframAlpha, Google, and WikiMedia**, to provide more accurate and timely answers.

This project is divided into `Ex-ChatGPT` and `WebChatGPTEnhance`. The former is a service that uses the `GPT3.5 Turbo API` and **Google,WolframAlpha,WikiMedia APIs**, while the latter is a **browser extension** which update the origin WebChatGPT plugin to Enable adding external API, supportting ChatGPT webpage to call different APIs and prompts

## user interface display

### ExChatGPT

![chatHistory](img/newPage.jpg)

### WebChatGPTEnhance

![WebChatGPT](img/chatGPTChromeEnhance.png)

## Highlights

- **OAuth2.0 Multi User Management** (In webTest branch)
- **Speech Dialogue Functionality**, utilizing Microsoft Azure API to optimize response time (around 1-2 seconds), featuring both speech recognition and text-to-speech capabilities, supporting multiple languages and voices, and allowing for customized voices.
- **Docker and Proxy support**
- **Redundant backup of chat history**
- Support for OpenAI GPT-3.5 Turbo API
- Ability for ChatGPT to call external API interfaces, such as **Google, WolframAlpha, and WikiMedia**
- Clean up Google search results data to reduce token usage.
- Automatic saving and loading of conversation history with **automatic compression**
- Ability to display the number of tokens used
- **API pool**
- **Markdown and MathJax rendering**
- API call process displayed with an animation, similar to Bing
- Conversation management with **load and chat** modes similar to ChatGPT web page layout
- **Shortcut keys** for quickly selecting modes (`Tab`), line breaks (`Shift+Enter`), sending messages (`Enter`), and selecting message history (`up` and `down`), similar to a terminal.
- `stream` feature is similar to that of a typewriter, it responds faster with results instead of loading everything at once. Stream outputs the results in steps, as shown in the example:
![stream](img/stream.gif)
- Automatic **prompt completion** in `Chat Mode` with support for fuzzy search, pinyin search, and custom prompt selection.The project comes with prompt from [awesome-chatgpt-prompts](https://github.com/f/awesome-chatgpt-prompts).
![promptCompletion](img/promptCompletion.gif)

## To Do List

- [ ] Mobile interface adaptation
- [ ] OCR recognition of formula text in images sent by users
- [ ] OAuth2.0 multi-user authentication
- [ ] Call the diffusing model to generate images (achieving similar multimodal effects)
- [ ] Further spider summary and data cleansing of web search results
- [ ] Add code running API, and more APIs
- [ ] Embedding alignment retrieval of chat records/local knowledge databases

## Installation

### Ex-chatGPT

- `pip install`
`pip install -r requirements.txt`
- Copy `apikey.ini.example` and rename it as `apikey.ini`. Then, fill in your `API key` and `proxy` in `apikey.ini`. If you only have one OpenAI API key, you should delete `key1 = sk-xxxx;key2 = sk-xxxx`.
- `Google api key and search engine id` [apply](https://developers.google.com/custom-search/v1/overview?hl=en)
- `wolframAlpha app id key` [apply](https://products.wolframalpha.com/api/)
- `openAI api key`(new feature) or `chatGPT access_token`(old version) [apply](https://platform.openai.com)
- (optional, Text To Speech And Speech recognition) fill in `Azure API key` and `region` [apply](https://learn.microsoft.com/zh-cn/azure/cognitive-services/speech-service)
- run the `main.py` and click the local url like `http://127.0.0.1:1234/`
- change the mode in the selection box, now have `chat,detail,web,webDirect,WebKeyWord`
- **Voice Conversation Chat**(optional feature), select language and voice in `chatGPTEx/static/styles/tts.js`, click the microphone on chat interface to `start/close` conversation mode.

### WebChatGPTEnhanceExtension

- fill you `Googgle api key and client id` in `chatGPTChromeEhance/src/util/apiManager.ts/getDefaultAPI`
- run `npm install`
- run `npm run build-prod`
- get the extension in `chatGPTChromeEhance/build`
- add your `prompts` and `APIs` in option page.
- `APIs` and `prompts` examples are in `/WebChatGPTAPI`
- `wolframAlpha` needs to run local sever - `WebChatGPTAPI/WolframLocalServer.py`

## Mode Introduction

### Web Mode

The Web Mode starts by asking ChatGPT a question directly. ChatGPT generates a series of API calls related to the query and uses the first returned result and question to verify and supplement with an API call. Finally, ChatGPT summarizes the information. Web Mode has a better chat ability than just summarizing the response.

### Chat Mode

Chat Mode only calls the OpenAI API interface, similar to the web version of ChatGPT. You can search and choose different prompts by typing `/promtname`, and it supports fuzz search.

### WebDirect Mode

WebDirect Mode first lets ChatGPT generate a series of API calls related to the query. Then, it directly calls a third-party API to search for the answer to each query, and finally, ChatGPT summarizes the information. WebDirect Mode is faster and relatively more accurate for single query information.

### Detail Mode

Detail Mode is an extension of the WebDirect Mode, where an additional API call is made to supplement the current results with further inquiries (such as information not found in the previous search). Finally, ChatGPT summarizes the information.

### Keyword Mode

Keyword Mode generates keywords directly from ChatGPT for querying, using DDG. It doesn't require other API keys. However, its accuracy is relatively poor.

## Update Log

- Clean up Google search results data to reduce token usage.
- Update all API proxy pools and add API restriction cooldown mechanism (Google 403 cooldown for 1 day).
- Voice dialogue function, using Microsoft Azure API, optimized response speed, including voice recognition and text-to-speech, supporting multiple voices and languages, custom voice.
- `stream` feature is similar to that of a typewriter, it responds faster with results instead of loading everything at once. Stream outputs the results in steps, as shown in the example:
![stream](img/stream.gif)
- Redundant backup of chat history.
- Auto-complete prompt selection in chat mode with **fuzzy search** and **Pinyin search** support.
![promptCompletion](img/promptCompletion.gif)

- Update docker and proxy support.

- Shortcut keys for quick mode selection (`Tab`) and line break (`Shift + Enter`), while `Enter` sends the message. Message history selection (`up`, `down`) is similar to a terminal.

- Update chat history management sidebar.
![chatHistory](img/newPage.jpg)

- Update API calls processing animation.
![APIAnimation](img/APIAnimation.png)

- Web page beautification.
![WebBeautification](img/WebPageBeautification.jpg)

- Update Markdown and MathJax renderer.
![MathJax](img/mathjax.jpg)

- Update chat history token optimizer, and web mode can respond according to chat history. Add token cost counter.
![history](img/webHistory.jpg)

- Update web chat mode selection in the webpage and optimize prompt and token cost. Restrict the token limit.
![mode](img/mode.jpg)

- Update better support for Chinese queries and add current date info.
![date](img/date.jpg)

- Update web chat mode and fix some bugs.
- Update API configuration.
- Update API pool.
- Automatic saving and loading of conversation history, ChatGPT can retrieve previous conversations.
- Update official support for OpenAI GPT3.5 Turbo API, which is super fast and cheap.
- Update extra API calls and search summarizations to provide a more comprehensive and detailed answer.