diff options
Diffstat (limited to 'src/client/apis/gpt/GPT.ts')
| -rw-r--r-- | src/client/apis/gpt/GPT.ts | 44 | 
1 files changed, 39 insertions, 5 deletions
| diff --git a/src/client/apis/gpt/GPT.ts b/src/client/apis/gpt/GPT.ts index 2e4dbe9a0..8b101bfe3 100644 --- a/src/client/apis/gpt/GPT.ts +++ b/src/client/apis/gpt/GPT.ts @@ -1,4 +1,4 @@ -import { ChatCompletionMessageParam } from 'openai/resources'; +import { ChatCompletionMessageParam, Image } from 'openai/resources';  import { openai } from './setup';  enum GPTCallType { @@ -14,6 +14,10 @@ enum GPTCallType {      DATA = 'data',      STACK = 'stack',      PRONUNCIATION = 'pronunciation', +    RUBRIC = 'rubric', +    TYPE = 'type', +    SUBSET = 'subset', +    INFO = 'info',  }  type GPTCallOpts = { @@ -34,6 +38,7 @@ const callTypeMap: { [type: string]: GPTCallOpts } = {          temp: 0.7,          prompt: 'Create a stack of flashcards out of this text with each question and answer labeled as question and answer. For some questions, ask "what is this image of" but tailored to stacks theme and the image and write a keyword that represents the image and label it "keyword". Otherwise, write none. Do not label each flashcard and do not include asterisks.',      }, +      completion: { model: 'gpt-4-turbo', maxTokens: 256, temp: 0.5, prompt: "You are a helpful assistant. Answer the user's prompt." },      mermaid: {          model: 'gpt-4-turbo', @@ -50,8 +55,8 @@ const callTypeMap: { [type: string]: GPTCallOpts } = {      sort: {          model: 'gpt-4o',          maxTokens: 2048, -        temp: 0.5, -        prompt: "I'm going to give you a list of descriptions. Each one is seperated by ====== on either side. They will vary in length, so make sure to only seperate when you see ======. Sort them into lists by shared content. MAKE SURE EACH DESCRIPTOR IS IN ONLY ONE LIST. Generate only the list with each list seperated by ====== with the elements seperated by ~~~~~~. Try to do around 4 groups, but a little more or less is ok.", +        temp: 0.25, +        prompt: "The user is going to give you a list of descriptions. Each one is separated by `======` on either side. Descriptions will vary in length, so make sure to only separate when you see `======`. Sort them by the user's specifications. Make sure each description is only in the list once. Each item should be separated by `======`. Immediately afterward, surrounded by `------` on BOTH SIDES, provide some insight into your reasoning for the way you sorted (and mention nothing about the formatting details given in this description). It is VERY important that you format it exactly as described, ensuring the proper number of `=` and `-` (6 of each) and NO commas",      },      describe: { model: 'gpt-4-vision-preview', maxTokens: 2048, temp: 0, prompt: 'Describe these images in 3-5 words' },      chatcard: { model: 'gpt-4-turbo', maxTokens: 512, temp: 0.5, prompt: 'Answer the following question as a short flashcard response. Do not include a label.' }, @@ -66,6 +71,35 @@ const callTypeMap: { [type: string]: GPTCallOpts } = {          maxTokens: 1024,          temp: 0.1, //0.3          prompt: '', +        prompt: "BRIEFLY (<50 words) describe any differences between the rubric and the user's answer answer in second person. If there are no differences, say correct", +    }, + +    rubric: { +        model: 'gpt-4-turbo', +        maxTokens: 1024, +        temp: 0, +        prompt: "BRIEFLY (<25 words) provide a definition for the following term. It will be used as a rubric to evaluate the user's understanding of the topic", +    }, + +    type: { +        model: 'gpt-4-turbo', +        maxTokens: 1024, +        temp: 0, +        prompt: "I'm going to provide you with a question. Based on the question, is the user asking you to 1. Assigns docs with tags(like star / heart etc)/labels, 2. Filter docs, 3. Provide information about a specific doc 4. Provide a specific doc based on a question/information 5. Provide general information 6. Put cards in a specific order. Answer with only the number for 2-6. For number one, provide the number (1) and the appropriate tag", +    }, + +    subset: { +        model: 'gpt-4-turbo', +        maxTokens: 1024, +        temp: 0, +        prompt: "I'm going to give you a list of descriptions. Each one is separated by `======` on either side. Descriptions will vary in length, so make sure to only separate when you see `======`. Based on the question the user asks, provide a subset of the given descriptions that best matches the user's specifications. Make sure each description is only in the list once. Each item should be separated by `======`. Immediately afterward, surrounded by `------` on BOTH SIDES, provide some insight into your reasoning in the 2nd person (and mention nothing about the formatting details given in this description). It is VERY important that you format it exactly as described, ensuring the proper number of `=` and `-` (6 of each) and no commas", +    }, + +    info: { +        model: 'gpt-4-turbo', +        maxTokens: 1024, +        temp: 0, +        prompt: "Answer the user's question with a short (<100 word) response. If a particular document is selected I will provide that information (which may help with your response)",      },  }; @@ -84,7 +118,7 @@ const gptAPICall = async (inputTextIn: string, callType: GPTCallType, prompt?: a      try {          lastCall = inputText; -        const usePrompt = prompt ? opts.prompt + prompt : opts.prompt; +        const usePrompt = prompt ? prompt + opts.prompt : opts.prompt;          const messages: ChatCompletionMessageParam[] = [              { role: 'system', content: usePrompt },              { role: 'user', content: inputText }, @@ -111,7 +145,7 @@ const gptImageCall = async (prompt: string, n?: number) => {              n: n ?? 1,              size: '1024x1024',          }); -        return response.data.map((data: any) => data.url); +        return response.data.map((data: Image) => data.url);          // return response.data.data[0].url;      } catch (err) {          console.error(err); | 
