All Downloads are FREE. Search and download functionalities are using the official Maven repository.

nlp-core-shared.22.3.2.source-code.NlpCore.kt Maven / Gradle / Ivy

/*
 * Copyright (C) 2017/2021 e-voyageurs technologies
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package ai.tock.nlp.core

import ai.tock.nlp.core.IntentSelector.Companion.defaultIntentSelector
import ai.tock.nlp.core.merge.ValueDescriptor

/**
 * The main entry point for NLP.
 */
interface NlpCore {

    /**
     * Returns all built-in entities.
     *
     * @return the built-in entity types (namespace:name)
     */
    fun getBuiltInEntityTypes(): Set

    /**
     * Parse text with NLP engine.
     */
    fun parse(
        context: CallContext,
        text: String,
        intentSelector: IntentSelector = defaultIntentSelector
    ):
        ParsingResult

    /**
     * Supported nlp engines.
     */
    fun supportedNlpEngineTypes(): Set

    /**
     * Evaluate entity values.
     *
     * @param context the call context
     * @param text the query
     * @param entities the not yet evaluated identified entities
     *
     * @return the evaluated entities
     */
    fun evaluateEntities(
        context: CallContext,
        text: String,
        entities: List
    ): List

    /**
     * Does the given [EntityType] supports values merge?
     */
    fun supportValuesMerge(entityType: EntityType): Boolean

    /**
     * Merge two or more values for the given [Entity].
     */
    fun mergeValues(context: CallContext, entity: Entity, values: List): ValueDescriptor?

    /**
     * Check engines availability.
     */
    fun healthcheck(): Boolean
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy