diff --git a/camel/agents/chat_agent.py b/camel/agents/chat_agent.py index 1c5f9a2c40..77da097f05 100644 --- a/camel/agents/chat_agent.py +++ b/camel/agents/chat_agent.py @@ -928,6 +928,16 @@ def _step_model_response( # Obtain the model's response response = self.model_backend.run(openai_messages) + # Some OpenAI compatible interfaces do not support the 'n' parameter. + # We will call the API multiple times until we accumulate the expected number of completion choices. + expected_completion_choices = self.model_backend.model_config_dict.get('n', 1) + while len(response.choices) < expected_completion_choices: + logger.warning(f"{self.role_type}[{self.role_name}] expected {expected_completion_choices} completion choices, " + f"but only {len(response.choices)} were returned. " + f"I will make another call until I accumulate {expected_completion_choices} choices") + additional_response = self.model_backend.run(openai_messages) + response.choices.extend(additional_response.choices) + if isinstance(response, ChatCompletion): output_messages, finish_reasons, usage_dict, response_id = ( self.handle_batch_response(response)