Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mshumer/gpt-author
https://github.com/mshumer/gpt-author
Last synced: 7 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/mshumer/gpt-author
- Owner: mshumer
- License: mit
- Created: 2023-06-20T17:15:43.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-03T03:14:59.000Z (8 months ago)
- Last Synced: 2024-11-29T12:09:02.611Z (14 days ago)
- Language: Jupyter Notebook
- Size: 5.69 MB
- Stars: 2,487
- Watchers: 41
- Forks: 361
- Open Issues: 34
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- AiTreasureBox - mshumer/gpt-author - 12-07_2490_0](https://img.shields.io/github/stars/mshumer/gpt-author.svg)|| (Repos)
- awesome-autonomous-gpt - 2023/06/21 - This project utilizes a chain of GPT-4, Stable Diffusion, and Anthropic API calls to generate an original fantasy novel. (Projects / Applications)
- jimsghstars - mshumer/gpt-author - (Jupyter Notebook)
- StarryDivineSky - mshumer/gpt-author - 4、Stable Diffusion 和 Anthropic API 调用链来生成原创奇幻小说。用户可以提供一个初始提示并输入他们想要的章节数,然后人工智能会生成一整本小说,输出一个与电子书阅读器兼容的 EPUB 文件。一本 15 章的小说的制作成本低至 4 美元,而且只需几分钟即可写完。 (A01_文本生成_文本对话 / 大语言对话模型及数据)
README
# gpt-author
This project utilizes a chain of GPT-4, Stable Diffusion, and Anthropic API calls to generate an original fantasy novel. Users can provide an initial prompt and enter how many chapters they'd like it to be, and the AI then generates an entire novel, outputting an EPUB file compatible with e-book readers.
**A 15-chapter novel can cost as little as $4 to produce, and is written in just a few minutes.**
## *New 4/2/24: The Claude 3 Version*
I've added a new version of gpt-author that takes full advantage of Anthropic's Claude 3 model. This version uses much simpler code and planning, but writes far better novels. Try it out with the Claude_Author.ipynb notebook in the repo!---
*A few output novel examples from the original (outdated) system are provided in this repo. To read one, you can download its file and view it on https://www.fviewer.com/view-epub, or install it on your Kindle, etc.*
## How It Works
The AI is asked to generate a list of potential plots based on a given prompt. It then selects the most engaging plot, improves upon it, and extracts a title. After that, it generates a detailed storyline with a specified number of chapters, and then tries to improve upon that storyline. Each chapter is then individually written by the AI, following the plot and taking into account the content of previous chapters. Finally, a prompt to design the cover art is generated, and the cover is created. Finally, it's all pulled together, and the novel is compiled into an EPUB file.
## Usage
You can [run the newest version of this project in Google Colab](https://colab.research.google.com/drive/1dJ_WQ_4OTm2F6e6hpqVc6CUCW_jBNHMd?usp=sharing) or in a local Jupyter notebook (use `gpt_author_v2.ipynb` for best results)!
In Google Colab, simply open the notebook, add your API keys, and run the cells in order.
If you are using a local Jupyter notebook, you will need to install the necessary dependencies. You can do this by running the following command in your terminal:
```bash
pip install openai ebooklib requests
```In the last cell of the notebook, you can customize the prompt and the number of chapters for your novel. For example:
```python
prompt = "Similar to Percy Jackson or Harry Potter in terms of vibes, but a different plot entirely. Set in modern day. Add some element of technology to it."
num_chapters = 20
writing_style = "Clear and easily understandable, similar to a young adult novel. Highly descriptive and sometimes long-winded."
novel, title, chapters, chapter_titles = write_fantasy_novel(prompt, num_chapters, writing_style)
```This will generate a novel based on the given prompt with 20 chapters. Note -- prompts with less than 7 chapters tend to cause issues.
## Contributions
Contributions, issues, and feature requests are welcome!
Some initial ideas:
- modify it to work solely with GPT-3.5-Turbo, GPT-3.5-Turbo-16k, or Claude Instant (it will likely require some level of compression/summariztion of early chapters so we don't run out of tokens when generating later chapters).
- improve the system for generating the first chapter -- the better the first chapter comes out, the better the rest of the novel is
- improve the prompts, as they were written very quickly
- improve each step in the process, adding more checks, improvement generations, etc.
- before generating improvements, have a model call identify potential improvements to add to the prompt, which will likely improve performance significantly
- modify it to go beyond just fantasy, allowing users to generate other genres as well
- fix the issue that causes some chapters to cut off early## License
This project is [MIT](https://github.com/your_username/your_repository/blob/master/LICENSE) licensed.
## Contact
Matt Shumer - [@mattshumer_](https://twitter.com/mattshumer_)
Project Link: [https://github.com/mshumer/gpt-author/](https://github.com/mshumer/gpt-author/ )