Lotus-12B is a GPT-NeoX 12B model fine-tuned on 2.5GB of a diverse range of light novels, erotica, annotated literature, and public-domain conversations for the purpose of generating novel-like fictional text and conversations.
The model used for fine-tuning is Pythia 12B Deduped, which is a 12 billion parameter auto-regressive language model trained on The Pile.
Training Data & Annotative Prompting
The data used in fine-tuning has been gathered from various sources such as the Gutenberg Project. The annotated fiction dataset has prepended tags to assist in generating towards a particular style. Here is an example prompt that shows how to use the annotations.
[ Title: The Dunwich Horror; Author: H. P. Lovecraft; Genre: Horror; Tags: 3rdperson, scary; Style: Dark ] *** When a traveler in north central Massachusetts takes the wrong fork...
And for conversations which were scraped from My Discord Server and publicly available subreddits from Reddit:
[ Title: (2019) Cars getting transported on an open deck catch on fire after salty water shorts their batteries; Genre: CatastrophicFailure ] *** Anonymous: Daaaaaamn try explaining that one to the owners EDIT: who keeps reposting this for my comment to get 3k upvotes? Anonymous: "Your car caught fire from some water" Irythros: Lol, I wonder if any compensation was in order Anonymous: Almost all of the carriers offer insurance but it isn’t cheap. I guarantee most of those owners declined the insurance.
The annotations can be mixed and matched to help generate towards a specific style.
This model can be used for entertainment purposes and as a creative writing assistant for fiction writers and chatbots.
from transformers import AutoTokenizer, AutoModelForCausalLM model = AutoModelForCausalLM.from_pretrained('hakurei/lotus-12B') tokenizer = AutoTokenizer.from_pretrained('hakurei/lotus-12B') prompt = '''[ Title: The Dunwich Horror; Author: H. P. Lovecraft; Genre: Horror ] *** When a traveler''' input_ids = tokenizer.encode(prompt, return_tensors='pt') output = model.generate(input_ids, do_sample=True, temperature=1.0, top_p=0.9, repetition_penalty=1.2, max_length=len(input_ids)+100, pad_token_id=tokenizer.eos_token_id) generated_text = tokenizer.decode(output) print(generated_text)
An example output from this code produces a result that will look similar to:
[ Title: The Dunwich Horror; Author: H. P. Lovecraft; Genre: Horror ] *** When a traveler comes to an unknown region, his thoughts turn inevitably towards the old gods and legends which cluster around its appearance. It is not that he believes in them or suspects their reality—but merely because they are present somewhere else in creation just as truly as himself, and so belong of necessity in any landscape whose features cannot be altogether strange to him. Moreover, man has been prone from ancient times to brood over those things most connected with the places where he dwells. Thus the Olympian deities who ruled Hyper
Team members and Acknowledgements
This project would not have been possible without the work done by EleutherAI. Thank you!
- Anthony Mercurio
In order to reach us, you can join our Discord server.
- Downloads last month