Table of Contents

Method GetBestCategoryAsync

Namespace
LMKit.TextAnalysis
Assembly
LM-Kit.NET.dll

GetBestCategoryAsync(IList<string>, string, bool, CancellationToken)

Classifies a given text into one of the categories from a predefined list asynchronously.

public Task<int> GetBestCategoryAsync(IList<string> categories, string candidate, bool normalize = true, CancellationToken cancellationToken = default)

Parameters

categories IList<string>

A list of predefined categories. Each entry should provide a description of its corresponding category.

candidate string

The plain text that needs to be classified.

normalize bool

Optional. Indicates whether input parameters should be normalized. The default value is true.

cancellationToken CancellationToken

Optional. A CancellationToken to handle cancellation requests.

Returns

Task<int>

A task representing the asynchronous operation. The task result contains the index within the categories list that best matches the category associated with the candidate text. Returns -1 if no category can be associated.

Examples

using LMKit.Model;
using LMKit.TextAnalysis;
using System;
using System.Collections.Generic;
using System.Threading.Tasks;

class Example
{
    static async Task Main()
    {
        Uri modelUri = new Uri("https://your-model-link-here");
        LM model = new LM(modelUri);

        Categorization categorization = new Categorization(model);
        var categories = new List<string> { "animals", "technology", "music" };
        string text = "A newly discovered frog species can glow in the dark.";

        int bestCategoryIndex = await categorization.GetBestCategoryAsync(categories, text);

        if (bestCategoryIndex != -1)
        {
            Console.WriteLine($"Category: {categories[bestCategoryIndex]}");
        }
        else
        {
            Console.WriteLine("No suitable category found.");
        }

        Console.WriteLine($"Confidence: {categorization.Confidence}");
    }
}

Exceptions

OperationCanceledException

Thrown if the operation is cancelled via the cancellationToken.