Jump to content

Connect SuperML | Leeroopedia MCP: Equip your AI agents with best practices, code verification, and debugging knowledge. Powered by Leeroo — building Organizational Superintelligence. Contact us at founders@leeroo.com.

Implementation:SeldonIO Seldon core PandasQuery Model

From Leeroopedia
Revision as of 13:50, 16 February 2026 by Admin (talk | contribs) (Auto-imported from implementations/SeldonIO_Seldon_core_PandasQuery_Model.md)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Knowledge Sources
Domains Data_Filtering, Pipeline_Routing, ML_Serving
Last Updated 2026-02-13 14:00 GMT

Overview

Custom MLServer model that filters tabular data using pandas DataFrame query expressions for conditional pipeline routing in Seldon Core 2.

Description

The PandasQueryRuntime class extends MLModel from MLServer to implement a data filtering step. On load, it reads a query expression from the model settings parameters (settings.parameters.extra["query"]). During inference, it decodes the input as a pandas DataFrame using PandasCodec, applies the query expression via DataFrame.query(), and returns the filtered rows with a status column. If no rows match the query, a status message is returned instead.

This is used in Seldon Core 2 pipelines for conditional routing, where a model step filters data before passing it downstream.

Usage

Use this model as a pipeline step when you need to filter incoming tabular data based on a pandas query expression. Configure the query via model settings in the model YAML or model-settings.json file.

Code Reference

Source Location

Signature

class ModelParametersMissing(MLServerError):
    def __init__(self, model_name: str, reason: str):
        """Raised when required model parameters are missing."""

class PandasQueryRuntime(MLModel):
    async def load(self) -> bool:
        """Load query from settings.parameters.extra['query']."""

    async def predict(self, payload: InferenceRequest) -> InferenceResponse:
        """Filter input DataFrame using the configured pandas query expression."""

Import

from pandasquery.model import PandasQueryRuntime

I/O Contract

Inputs

Name Type Required Description
payload InferenceRequest Yes V2 inference request with tabular data decodable by PandasCodec
settings.parameters.extra["query"] string Yes Pandas DataFrame query expression (e.g., "Age > 30")

Outputs

Name Type Description
InferenceResponse InferenceResponse Filtered DataFrame encoded via PandasCodec with added "status" column

Usage Examples

Model Settings Configuration

{
    "name": "pandasquery",
    "implementation": "pandasquery.model.PandasQueryRuntime",
    "parameters": {
        "extra": {
            "query": "Age > 30"
        }
    }
}

Seldon Model YAML

apiVersion: mlops.seldon.io/v1alpha1
kind: Model
metadata:
  name: pandasquery
spec:
  storageUri: "gs://seldon-models/pandasquery"
  requirements:
    - pandas
  parameters:
    - name: query
      value: "Age > 30"

Pipeline with PandasQuery

apiVersion: mlops.seldon.io/v1alpha1
kind: Pipeline
metadata:
  name: income-filter
spec:
  steps:
    - name: income
    - name: pandasquery
      inputs:
        - income
  output:
    steps:
      - pandasquery

Related Pages

Page Connections

Double-click a node to navigate. Hold to expand connections.
Principle
Implementation
Heuristic
Environment