@arizeai/phoenix-evals 0.4.0 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/dist/esm/llm/ClassificationEvaluator.d.ts +2 -2
  2. package/dist/esm/llm/ClassificationEvaluator.d.ts.map +1 -1
  3. package/dist/esm/llm/ClassificationEvaluator.js.map +1 -1
  4. package/dist/esm/template/applyTemplate.d.ts.map +1 -1
  5. package/dist/esm/template/applyTemplate.js +3 -1
  6. package/dist/esm/template/applyTemplate.js.map +1 -1
  7. package/dist/esm/template/createTemplateVariablesProxy.d.ts +7 -0
  8. package/dist/esm/template/createTemplateVariablesProxy.d.ts.map +1 -0
  9. package/dist/esm/template/createTemplateVariablesProxy.js +61 -0
  10. package/dist/esm/template/createTemplateVariablesProxy.js.map +1 -0
  11. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
  12. package/dist/esm/types/evals.d.ts +2 -1
  13. package/dist/esm/types/evals.d.ts.map +1 -1
  14. package/dist/esm/types/templating.d.ts +7 -0
  15. package/dist/esm/types/templating.d.ts.map +1 -1
  16. package/dist/src/llm/ClassificationEvaluator.d.ts +2 -2
  17. package/dist/src/llm/ClassificationEvaluator.d.ts.map +1 -1
  18. package/dist/src/llm/ClassificationEvaluator.js.map +1 -1
  19. package/dist/src/template/applyTemplate.d.ts.map +1 -1
  20. package/dist/src/template/applyTemplate.js +3 -1
  21. package/dist/src/template/applyTemplate.js.map +1 -1
  22. package/dist/src/template/createTemplateVariablesProxy.d.ts +7 -0
  23. package/dist/src/template/createTemplateVariablesProxy.d.ts.map +1 -0
  24. package/dist/src/template/createTemplateVariablesProxy.js +64 -0
  25. package/dist/src/template/createTemplateVariablesProxy.js.map +1 -0
  26. package/dist/src/types/evals.d.ts +2 -1
  27. package/dist/src/types/evals.d.ts.map +1 -1
  28. package/dist/src/types/templating.d.ts +7 -0
  29. package/dist/src/types/templating.d.ts.map +1 -1
  30. package/dist/tsconfig.tsbuildinfo +1 -1
  31. package/package.json +1 -1
  32. package/src/llm/ClassificationEvaluator.ts +5 -3
  33. package/src/template/applyTemplate.ts +9 -1
  34. package/src/template/createTemplateVariablesProxy.ts +69 -0
  35. package/src/types/evals.ts +2 -1
  36. package/src/types/templating.ts +8 -0
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Creates a Proxy that wraps an object to stringify nested object values when accessed directly.
3
+ * This allows Mustache to access properties of objects (e.g., {{user.name}}) while
4
+ * stringifying objects that are accessed as leaf values (e.g., {{user.profile}}).
5
+ */
6
+ export declare function createTemplateVariablesProxy(obj: unknown): unknown;
7
+ //# sourceMappingURL=createTemplateVariablesProxy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTemplateVariablesProxy.d.ts","sourceRoot":"","sources":["../../../src/template/createTemplateVariablesProxy.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,wBAAgB,4BAA4B,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CA+DlE"}
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createTemplateVariablesProxy = createTemplateVariablesProxy;
4
+ /**
5
+ * Creates a Proxy that wraps an object to stringify nested object values when accessed directly.
6
+ * This allows Mustache to access properties of objects (e.g., {{user.name}}) while
7
+ * stringifying objects that are accessed as leaf values (e.g., {{user.profile}}).
8
+ */
9
+ function createTemplateVariablesProxy(obj) {
10
+ if (obj === null || obj === undefined) {
11
+ return obj;
12
+ }
13
+ if (Array.isArray(obj)) {
14
+ return obj.map(createTemplateVariablesProxy);
15
+ }
16
+ if (typeof obj === "object") {
17
+ return new Proxy(obj, {
18
+ get(target, prop) {
19
+ // Handle toString and valueOf to stringify the object when accessed directly
20
+ if (prop === "toString") {
21
+ return () => JSON.stringify(target);
22
+ }
23
+ if (prop === "valueOf") {
24
+ return () => JSON.stringify(target);
25
+ }
26
+ if (typeof prop !== "string") {
27
+ return Reflect.get(target, prop);
28
+ }
29
+ const value = Reflect.get(target, prop);
30
+ // If the value is an object (not array, not null), wrap it in a proxy
31
+ // so it can be stringified if accessed directly, or have its properties accessed
32
+ if (value !== null &&
33
+ typeof value === "object" &&
34
+ !Array.isArray(value)) {
35
+ return createTemplateVariablesProxy(value);
36
+ }
37
+ return value;
38
+ },
39
+ // Override valueOf and toString to stringify the object when Mustache tries to render it directly
40
+ // Mustache will call toString() when it needs to render an object as a string
41
+ has(target, prop) {
42
+ if (prop === "toString" || prop === "valueOf") {
43
+ return true;
44
+ }
45
+ return Reflect.has(target, prop);
46
+ },
47
+ ownKeys(target) {
48
+ return Reflect.ownKeys(target);
49
+ },
50
+ getOwnPropertyDescriptor(target, prop) {
51
+ if (prop === "toString") {
52
+ return {
53
+ enumerable: false,
54
+ configurable: true,
55
+ value: () => JSON.stringify(target),
56
+ };
57
+ }
58
+ return Reflect.getOwnPropertyDescriptor(target, prop);
59
+ },
60
+ });
61
+ }
62
+ return obj;
63
+ }
64
+ //# sourceMappingURL=createTemplateVariablesProxy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTemplateVariablesProxy.js","sourceRoot":"","sources":["../../../src/template/createTemplateVariablesProxy.ts"],"names":[],"mappings":";;AAKA,oEA+DC;AApED;;;;GAIG;AACH,SAAgB,4BAA4B,CAAC,GAAY;IACvD,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;QACtC,OAAO,GAAG,CAAC;IACb,CAAC;IAED,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;QACvB,OAAO,GAAG,CAAC,GAAG,CAAC,4BAA4B,CAAC,CAAC;IAC/C,CAAC;IAED,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC5B,OAAO,IAAI,KAAK,CAAC,GAA8B,EAAE;YAC/C,GAAG,CAAC,MAAM,EAAE,IAAqB;gBAC/B,6EAA6E;gBAC7E,IAAI,IAAI,KAAK,UAAU,EAAE,CAAC;oBACxB,OAAO,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBACtC,CAAC;gBACD,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;oBACvB,OAAO,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBACtC,CAAC;gBAED,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;oBAC7B,OAAO,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;gBACnC,CAAC;gBAED,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;gBAExC,sEAAsE;gBACtE,iFAAiF;gBACjF,IACE,KAAK,KAAK,IAAI;oBACd,OAAO,KAAK,KAAK,QAAQ;oBACzB,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EACrB,CAAC;oBACD,OAAO,4BAA4B,CAAC,KAAK,CAAC,CAAC;gBAC7C,CAAC;gBAED,OAAO,KAAK,CAAC;YACf,CAAC;YACD,kGAAkG;YAClG,8EAA8E;YAC9E,GAAG,CAAC,MAAM,EAAE,IAAI;gBACd,IAAI,IAAI,KAAK,UAAU,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;oBAC9C,OAAO,IAAI,CAAC;gBACd,CAAC;gBACD,OAAO,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;YACnC,CAAC;YACD,OAAO,CAAC,MAAM;gBACZ,OAAO,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YACjC,CAAC;YACD,wBAAwB,CAAC,MAAM,EAAE,IAAI;gBACnC,IAAI,IAAI,KAAK,UAAU,EAAE,CAAC;oBACxB,OAAO;wBACL,UAAU,EAAE,KAAK;wBACjB,YAAY,EAAE,IAAI;wBAClB,KAAK,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;qBACpC,CAAC;gBACJ,CAAC;gBACD,OAAO,OAAO,CAAC,wBAAwB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;YACxD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,OAAO,GAAG,CAAC;AACb,CAAC"}
@@ -1,4 +1,5 @@
1
1
  import { WithTelemetry } from "./otel";
2
+ import { Template } from "./templating";
2
3
  import { LanguageModel } from "ai";
3
4
  /**
4
5
  * A specific AI example that is under evaluation
@@ -65,7 +66,7 @@ export interface CreateClassifierArgs extends WithTelemetry {
65
66
  /**
66
67
  * The prompt template to use for classification
67
68
  */
68
- promptTemplate: string;
69
+ promptTemplate: Template;
69
70
  }
70
71
  export interface CreateEvaluatorArgs {
71
72
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"evals.d.ts","sourceRoot":"","sources":["../../../src/types/evals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAEvC,OAAO,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AAEnC;;GAEG;AACH,MAAM,WAAW,aAAa,CAAC,UAAU,EAAE,SAAS;IAClD,MAAM,EAAE,UAAU,CAAC;IACnB,QAAQ,CAAC,EAAE,UAAU,CAAC;IACtB,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,OAAO;IACtB,KAAK,EAAE,aAAa,CAAC;CACtB;AAGD,MAAM,WAAW,iBAAkB,SAAQ,OAAO;CAAG;AAErD;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IACf;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IACf;;;OAGG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED;;GAEG;AACH,MAAM,MAAM,wBAAwB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAE9D;;GAEG;AACH,MAAM,WAAW,oBAAqB,SAAQ,aAAa;IAIzD,KAAK,EAAE,aAAa,CAAC;IACrB;;;OAGG;IACH,OAAO,EAAE,wBAAwB,CAAC;IAClC;;OAEG;IACH,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,mBAAmB;IAClC;;;OAGG;IACH,IAAI,EAAE,MAAM,CAAC;IACb;;;OAGG;IACH,qBAAqB,CAAC,EAAE,qBAAqB,CAAC;CAC/C;AAED,MAAM,WAAW,iCACf,SAAQ,oBAAoB,EAC1B,mBAAmB;CAAG;AAE1B,MAAM,MAAM,WAAW,CAAC,WAAW,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI,CACrE,IAAI,EAAE,WAAW,KACd,OAAO,CAAC,gBAAgB,CAAC,CAAC;AAE/B;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,KAAK,GAAG,MAAM,CAAC;AAE5C;;;GAGG;AACH,MAAM,MAAM,qBAAqB,GAAG,UAAU,GAAG,UAAU,CAAC;AAE5D;;GAEG;AACH,UAAU,oBAAoB;IAC5B;;OAEG;IACH,IAAI,EAAE,MAAM,CAAC;IACb;;OAEG;IACH,IAAI,EAAE,cAAc,CAAC;IACrB;;;OAGG;IACH,qBAAqB,CAAC,EAAE,qBAAqB,CAAC;CAC/C;AAED;;;GAGG;AACH,MAAM,WAAW,SAAS,CAAC,WAAW,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CACpE,SAAQ,oBAAoB;IAC5B;;OAEG;IACH,QAAQ,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC;CACpC"}
1
+ {"version":3,"file":"evals.d.ts","sourceRoot":"","sources":["../../../src/types/evals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAExC,OAAO,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AAEnC;;GAEG;AACH,MAAM,WAAW,aAAa,CAAC,UAAU,EAAE,SAAS;IAClD,MAAM,EAAE,UAAU,CAAC;IACnB,QAAQ,CAAC,EAAE,UAAU,CAAC;IACtB,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,OAAO;IACtB,KAAK,EAAE,aAAa,CAAC;CACtB;AAGD,MAAM,WAAW,iBAAkB,SAAQ,OAAO;CAAG;AAErD;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IACf;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IACf;;;OAGG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED;;GAEG;AACH,MAAM,MAAM,wBAAwB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAE9D;;GAEG;AACH,MAAM,WAAW,oBAAqB,SAAQ,aAAa;IAIzD,KAAK,EAAE,aAAa,CAAC;IACrB;;;OAGG;IACH,OAAO,EAAE,wBAAwB,CAAC;IAClC;;OAEG;IACH,cAAc,EAAE,QAAQ,CAAC;CAC1B;AAED,MAAM,WAAW,mBAAmB;IAClC;;;OAGG;IACH,IAAI,EAAE,MAAM,CAAC;IACb;;;OAGG;IACH,qBAAqB,CAAC,EAAE,qBAAqB,CAAC;CAC/C;AAED,MAAM,WAAW,iCACf,SAAQ,oBAAoB,EAC1B,mBAAmB;CAAG;AAE1B,MAAM,MAAM,WAAW,CAAC,WAAW,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI,CACrE,IAAI,EAAE,WAAW,KACd,OAAO,CAAC,gBAAgB,CAAC,CAAC;AAE/B;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,KAAK,GAAG,MAAM,CAAC;AAE5C;;;GAGG;AACH,MAAM,MAAM,qBAAqB,GAAG,UAAU,GAAG,UAAU,CAAC;AAE5D;;GAEG;AACH,UAAU,oBAAoB;IAC5B;;OAEG;IACH,IAAI,EAAE,MAAM,CAAC;IACb;;OAEG;IACH,IAAI,EAAE,cAAc,CAAC;IACrB;;;OAGG;IACH,qBAAqB,CAAC,EAAE,qBAAqB,CAAC;CAC/C;AAED;;;GAGG;AACH,MAAM,WAAW,SAAS,CAAC,WAAW,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CACpE,SAAQ,oBAAoB;IAC5B;;OAEG;IACH,QAAQ,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC;CACpC"}
@@ -1,3 +1,10 @@
1
1
  export type Template = string;
2
2
  export type TemplateVariables = Record<string, unknown>;
3
+ /**
4
+ * A class or object that has a prompt template
5
+ */
6
+ export interface WithPromptTemplate {
7
+ readonly promptTemplate: Template;
8
+ get promptTemplateVariables(): string[];
9
+ }
3
10
  //# sourceMappingURL=templating.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"templating.d.ts","sourceRoot":"","sources":["../../../src/types/templating.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,MAAM,CAAC;AAC9B,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC"}
1
+ {"version":3,"file":"templating.d.ts","sourceRoot":"","sources":["../../../src/types/templating.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,MAAM,CAAC;AAC9B,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAExD;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,QAAQ,CAAC,cAAc,EAAE,QAAQ,CAAC;IAClC,IAAI,uBAAuB,IAAI,MAAM,EAAE,CAAC;CACzC"}