tri.ai.pips.AiTaskResult.kt Maven / Gradle / Ivy
/*-
* #%L
* tri.promptfx:promptkt
* %%
* Copyright (C) 2023 - 2024 Johns Hopkins University Applied Physics Laboratory
* %%
* 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.
* #L%
*/
package tri.ai.pips
import tri.ai.prompt.trace.*
import java.time.Duration
/**
* Result of executing a task.
* Includes optional parameters for errors, model ids, execution duration, retry attempts.
*/
data class AiTaskResult(
/** Result of the task. */
val value: T? = null,
/** Error message, if any. */
val errorMessage: String? = null,
/** Error that occurred during execution, if any. */
val error: Throwable? = null,
/** Model ID of the task, if any. */
val modelId: String? = null,
/** Duration of first successful or final retry. */
val duration: Duration? = null,
/** Total duration including retries. */
val durationTotal: Duration? = null,
/** Number of executions attempted. */
val attempts: Int? = null,
) {
/** Applies an operation to the result value, if present. All other values are copied directly. */
fun map(function: (T) -> S) = AiTaskResult(
value?.let { function(value) },
errorMessage, error, modelId, duration, durationTotal, attempts
)
/**
* Wraps this as a pipeline result.
* If [promptInfo] and [modelInfo] are provided, result will also be wrapped in [AiPromptTrace].
*/
fun asPipelineResult(promptInfo: AiPromptInfo? = null, modelInfo: AiPromptModelInfo? = null): AiPipelineResult {
if (promptInfo != null && modelInfo != null) {
return map {
AiPromptTrace(
promptInfo,
modelInfo,
AiPromptExecInfo(errorMessage, responseTimeMillis = durationTotal?.toMillis()),
AiPromptOutputInfo(value?.toString())
)
}.asPipelineResult()
}
return AiPipelineResult("result", mapOf("result" to this))
}
companion object {
/** Task with token result. */
fun result(value: T, modelId: String? = null) =
AiTaskResult(value, modelId = modelId)
/** Task not attempted because input was invalid. */
fun invalidRequest(message: String) =
error(message, IllegalArgumentException(message))
/** Task not attempted or successful because of a general error. */
fun error(message: String, error: Throwable) =
AiTaskResult(errorMessage = message, error = error)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy