# Prompt Templates For clients that are in complete control of the prompt generation, such as the KoboldCpp or the Text-Generation-WebUI client, it is important to understand the concept of prompt templates. ## Clients that support prompt templates - KoboldCpp - Text-Generation-WebUI - LMStudio - TabbyAPI ## Am i using the correct prompt template? For good results it is **vital** that the correct prompt template is specified for whichever model you have loaded. Talemate does come with a set of pre-defined templates for some popular models, and has recently implemented automatic detection of the template via Huggingface's model metadata. However this does not always work, so understanding and specifying the correct prompt template is something you should familiarize yourself with. If a client shows a yellow triangle next to it, it means that the prompt template is not set, and it is currently using the default `Alpaca` style prompt template. ![Client unknown prompt template](/talemate/img/0.26.0/client-unknown-prompt-template.png) Click the two cogwheels to the right of the triangle to open the client settings. ![Client unknown prompt template modal](/talemate/img/0.26.0/client-unknown-prompt-template-modal.png) You can first try by clicking the `DETERMINE VIA HUGGINGFACE` button. This doesn't always work, it requires either the model's `README.md` to contain an example or for the template to be set in the tokenizer_config.json file. If that doesn't work, you can manually select the prompt template from the dropdown. In the case for `Phi-3-medium-128k-instruct-Q8_0` that is `Phi3` - select it from the dropdown and click `Save`. ![Client assigned prompt template](/talemate/img/0.26.0/client-assigned-prompt-template.png) ## Adding a new prompt template Talemate keeps its prompt templates in the `./templates/llm-prompts/` directory. In there you will find a `std`, `talemate` and `user` subdirectory. The `std` directory contains the most common prompt templates by format. The `talemate` directory contains the talemate supplied templates for some popular models (although this is quickly becoming redundant with the automatic detection). The `user` directory is for user supplied templates. Templates in the `user` and `talemate` directories will be auto assigned based on name matching. If you want to add a new template, you can do so by creating a new file in the `user` directory. Although it is recommended to just use the user-interface to assign the template, assuming it exists in the `std` directory (See above). Any template assigned through the user-interface will create a new file in the `user` directory.