ONNX model 13049 outputs

#78
by here4data - opened

Which pooling technique does the '13049' output use?
Maybe the answer exists, but I don't think its obvious ... When manually normalizing and mean pooling the onnx embeddings, these results lines up with HF/ST mean-pooling, however it does not line up with 13049, so I assume 13049 does not do mean pooling?

As a sidenote, if mean pooling is the recommended technique, why not have the onnx model output the mean pooling embedding rather than us post-processing the embeddings?

These questions may be ill-posed due to my lack of knowledge, but hopefully I get answers!

Hi @here4data , what do you mean by 13049?

Hi @jupyterjazz , 13049 is the label given to one of the outputs of the ONNX model, along with text_embeds

 'inputs': [{'name': 'task_id', 'datatype': 'INT64', 'shape': [1]},
  {'name': 'attention_mask', 'datatype': 'INT64', 'shape': [-1, -1]},
  {'name': 'input_ids', 'datatype': 'INT64', 'shape': [-1, -1]}],
 'outputs': [{'name': '13049', 'datatype': 'FP32', 'shape': [-1, 1024]},
  {'name': 'text_embeds', 'datatype': 'FP32', 'shape': [-1, -1, 1024]}]}

I also wanted to ask about the task_id input being optional in HF/ST but mandatory in ONNX. Are the HF/ST approaches just using one of the loras by default? and if so, which one?

Thanks!

Hi @here4data , thanks for clarifying the question. The 13049 output is a cls embedding, however we don't train our models on the cls embeddings so it's redundant and should not be used.

I also wanted to ask about the task_id input being optional in HF/ST but mandatory in ONNX. Are the HF/ST approaches just using one of the loras by default? and if so, which one?

HF/ST are using no adapters by default. We went with a mandatory task type for onnx because of the implementation nuances, however supporting no-adapter option should not be difficult so if you'd like to see it lmk and I can update it sometime next week.

@jupyterjazz Thanks for the reply and the no-adapter option would be very helpful in ONNX format, I appreciate it very much!

@jupyterjazz Is it necessary to prepend the input text with the task_instructions (for retrieval.query/retrieval.passage) when doing inference using ONNX, or is it somehow automatically prepended by the model during inference?

Hi @Nemphys , yes you should prepend the insturctions for the retrieval tasks

Sign up or log in to comment