|
import { createLlamaPrompt } from "@/lib/createLlamaPrompt" |
|
import { dirtyLLMResponseCleaner } from "@/lib/dirtyLLMResponseCleaner" |
|
import { dirtyLLMJsonParser } from "@/lib/dirtyLLMJsonParser" |
|
import { dirtyCaptionCleaner } from "@/lib/dirtyCaptionCleaner" |
|
|
|
import { predict } from "./predict" |
|
import { Preset } from "../engine/presets" |
|
|
|
export const getStory = async ({ |
|
preset, |
|
prompt = "", |
|
}: { |
|
preset: Preset; |
|
prompt: string; |
|
}): Promise<string[]> => { |
|
|
|
const query = createLlamaPrompt([ |
|
{ |
|
role: "system", |
|
content: [ |
|
`You are a comic book author specialized in ${preset.llmPrompt}`, |
|
`Please generate detailed drawing instructions for the 4 panels of a new silent comic book page.`, |
|
`Give your response as a JSON array like this: \`Array<{ panel: number; caption: string}>\`.`, |
|
|
|
`Be brief in your caption don't add your own comments. Be straight to the point, and never reply things like "Sure, I can.." etc.` |
|
].filter(item => item).join("\n") |
|
}, |
|
{ |
|
role: "user", |
|
content: `The story is: ${prompt}`, |
|
} |
|
]) |
|
|
|
|
|
let result = "" |
|
|
|
try { |
|
result = await predict(query) |
|
if (!result.trim().length) { |
|
throw new Error("empty result!") |
|
} |
|
} catch (err) { |
|
console.log(`prediction of the story failed, trying again..`) |
|
try { |
|
result = await predict(query+".") |
|
if (!result.trim().length) { |
|
throw new Error("empty result!") |
|
} |
|
} catch (err) { |
|
console.error(`prediction of the story failed again!`) |
|
throw new Error(`failed to generate the story ${err}`) |
|
} |
|
} |
|
|
|
console.log("Raw response from LLM:", result) |
|
const tmp = dirtyLLMResponseCleaner(result) |
|
|
|
let captions: string[] = [] |
|
|
|
try { |
|
captions = dirtyLLMJsonParser(tmp) |
|
} catch (err) { |
|
console.log(`failed to read LLM response: ${err}`) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
try { |
|
|
|
let strategy2 = `[${tmp.split("[").pop() || ""}` |
|
strategy2.replaceAll("[", ",") |
|
|
|
captions = dirtyLLMJsonParser(strategy2) |
|
} catch (err2) { |
|
|
|
|
|
|
|
|
|
captions = ( |
|
tmp.split("*") |
|
.map(item => item.replaceAll("[", "[").replaceAll("]", "]").trim()) |
|
) |
|
} |
|
} |
|
|
|
return captions.map(caption => dirtyCaptionCleaner(caption)) |
|
} |