forked from continuedev/continue
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathReplicate.ts
85 lines (76 loc) · 2.91 KB
/
Replicate.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
import ReplicateClient from "replicate";
import { BaseLLM } from "..";
import { CompletionOptions, LLMOptions, ModelProvider } from "../..";
class Replicate extends BaseLLM {
private static MODEL_IDS: {
[name: string]: `${string}/${string}:${string}`;
} = {
"codellama-7b":
"meta/codellama-7b-instruct:aac3ab196f8a75729aab9368cd45ea6ad3fc793b6cda93b1ded17299df369332",
"codellama-13b":
"meta/codellama-13b-instruct:a5e2d67630195a09b96932f5fa541fe64069c97d40cd0b69cdd91919987d0e7f",
"codellama-34b":
"meta/codellama-34b-instruct:eeb928567781f4e90d2aba57a51baef235de53f907c214a4ab42adabf5bb9736",
"codellama-70b":
"meta/codellama-70b-instruct:a279116fe47a0f65701a8817188601e2fe8f4b9e04a518789655ea7b995851bf",
"llama2-7b": "meta/llama-2-7b-chat" as any,
"llama2-13b": "meta/llama-2-13b-chat" as any,
"zephyr-7b":
"nateraw/zephyr-7b-beta:b79f33de5c6c4e34087d44eaea4a9d98ce5d3f3a09522f7328eea0685003a931",
"mistral-7b":
"mistralai/mistral-7b-instruct-v0.1:83b6a56e7c828e667f21fd596c338fd4f0039b46bcfa18d973e8e70e455fda70",
"mistral-8x7b": "mistralai/mixtral-8x7b-instruct-v0.1" as any,
"wizardcoder-34b":
"andreasjansson/wizardcoder-python-34b-v1-gguf:67eed332a5389263b8ede41be3ee7dc119fa984e2bde287814c4abed19a45e54",
"neural-chat-7b":
"tomasmcm/neural-chat-7b-v3-1:acb450496b49e19a1e410b50c574a34acacd54820bc36c19cbfe05148de2ba57",
"deepseek-7b": "kcaverly/deepseek-coder-33b-instruct-gguf" as any,
"phind-codellama-34b": "kcaverly/phind-codellama-34b-v2-gguf" as any,
};
static providerName: ModelProvider = "replicate";
private _replicate: ReplicateClient;
private _convertArgs(
options: CompletionOptions,
prompt: string,
): [`${string}/${string}:${string}`, { input: any }] {
return [
Replicate.MODEL_IDS[options.model] || (options.model as any),
{
input: { prompt, message: prompt },
},
];
}
constructor(options: LLMOptions) {
super(options);
this._replicate = new ReplicateClient({ auth: options.apiKey });
}
protected async _complete(
prompt: string,
options: CompletionOptions,
): Promise<string> {
const [model, args] = this._convertArgs(options, prompt);
const response = await this._replicate.run(model, args);
return (response as any)[0];
}
protected async *_streamComplete(
prompt: string,
options: CompletionOptions,
): AsyncGenerator<string> {
const [model, args] = this._convertArgs(options, prompt);
for await (const event of this._replicate.stream(model, args)) {
if (event.event === "output") {
yield event.data;
}
}
}
// protected async *_streamChat(
// messages: ChatMessage[],
// options: CompletionOptions
// ): AsyncGenerator<ChatMessage> {
// const resp = await this.complete(
// stripImages(messages[0]?.content || ""),
// options
// );
// }
}
export default Replicate;