Ollama | Create a ChatGPT Clone with Ollama and HyperDiv
In this blog post, we’ll explore how to create a ChatGPT-like application using Hyperdiv and Ollama. Hyperdiv provides a flexible framework for building web applications, while Ollama offers powerful local machine learning capabilities.
We will start with the Hyperdiv GPT-chatbot app template and adapt it to leverage Ollama, which runs locally. This guide will walk you through the necessary steps and code changes to integrate these technologies effectively.
TL;DR
The complete code for this tutorial is here.
Step 1: Setting Up Your Environment
Install Ollama
Download Ollama from https://ollama.com/download.
Install (Windows) or unpack (macOS) the downloaded file. This gets you an Ollama app (which allows you to start the Ollama service) and a Ollama command line.
Start the Ollama service by starting the Ollama app.
data:image/s3,"s3://crabby-images/55a1b/55a1b2fac94c99cf6e6ff4d503b92cca04671800" alt=""
On macOS, you will see an icon for the Ollama Servce at the top bar.
data:image/s3,"s3://crabby-images/6b1f1/6b1f1dd55e462f4a0b9ab19280a64c953597598a" alt=""
Then, open a terminal and type ollama list
. This command displays the install models.
ollama list
data:image/s3,"s3://crabby-images/0b8af/0b8afa3215aab28eaddef3aaffef3f1a8658c4ad" alt=""
To install a model, type
ollama pull llama3
data:image/s3,"s3://crabby-images/90ec2/90ec27ebab2c3a815af1dff2a7c0ffa14c1f5442" alt=""
For our ChatGPT Clone, we will use the llama3 model.
If you want to use another model, then search here: https://ollama.com/library
Clone the HyperDiv Examples Repository
Start by cloning or downloading the Hyperdiv GPT-chatbot app. This app provides a basic structure for a chatbot application, which we will modify to work with Ollama.
Go to your desired local folder to store the sources and type
git clone https://github.com/hyperdiv/hyperdiv-apps
Then, go to the folder hyperdiv-apps/gpt-chatbot
Adapt app to use Ollama backend
First, we will create an ollama client to process all request:
from openai import OpenAI client = OpenAI( base_url="http://localhost:11434/v1", api_key="ollama", )
data:image/s3,"s3://crabby-images/8a523/8a52341b01462794fce7b9f90f7aa28a60032e5d" alt=""
Then we modify the request function to use this client
We change
response = openai.ChatCompletion.create(
to
response = client.chat.completions.create(
data:image/s3,"s3://crabby-images/cc352/cc352f9ae7b5335fd3f7cd7265c95e83090f70ce" alt=""
Next step is changing the accees to the response fields. With OpenAI, the response data is a dictionary, so the way to acess the fields is like
chunk["choices"]
With Ollama, we can access the field by name
chunk.choices
The changes are
for chunk in response: message = chunk.choices[0].delta state.current_reply += message.content
data:image/s3,"s3://crabby-images/b98c6/b98c67944590a15a5cff113670d7f2be85281613" alt=""
And the last step would be the change to use the correct model:
model = form.select( options=("codellama", "llama2", "llama3", "mistral"), value="llama3", name="gpt-model", )
data:image/s3,"s3://crabby-images/9c1af/9c1af0c0f8f4f11fa97ff416cb5b07aabb9848f1" alt=""
Thats is! Save all changes
Prepare Python environment and run app
Install the required modules:
pip install openai hyperdiv
Run the app:
python start.py
data:image/s3,"s3://crabby-images/37a6a/37a6abe52f5dee4e210cb0fcd7da376bdd1a8cde" alt=""
Open the browser at http://localhost:8888
data:image/s3,"s3://crabby-images/97078/97078c1ae8bed056c13382ab113f5c0046b75dbd" alt=""
Final Result
data:image/s3,"s3://crabby-images/d623c/d623c07e9fe676d6af8de915174e9855303c9d31" alt=""
The complete code for this tutorial is here.