Skip to content

Commit

Permalink
feat(js): llama-index-ts embeddings support (#761)
Browse files Browse the repository at this point in the history
Co-authored-by: Parker Stafford <parker.stafford92@gmail.com>
Co-authored-by: Mikyo King <mikyo@arize.com>
  • Loading branch information
3 people committed Dec 6, 2024
1 parent 8632b29 commit 5dfa974
Show file tree
Hide file tree
Showing 6 changed files with 408 additions and 180 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@
"@opentelemetry/instrumentation": "^0.46.0"
},
"devDependencies": {
"llamaindex": "^0.3.14"
"jest": "^29.7.0",
"llamaindex": "^0.3.14",
"openai": "^4.24.1"
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,13 @@ import {
InstrumentationNodeModuleDefinition,
} from "@opentelemetry/instrumentation";
import { diag } from "@opentelemetry/api";
import { patchQueryMethod, patchRetrieveMethod } from "./utils";
import {
patchQueryEngineQueryMethod,
patchRetrieveMethod,
patchQueryEmbeddingMethod,
isRetrieverPrototype,
isEmbeddingPrototype,
} from "./utils";
import { VERSION } from "./version";

const MODULE_NAME = "llamaindex";
Expand Down Expand Up @@ -58,31 +64,52 @@ export class LlamaIndexInstrumentation extends InstrumentationBase<
}

// TODO: Support streaming
// TODO: Generalize to QueryEngine interface (RetrieverQueryEngine, RouterQueryEngine)
this._wrap(
moduleExports.RetrieverQueryEngine.prototype,
"query",
// eslint-disable-next-line @typescript-eslint/no-explicit-any
(original): any => {
return patchQueryMethod(original, moduleExports, this.tracer);
return patchQueryEngineQueryMethod(original, this.tracer);
},
);

this._wrap(
moduleExports.VectorIndexRetriever.prototype,
"retrieve",
(original) => {
return patchRetrieveMethod(original, moduleExports, this.tracer);
},
);
for (const value of Object.values(moduleExports)) {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const prototype = (value as any).prototype;

if (isRetrieverPrototype(prototype)) {
this._wrap(prototype, "retrieve", (original) => {
return patchRetrieveMethod(original, this.tracer);
});
}

if (isEmbeddingPrototype(prototype)) {
this._wrap(prototype, "getQueryEmbedding", (original) => {
return patchQueryEmbeddingMethod(original, this.tracer);
});
}
}
_isOpenInferencePatched = true;
return moduleExports;
}

private unpatch(moduleExports: typeof llamaindex, moduleVersion?: string) {
this._diag.debug(`Un-patching ${MODULE_NAME}@${moduleVersion}`);
this._unwrap(moduleExports.RetrieverQueryEngine.prototype, "query");
this._unwrap(moduleExports.VectorIndexRetriever.prototype, "retrieve");

for (const value of Object.values(moduleExports)) {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const prototype = (value as any).prototype;

if (isRetrieverPrototype(prototype)) {
this._unwrap(prototype, "retrieve");
}

if (isEmbeddingPrototype(prototype)) {
this._unwrap(prototype, "getQueryEmbedding");
}
}

_isOpenInferencePatched = false;
}
Expand Down
62 changes: 9 additions & 53 deletions js/packages/openinference-instrumentation-llama-index/src/types.ts
Original file line number Diff line number Diff line change
@@ -1,39 +1,5 @@
import { SemanticConventions } from "@arizeai/openinference-semantic-conventions";

export type RetrievalDocument = {
[SemanticConventions.DOCUMENT_ID]?: string;
[SemanticConventions.DOCUMENT_CONTENT]?: string;
[SemanticConventions.DOCUMENT_SCORE]?: number | undefined;
[SemanticConventions.DOCUMENT_METADATA]?: string;
};

type LLMMessageToolCall = {
[SemanticConventions.TOOL_CALL_FUNCTION_NAME]?: string;
[SemanticConventions.TOOL_CALL_FUNCTION_ARGUMENTS_JSON]?: string;
};

export type LLMMessageToolCalls = {
[SemanticConventions.MESSAGE_TOOL_CALLS]?: LLMMessageToolCall[];
};

export type LLMMessageFunctionCall = {
[SemanticConventions.MESSAGE_FUNCTION_CALL_NAME]?: string;
[SemanticConventions.MESSAGE_FUNCTION_CALL_ARGUMENTS_JSON]?: string;
};

export type LLMMessage = LLMMessageToolCalls &
LLMMessageFunctionCall & {
[SemanticConventions.MESSAGE_ROLE]?: string;
[SemanticConventions.MESSAGE_CONTENT]?: string;
};

export type LLMMessagesAttributes =
| {
[SemanticConventions.LLM_INPUT_MESSAGES]: LLMMessage[];
}
| {
[SemanticConventions.LLM_OUTPUT_MESSAGES]: LLMMessage[];
};
import * as llamaindex from "llamaindex";
import { BaseRetriever } from "llamaindex";

// eslint-disable-next-line @typescript-eslint/no-explicit-any
export type GenericFunction = (...args: any[]) => any;
Expand All @@ -42,22 +8,12 @@ export type SafeFunction<T extends GenericFunction> = (
...args: Parameters<T>
) => ReturnType<T> | null;

export type LLMParameterAttributes = {
[SemanticConventions.LLM_MODEL_NAME]?: string;
[SemanticConventions.LLM_INVOCATION_PARAMETERS]?: string;
};
export type ObjectWithModel = { model: string };

export type RetrieverQueryEngineQueryMethodType =
typeof llamaindex.RetrieverQueryEngine.prototype.query;

export type PromptTemplateAttributes = {
[SemanticConventions.PROMPT_TEMPLATE_TEMPLATE]?: string;
[SemanticConventions.PROMPT_TEMPLATE_VARIABLES]?: string;
};
export type TokenCountAttributes = {
[SemanticConventions.LLM_TOKEN_COUNT_COMPLETION]?: number;
[SemanticConventions.LLM_TOKEN_COUNT_PROMPT]?: number;
[SemanticConventions.LLM_TOKEN_COUNT_TOTAL]?: number;
};
export type RetrieverRetrieveMethodType = BaseRetriever["retrieve"];

export type ToolAttributes = {
[SemanticConventions.TOOL_NAME]?: string;
[SemanticConventions.TOOL_DESCRIPTION]?: string;
};
export type QueryEmbeddingMethodType =
typeof llamaindex.BaseEmbedding.prototype.getQueryEmbedding;
Loading

0 comments on commit 5dfa974

Please sign in to comment.