nscale.py 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. import base64
  2. from typing import Any
  3. from huggingface_hub.hf_api import InferenceProviderMapping
  4. from huggingface_hub.inference._common import RequestParameters, _as_dict
  5. from ._common import BaseConversationalTask, TaskProviderHelper, filter_none
  6. class NscaleConversationalTask(BaseConversationalTask):
  7. def __init__(self):
  8. super().__init__(provider="nscale", base_url="https://inference.api.nscale.com")
  9. class NscaleTextToImageTask(TaskProviderHelper):
  10. def __init__(self):
  11. super().__init__(provider="nscale", base_url="https://inference.api.nscale.com", task="text-to-image")
  12. def _prepare_route(self, mapped_model: str, api_key: str) -> str:
  13. return "/v1/images/generations"
  14. def _prepare_payload_as_dict(
  15. self, inputs: Any, parameters: dict, provider_mapping_info: InferenceProviderMapping
  16. ) -> dict | None:
  17. mapped_model = provider_mapping_info.provider_id
  18. # Combine all parameters except inputs and parameters
  19. parameters = filter_none(parameters)
  20. if "width" in parameters and "height" in parameters:
  21. parameters["size"] = f"{parameters.pop('width')}x{parameters.pop('height')}"
  22. if "num_inference_steps" in parameters:
  23. parameters.pop("num_inference_steps")
  24. if "cfg_scale" in parameters:
  25. parameters.pop("cfg_scale")
  26. payload = {
  27. "response_format": "b64_json",
  28. "prompt": inputs,
  29. "model": mapped_model,
  30. **parameters,
  31. }
  32. return payload
  33. def get_response(self, response: bytes | dict, request_params: RequestParameters | None = None) -> Any:
  34. response_dict = _as_dict(response)
  35. return base64.b64decode(response_dict["data"][0]["b64_json"])