Configuration
This page describes how to configure evaluations in Laminar and showcases some common use cases.
Registering human evaluators
You can register human evaluators right from your code. To do this, you will need to
first create a labeling queue, and then pass the queue name to the evaluate
function.
In this example, let’s assume you have created labeling queues with names my_queue
and my_other_queue
.
This will run your programmatic evaluator (“check capital correctness”) and then
send the target
and executor_output
to the queues my_queue
and my_other_queue
.
When a label is added to an item in the queue, it will be added back to the evaluation alongside the programmatic evaluator scores.
You can then visualize the human labeler scores in the UI, and compare them to the programmatic evaluator scores.
Configuring evaluations to report results to locally self-hosted Laminar
In this example, we configure the evaluation to report results to a locally self-hosted Laminar instance.
Evaluations send data to Laminar over both HTTP and gRPC. HTTP is used to create an evaluation and report the datapoints, stats, and trace ids. OpenTelemetry traces themselves are sent over gRPC.
Assuming you have configured Laminar to run on ports 8000 and 8001 on your localhost
, you will need to
pass these values to the evaluate
function.
Run this file either by executing it, or by running it with npx lmnr eval
CLI.
Using a Laminar dataset for evaluations
Prerequisites
Have a dataset uploaded to Laminar, or collected from traces. See datasets for more information.
Defining data
To run an evaluation with a Laminar dataset, you pass the dataset object as data
instead of a list of dictionaries.
Use LaminarDataset
to create a dataset object. The dataset name should match the name of the dataset in Laminar.
The constructor also takes an optional fetch_size
/fetchSize
parameter, which specifies the number of datapoints to fetch at once.
The default value is 25. We strongly recommend setting this value to a number that is a multiple of the
evaluation batch size for best performance.
Technical details and extension
LaminarDataset
is an implementation of an abstract class EvaluationDataset
which defines 2 methods besides initialization:
__len__
(size
in JS): Returns the number of datapoints in the dataset.__getitem__
(get
in JS): Returns a single datapoint by index.
We also implement a concrete slice
method to make slicing easier than using __getitem__
directly.
This is inspired by the PyTorch Dataset
class,
and is designed to be used in a similar way.
You can re-use the EvaluationDataset
class to create your own dataset classes, for example, to fetch data from a database or an API.
Configuring evaluations
evaluate reference
Evaluations in Laminar are configured using the evaluate
function. The function takes the following arguments:
data
: Either (1) A list of dictionaries, where each dictionary contains the data and target for a single evaluation; or (2) An instance ofLaminarDataset
– read more in the dedicated section above.executor
: An optionally async function that takes a single argument, the evaluation data, and returns the output.evaluators
: A dictionary of async functions that take the output and target as arguments and return a score. Keys in the dictionary are the names of the evaluators.humanEvaluators
/human_evaluators
: A list ofHumanEvaluator
objects, which register human evaluators for the evaluation. Read more in the dedicated section above.name
(optional): Evaluation name, so it is easier to identify the evaluation in the UI. If not provided, a random name is assigned.groupId
/group_id
(optional): An optional string that groups evaluations together. Only evaluations with the samegroup_id
can be visually compared.
Additional optional configuration parameters are passed as a config
object in JavaScript/TypeScript and directly to evaluate
in Python.
projectApiKey
: The API key of the project where the evaluation results will be stored. Required, unless you set theLMNR_PROJECT_API_KEY
environment variable.batchSize
: The number of evaluations to run in parallel. Default is5
.baseUrl
: The base URL of the Laminar instance. Do NOT include port here. Default ishttps://api.lmnr.ai
.httpPort
: The port of the Laminar instance for HTTP. Used to send evaluation results and metadata. Default is 443. For local self-hosted Laminar, use 8000.grpcPort
: The port of the Laminar instance for gRPC. Used to send traces via OTel gRPC exporter. Default is 8443. For local self-hosted Laminar, use 8001.instrumentModules
: An object with modules to instrument. Read more in the instrumentation guide.
eval CLI reference
lmnr eval
subcommand is used to run evaluations.
Options
First positional argument is the path to the evaluation file. E.g.
If file is not provided, lmnr eval
will run all files in the evals
directory that match the naming pattern.
For TypeScript/JavaScript, the pattern is *.eval.{ts,js}
. For Python, the pattern is eval_*.py
or *_eval.py
.
Params
--fail-on-error
– if set, the CLI will fail on non-critical errors, for example, if evaluate
is not called in the file. Default is false
.