Improve snippets (#45)
Browse files
src/lib/components/InferencePlayground/InferencePlaygroundCodeSnippets.svelte
CHANGED
@@ -69,7 +69,7 @@
|
|
69 |
const formattedMessages = ({ sep, start, end }: MessagesJoiner) =>
|
70 |
start +
|
71 |
getMessages()
|
72 |
-
.map(({ role, content }) => `{ role: "${role}", content: "${content}" }`)
|
73 |
.join(sep) +
|
74 |
end;
|
75 |
|
@@ -97,15 +97,13 @@ let out = "";
|
|
97 |
|
98 |
for await (const chunk of inference.chatCompletionStream({
|
99 |
model: "${conversation.model.id}",
|
100 |
-
messages: ${formattedMessages({ sep: ",\n
|
101 |
-
${formattedConfig({ sep: ",\n ", start: "", end: "" })}
|
102 |
-
seed: 0,
|
103 |
})) {
|
104 |
if (chunk.choices && chunk.choices.length > 0) {
|
105 |
const newContent = chunk.choices[0].delta.content;
|
106 |
out += newContent;
|
107 |
-
|
108 |
-
console.log(out);
|
109 |
}
|
110 |
}`,
|
111 |
});
|
@@ -118,10 +116,9 @@ for await (const chunk of inference.chatCompletionStream({
|
|
118 |
const inference = new HfInference("your access token")
|
119 |
|
120 |
const out = await inference.chatCompletion({
|
121 |
-
|
122 |
-
|
123 |
-
${formattedConfig({ sep: ",\n
|
124 |
-
seed: 0,
|
125 |
});
|
126 |
|
127 |
console.log(out.choices[0].message);`,
|
@@ -135,40 +132,41 @@ console.log(out.choices[0].message);`,
|
|
135 |
const formattedMessages = ({ sep, start, end }: MessagesJoiner) =>
|
136 |
start +
|
137 |
getMessages()
|
138 |
-
.map(({ role, content }) => `{ "role": "${role}", "content": "${content}" }`)
|
139 |
.join(sep) +
|
140 |
end;
|
141 |
|
142 |
-
const formattedConfig = ({ sep, start, end }: MessagesJoiner) =>
|
143 |
start +
|
144 |
Object.entries(conversation.config)
|
145 |
-
.map(([key, val]) => `${key}
|
146 |
.join(sep) +
|
147 |
end;
|
148 |
|
149 |
const snippets: Snippet[] = [];
|
150 |
snippets.push({
|
151 |
-
label: "Install huggingface_hub",
|
152 |
language: "http",
|
153 |
-
code: `pip install huggingface_hub`,
|
154 |
});
|
155 |
if (conversation.streaming) {
|
156 |
snippets.push({
|
157 |
label: "Streaming API",
|
158 |
code: `from huggingface_hub import InferenceClient
|
159 |
|
160 |
-
|
161 |
-
hf_token = "your HF token"
|
162 |
-
inference_client = InferenceClient(model_id, token=hf_token)
|
163 |
|
164 |
-
|
165 |
|
166 |
-
|
|
|
|
|
|
|
|
|
|
|
167 |
|
168 |
-
for
|
169 |
-
|
170 |
-
print(new_content, end="")
|
171 |
-
output += new_content`,
|
172 |
});
|
173 |
} else {
|
174 |
// non-streaming
|
@@ -177,12 +175,15 @@ for token in client.chat_completion(messages, stream=True, ${formattedConfig({ s
|
|
177 |
code: `from huggingface_hub import InferenceClient
|
178 |
|
179 |
model_id="${conversation.model.id}"
|
180 |
-
|
181 |
-
inference_client = InferenceClient(model_id, token=hf_token)
|
182 |
|
183 |
-
messages = ${formattedMessages({ sep: ",\n
|
184 |
|
185 |
-
output =
|
|
|
|
|
|
|
|
|
186 |
|
187 |
print(output.choices[0].message)`,
|
188 |
});
|
@@ -195,7 +196,7 @@ print(output.choices[0].message)`,
|
|
195 |
const formattedMessages = ({ sep, start, end }: MessagesJoiner) =>
|
196 |
start +
|
197 |
getMessages()
|
198 |
-
.map(({ role, content }) => `{ "role": "${role}", "content": "${content}" }`)
|
199 |
.join(sep) +
|
200 |
end;
|
201 |
|
|
|
69 |
const formattedMessages = ({ sep, start, end }: MessagesJoiner) =>
|
70 |
start +
|
71 |
getMessages()
|
72 |
+
.map(({ role, content }) => `{ role: "${role}", content: "${content?.replace(/"/g, '\\"')}" }`)
|
73 |
.join(sep) +
|
74 |
end;
|
75 |
|
|
|
97 |
|
98 |
for await (const chunk of inference.chatCompletionStream({
|
99 |
model: "${conversation.model.id}",
|
100 |
+
messages: ${formattedMessages({ sep: ",\n\t", start: "[\n\t", end: "\n ]" })},
|
101 |
+
${formattedConfig({ sep: ",\n ", start: "", end: "" })}
|
|
|
102 |
})) {
|
103 |
if (chunk.choices && chunk.choices.length > 0) {
|
104 |
const newContent = chunk.choices[0].delta.content;
|
105 |
out += newContent;
|
106 |
+
console.log(newContent);
|
|
|
107 |
}
|
108 |
}`,
|
109 |
});
|
|
|
116 |
const inference = new HfInference("your access token")
|
117 |
|
118 |
const out = await inference.chatCompletion({
|
119 |
+
model: "${conversation.model.id}",
|
120 |
+
messages: ${formattedMessages({ sep: ",\n\t\t", start: "[\n\t\t", end: "\n\t]" })},
|
121 |
+
${formattedConfig({ sep: ",\n\t", start: "", end: "" })}
|
|
|
122 |
});
|
123 |
|
124 |
console.log(out.choices[0].message);`,
|
|
|
132 |
const formattedMessages = ({ sep, start, end }: MessagesJoiner) =>
|
133 |
start +
|
134 |
getMessages()
|
135 |
+
.map(({ role, content }) => `{ "role": "${role}", "content": "${content?.replace(/"/g, '\\"')}" }`)
|
136 |
.join(sep) +
|
137 |
end;
|
138 |
|
139 |
+
const formattedConfig = ({ sep, start, end, connector }: MessagesJoiner & { connector: string }) =>
|
140 |
start +
|
141 |
Object.entries(conversation.config)
|
142 |
+
.map(([key, val]) => `${key}${connector}${val}`)
|
143 |
.join(sep) +
|
144 |
end;
|
145 |
|
146 |
const snippets: Snippet[] = [];
|
147 |
snippets.push({
|
148 |
+
label: "Install the latest huggingface_hub",
|
149 |
language: "http",
|
150 |
+
code: `pip install huggingface_hub --upgrade`,
|
151 |
});
|
152 |
if (conversation.streaming) {
|
153 |
snippets.push({
|
154 |
label: "Streaming API",
|
155 |
code: `from huggingface_hub import InferenceClient
|
156 |
|
157 |
+
client = InferenceClient(api_key="your HF token")
|
|
|
|
|
158 |
|
159 |
+
messages = ${formattedMessages({ sep: ",\n\t", start: `[\n\t`, end: `\n]` })}
|
160 |
|
161 |
+
output = client.chat.completions.create(
|
162 |
+
model="${conversation.model.id}",
|
163 |
+
messages=messages,
|
164 |
+
stream=True,
|
165 |
+
${formattedConfig({ sep: ",\n\t", start: "", end: "", connector: "=" })}
|
166 |
+
)
|
167 |
|
168 |
+
for chunk in output:
|
169 |
+
print(chunk.choices[0].delta.content)`,
|
|
|
|
|
170 |
});
|
171 |
} else {
|
172 |
// non-streaming
|
|
|
175 |
code: `from huggingface_hub import InferenceClient
|
176 |
|
177 |
model_id="${conversation.model.id}"
|
178 |
+
client = InferenceClient(api_key="your HF token")
|
|
|
179 |
|
180 |
+
messages = ${formattedMessages({ sep: ",\n\t", start: `[\n\t`, end: `\n]` })}
|
181 |
|
182 |
+
output = client.chat.completions.create(
|
183 |
+
model="${conversation.model.id}",
|
184 |
+
messages=messages,
|
185 |
+
${formattedConfig({ sep: ",\n\t", start: "", end: "", connector: "=" })}
|
186 |
+
)
|
187 |
|
188 |
print(output.choices[0].message)`,
|
189 |
});
|
|
|
196 |
const formattedMessages = ({ sep, start, end }: MessagesJoiner) =>
|
197 |
start +
|
198 |
getMessages()
|
199 |
+
.map(({ role, content }) => `{ "role": "${role}", "content": "${content?.replace(/"/g, '\\"')}" }`)
|
200 |
.join(sep) +
|
201 |
end;
|
202 |
|