pub trait AsyncEngine<Req: Data, Resp: Data + AsyncEngineContextProvider, E: Data>: Send + Sync {
// Required method
fn generate<'life0, 'async_trait>(
&'life0 self,
request: Req,
) -> Pin<Box<dyn Future<Output = Result<Resp, E>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait;
}
Expand description
Engine is a trait that defines the interface for a steaming LLM completion engine. The synchronous Engine version is does not need to be awaited.
Required Methods§
Implementors§
impl<In: PipelineIO, Out: PipelineIO> AsyncEngine<In, Out, Error> for SegmentSource<In, Out>
impl<In: PipelineIO, Out: PipelineIO> AsyncEngine<In, Out, Error> for ServiceFrontend<In, Out>
impl<T, U> AsyncEngine<Context<AddressedRequest<T>>, Pin<Box<dyn AsyncEngineStream<U, Item = U>>>, Error> for AddressedPushRouter
impl<T, U> AsyncEngine<Context<T>, Pin<Box<dyn AsyncEngineStream<U, Item = U>>>, Error> for Client<T, U>
impl<T, U> AsyncEngine<Context<T>, Pin<Box<dyn AsyncEngineStream<U, Item = U>>>, Error> for Egress<SingleIn<T>, ManyOut<U>>
impl<UpIn, UpOut, DownIn, DownOut> AsyncEngine<UpIn, UpOut, Error> for PipelineOperator<UpIn, UpOut, DownIn, DownOut>
A PipelineOperator
is an AsyncEngine
for the upstream AsyncEngine<UpIn, UpOut, Error>
.