My goal with this project was to learn how to use the new Large Language Model AI GPT-3 created by OpenAI. I also wanted to know if it could be used in a practical web application.
To learn it, I created a website that uses it in two ways.
- I used it to create the web application.
- The web application then uses GPT-3 itself to create other simple web pages or one-page web applications.
I also recorded this video that guides you through my learning experience: 🤯
A Few Words on ChatGPT
GPT stands for Generative Pre-trained transformer.
I examined its background is clearly explained in depth in its wiki article and why it works is written in a great article by Stephen Wolfram. GPT is a high-powered autocomplete that creates paragraphs and words based on their statistical association. It adds randomness to this selection, so it does not always return the same result given the same prompt.
I witnessed how it can enable great applications in multiple ways. 👇
- ChatGPT Usage 1: Text autocompletes can be used superbly to write well-written code.
- ChatGPT Usage 2: It can also be used in the application to enable or enhance its functionality.
- ChatGPT Usage 3: The coder can also use it to expedite learning and create new code.
In creating the website, I found the latter to be the most useful.
This article guides you through how I used and created a website that can generate a website from a text prompt. Open AI’s GPT Da Vinci powers the site. I used Open AI’s Chat GPT to create much of its code.
I also used GPT-3 based ghostwriter code assistant in the Replit IDE or interactive development environment for auto-completion. I also examine how I used prompt engineering for development, Flask, and JavaScript to create its functionality.
The GPT-3 Website Prototyper Site
Here’s an example of what the site looks like:
Here’s an example of a pong game created with it just from entering the above prompt text:
How the Application Works
Let’s first see what the site does before we look into its code.
Here’s the site https://web-prototyper.kevron.repl.co/. Go to the site and enter a prompt.
Here are some example prompts:
- “Create an HTML pong game with javascript and an AI”
- “Create an HTML page with street address, zip code, first name, last name, and a date picker for the birthdate.”
Here’s a site that gives you information on prompt engineering from OpenAI. If you want to create a website, you’ll have some keywords like “JavaScript” and “HTML”. In addition, you can add CSS and colors to your site.
Then Click on the Create
button that gets the output from the GPT API Davinci. Enter a name. Then save.
You can click on the link to go to the site. You can also click on the code to view the code. You should remember that the code it generates has some randomness to it, and it won’t always return the same result.
If you want to learn more about using ChatGPT as the logic of your own apps, feel free to check out the Finxter premium course here: 👇
How I Created the GPT-3 Website Prototyper Site
I wrote some of this website’s code using Chat-GPT and then manually put the pieces together.
This is a gap in the AIs and where the programmers come in. They can’t see the big picture and put together pieces of code from different sites like
- Stack Overflow,
- Google,
- Finxter, and
- Chat GPT.
Chat GPT, on the other hand, can only use code already processed on its site. Throughout the creation of this site, I used these sources to look up how to create this site. I could not just use Chat GPT.
One of the current gaps humans can fill that Chat generators can’t, even though they are impressive, is tying large pieces and concepts together accurately. So I had to manually tie together the front end, backend, and saving functionality.
Here’s the prompt used to create the Flask backend.
This generated back-end Flask python code and JavaScript code, the JavaScript code called the Flask backend.
I modified the code to work with my site, but the basic structure of the code is from what was generated by OpenAI. I was not familiar with Flask. I’m a professional web developer, though. The ChatGPT, the Finxter tutorial, and my experience helped me get up to speed with Flask in minutes.
The code for the application can be found on Replit and Github. I’ll post links to the Replit because I believe it gives you the best ability to run and fork the code.
The communication of the API is the Python code here (Replit):
def gpt3_request(): data = request.get_json() prompt = data['prompt'] completions = openai.Completion.create( engine="text-davinci-002", prompt=prompt, max_tokens=4000, n=1, stop=None, temperature=0.5, ) message = completions.choices[0].text print(message) return jsonify({'message': message})
It’s called by the JavaScript code here, which parses the HTML. You can see the code below.
It does this to organize the code into CSS, HTML, and JavaScript. It’ll later be injected back into the DOM of a new page. I did this step because the JavaScript and CSS were not always well-formed, so I wanted to separate them out.
I used Chat GPT and StackOverflow. I used StackOverflow to find a technique to help me determine which one to use. I used Stackoverflow to determine what JavaScript technique I should use to save it in the database.
I like StackOverflow because there is a human voting mechanism. It also has feedback and different perspectives and opposing sides. This is something that ChatGPT misses. It’s only one source
Here’s the prompt I used on ChatGPT to show me the JavaScript client-side database code
I knew I had to save it for the client. Here’s some of the code to save to the client
You can see the full code here: https://replit.com/@kevron/Web-Prototyper#static/post.js
It is about 75% of the same code as what I got from Chat-GPT-3 .
The technologies used are Replit for the IDE, OpenAI DaVinci, Python and flask for the backend, HTML and javascript, GIT for source control, and Chat-GPT3.
Understanding the Security, Safety Concerns, and Limitations
This a powerful technology, and I think there are both security and safety concerns that I learned about from using GPT 3 and reading articles about it.
The security concern in this app is that I can now generate tons of HTML pages if I want to. What if some of the information on this site is unsafe or inaccurate? The potential for the inaccuracy of the data is mentioned on many sites. This technology needs to be used safely from OpenAI.
Since this is a new powerful and new technology, many other new safety concerns may arise. I think it’ll vary depending on the organizations’ specific use of GPT.
They lack the ability to generalize and see the big picture.
Also, the data is stored in the browser’s database. It should not be modified and open to store the HTML code from the website. It could be an internal company tool, though. It’s ok when it is run on the client, but saving this in the database could be dangerous and open up cross-site scripting concerns.
For example, it could be saved in GitHub or saved in someone else’s database.
My Conclusions
This technology is super exciting and will empower many people to create things from just an idea.
Bill Gates and other large investors have said this technology is transformative. Companies such as Google and Microsoft are investing millions of dollars in it.
Despite the safety concerns of GPT and some of its limitations, I’m very excited about working with this technology and other assistive AI technology in the future.
It helped me immensely in writing this code.
I’m also optimistic that some of its criticisms of accuracy are being worked on and addressed.
I learned through writing this article how powerful and helpful GPT can be as an assistive tool. I also learned firsthand that while GPT is powerful, it does not seem like it will replace a human programmer. It cannot generalize, see the big picture, and fact-check like a human does from multiple sources.
So I hope that in following this article, you’ve developed knowledge about GPT and learned how to use it as a code generation tool too.