topkrouter.h 1.5 KB
Newer Older
blkmjsian's avatar
blkmjsian committed
1
2
3
4
5
6
7
#ifndef __INFINIOP_TOPKRouter_API_H__
#define __INFINIOP_TOPKRouter_API_H__

#include "../operator_descriptor.h"

typedef struct InfiniopDescriptor *infiniopTopkrouterDescriptor_t;

8
__INFINI_C __export infiniStatus_t infiniopCreateTopkrouterDescriptor(infiniopHandle_t handle,
9
10
11
                                                               infiniopTopkrouterDescriptor_t *desc_ptr,
                                                               infiniopTensorDescriptor_t x_desc,
                                                               infiniopTensorDescriptor_t correction_bias_desc);
blkmjsian's avatar
blkmjsian committed
12

13
__INFINI_C __export infiniStatus_t infiniopGetTopkrouterWorkspaceSize(infiniopTopkrouterDescriptor_t desc, size_t *size);
blkmjsian's avatar
blkmjsian committed
14

15
__INFINI_C __export infiniStatus_t infiniopTopkrouter(infiniopTopkrouterDescriptor_t desc,
16
17
18
19
20
21
22
23
24
                                               void *workspace,
                                               size_t workspace_size,
                                               void *values,
                                               void *indices,
                                               const void *x,
                                               const void *correction_bias,
                                               const float routed_scaling_factor,
                                               const size_t topk,
                                               void *stream);
blkmjsian's avatar
blkmjsian committed
25

26
__INFINI_C __export infiniStatus_t infiniopDestroyTopkrouterDescriptor(infiniopTopkrouterDescriptor_t desc);
blkmjsian's avatar
blkmjsian committed
27
28

#endif