llama_index 我想要构建一个本地的多模态RAG聊天机器人,但是遇到了以下错误,

fafcakar  于 6个月前  发布在  其他
关注(0)|答案(7)|浏览(73)

问题验证

  • 我已在文档和Discord中寻找答案。

问题

  1. # This class will transform video to text and images
  2. class VideoProcessor:
  3. def __init__(self, video_path, output_audio_path, output_folder):
  4. self.video_path = video_path
  5. self.output_audio_path = output_audio_path
  6. self.image_path = output_folder
  7. self.text_path = output_folder
  8. def extract_audio(self):
  9. video = VideoFileClip(os.path.join(self.video_path, "input.mp4"))
  10. audio_part = video.audio
  11. audio_part.write_audiofile(os.path.join(self.output_audio_path, "output_audio.mp3"))
  12. def extract_text(self):
  13. model = whisper.load_model("base")
  14. result = model.transcribe(os.path.join(self.output_audio_path, "output_audio.mp3"))
  15. with open(os.path.join(self.text_path, "audio.md"), "w") as file:
  16. file.write(result['text'])
  17. file.close()
  18. def extract_frames(self):
  19. clip = VideoFileClip(os.path.join(self.video_path, "input.mp4"))
  20. clip.write_images_sequence(os.path.join(self.image_path, "frame%04d.png"), fps=0.2)
  21. def process_video(self):
  22. self.extract_audio()
  23. self.extract_text()
  24. self.extract_frames()
  25. # This class maker sure RAG and ask
  26. class retriever_ask:
  27. def __init__(self, output_folder, similarity_top_k, image_similarity_top_k) -> None:
  28. self.text_store = LanceDBVectorStore(uri="lancedb", table_name="text_collection")
  29. self.image_store = LanceDBVectorStore(uri="lancedb", table_name="image_collection")
  30. self.output_folder = output_folder
  31. self.similarity_top_k = similarity_top_k
  32. self.image_similarity_top_k = image_similarity_top_k
  33. # self.llm = Ollama(model='llava', request_timeout=100)
  34. self.llm = OllamaMultiModal(model='llava', request_timeout=3600)
  35. self.qa_tmpl_str = (
  36. """
  37. Given the provided information, including relevant images and retrieved context from the video,\
  38. accurately and precisely answer the query without any additional prior knowledge.\n"
  39. "Please ensure honesty and responsibility, refraining from any racist or sexist remarks.\n"
  40. "---------------------\n"
  41. "Context: {context_str}\n"
  42. "Metadata for video: {metadata_str} \n"
  43. "---------------------\n"
  44. "Query: {query_str}\n"
  45. "Answer: "
  46. """
  47. )
  48. def retriever_engine(self):
  49. documents = SimpleDirectoryReader(self.output_folder).load_data()
  50. storage_context = StorageContext.from_defaults(vector_store=self.text_store, image_store=self.image_store)
  51. index = MultiModalVectorStoreIndex.from_documents(documents, storage_context=storage_context)
  52. retriever_engine = index.as_retriever(similarity_top_k=self.similarity_top_k, image_similarity_top_k=self.image_similarity_top_k)
  53. return retriever_engine
  54. def retrieve(self, retriever_engine, query_str):
  55. retrieval_results = retriever_engine.retrieve(query_str)
  56. retrieved_image = []
  57. retrieved_text = []
  58. for res_node in retrieval_results:
  59. if isinstance(res_node.node, ImageNode):
  60. retrieved_image.append(res_node.node.metadata["file_path"])
  61. else:
  62. retrieved_text.append(res_node.text)
  63. return retrieved_image, retrieved_text
  64. def ask(self):
  65. retriever_engine = self.retriever_engine()
  66. while True:
  67. try:
  68. query_str = input('\033[94m' +"Prompt: " + '\033[0m')
  69. image, text = self.retrieve(retriever_engine=retriever_engine, query_str=query_str)
  70. context_str = "".join(text)
  71. metadata_str= image
  72. image_documents = SimpleDirectoryReader(input_dir=self.output_folder, input_files=image).load_data()
  73. response = self.llm.complete(prompt=self.qa_tmpl_str.format(context_str=context_str, query_str=query_str, metadata_str=metadata_str),image_documents=image_documents)
  74. print(response)
  75. except KeyboardInterrupt:
  76. break
  77. if __name__ == '__main__':
  78. Settings.embed_model = HuggingFaceEmbedding(model_name="BAAI/bge-small-en-v1.5")
  79. video_path = './video/'
  80. output_audio_path = './audio/'
  81. output_folder= './output/'
  82. # process video to images and text
  83. processor = VideoProcessor(video_path, output_audio_path, output_folder)
  84. processor.process_video()
  85. # Ask question
  86. engine = retriever_ask(output_folder, 5, 5)
  87. engine.ask()

但我遇到了以下问题:

  1. Prompt: hello
  2. Traceback (most recent call last):
  3. File "/usr/local/lib/python3.8/dist-packages/httpx/_transports/default.py", line 69, in map_httpcore_exceptions
  4. yield
  5. File "/usr/local/lib/python3.8/dist-packages/httpx/_transports/default.py", line 233, in handle_request
  6. resp = self._pool.handle_request(req)
  7. File "/usr/local/lib/python3.8/dist-packages/httpcore/_sync/connection_pool.py", line 216, in handle_request
  8. raise exc from None
  9. File "/usr/local/lib/python3.8/dist-packages/httpcore/_sync/connection_pool.py", line 196, in handle_request
  10. response = connection.handle_request(
  11. File "/usr/local/lib/python3.8/dist-packages/httpcore/_sync/connection.py", line 101, in handle_request
  12. return self._connection.handle_request(request)
  13. File "/usr/local/lib/python3.8/dist-packages/httpcore/_sync/http11.py", line 143, in handle_request
  14. raise exc
  15. File "/usr/local/lib/python3.8/dist-packages/httpcore/_sync/http11.py", line 113, in handle_request
  16. ) = self._receive_response_headers(**kwargs)
  17. File "/usr/local/lib/python3.8/dist-packages/httpcore/_sync/http11.py", line 186, in _receive_response_headers
  18. event = self._receive_event(timeout=timeout)
  19. File "/usr/local/lib/python3.8/dist-packages/httpcore/_sync/http11.py", line 224, in _receive_event
  20. data = self._network_stream.read(
  21. File "/usr/local/lib/python3.8/dist-packages/httpcore/_backends/sync.py", line 126, in read
  22. return self._sock.recv(max_bytes)
  23. File "/usr/lib/python3.8/contextlib.py", line 131, in __exit__
  24. self.gen.throw(type, value, traceback)
  25. File "/usr/local/lib/python3.8/dist-packages/httpcore/_exceptions.py", line 14, in map_exceptions
  26. raise to_exc(exc) from exc
  27. httpcore.ReadTimeout: timed out
  28. The above exception was the direct cause of the following exception:
  29. Traceback (most recent call last):
  30. File "./mulitRAG.py", line 153, in <module>
  31. engine.ask()
  32. File "./mulitRAG.py", line 135, in ask
  33. response = self.llm.complete(prompt=self.qa_tmpl_str.format(context_str=context_str, query_str=query_str, metadata_str=metadata_str),image_documents=image_documents)
  34. File "/usr/local/lib/python3.8/dist-packages/llama_index/multi_modal_llms/ollama/base.py", line 160, in complete
  35. response = self._client.generate(
  36. File "/usr/local/lib/python3.8/dist-packages/ollama/_client.py", line 126, in generate
  37. return self._request_stream(
  38. File "/usr/local/lib/python3.8/dist-packages/ollama/_client.py", line 97, in _request_stream
  39. return self._stream(*args, **kwargs) if stream else self._request(*args, **kwargs).json()
  40. File "/usr/local/lib/python3.8/dist-packages/ollama/_client.py", line 68, in _request
  41. response = self._client.request(method, url, **kwargs)
  42. File "/usr/local/lib/python3.8/dist-packages/httpx/_client.py", line 827, in request
  43. return self.send(request, auth=auth, follow_redirects=follow_redirects)
  44. File "/usr/local/lib/python3.8/dist-packages/httpx/_client.py", line 914, in send
  45. response = self._send_handling_auth(
  46. File "/usr/local/lib/python3.8/dist-packages/httpx/_client.py", line 942, in _send_handling_auth
  47. response = self._send_handling_redirects(
  48. File "/usr/local/lib/python3.8/dist-packages/httpx/_client.py", line 979, in _send_handling_redirects
  49. response = self._send_single_request(request)
  50. File "/usr/local/lib/python3.8/dist-packages/httpx/_client.py", line 1015, in _send_single_request
  51. response = transport.handle_request(request)
  52. File "/usr/local/lib/python3.8/dist-packages/httpx/_transports/default.py", line 233, in handle_request
  53. resp = self._pool.handle_request(req)
  54. File "/usr/lib/python3.8/contextlib.py", line 131, in __exit__
  55. self.gen.throw(type, value, traceback)
  56. File "/usr/local/lib/python3.8/dist-packages/httpx/_transports/default.py", line 86, in map_httpcore_exceptions
  57. raise mapped_exc(message) from exc
  58. httpx.ReadTimeout: timed out

我确信我的电脑正在对我的问题进行推理,但我没有得到对问题的回应。

qqrboqgw

qqrboqgw1#

要解决在运行本地多模态RAG聊天机器人代码时遇到的超时问题,你可以在 OllamaMultiModal 类中设置 request_timeout 参数。此参数指定向 Ollama API 服务器发出 HTTP 请求的超时时间。
以下是如何设置 request_timeout 参数的方法:

  1. ollama_model = OllamaMultiModal(
  2. base_url="http://localhost:11434",
  3. model="llava",
  4. temperature=0.75,
  5. context_window=DEFAULT_CONTEXT_WINDOW,
  6. request_timeout=3600, # Set the timeout to 3600 seconds (1 hour) or any other value you prefer
  7. additional_kwargs={}
  8. )

在你的代码中,你已经将 request_timeout 设置为 3600 秒,这对于大多数情况来说应该足够了。然而,如果你仍然遇到超时问题,可以考虑以下附加步骤:

  1. 检查网络稳定性:确保你的网络连接稳定,请求过程中没有中断。
  2. 优化视频处理:大型视频文件需要花费大量时间进行处理。确保你的视频处理步骤(音频提取、文本提取和帧提取)针对性能进行了优化。
  3. 进一步增加超时:如果必要,你可以进一步增加 request_timeout 值以容纳更长的处理时间。
  4. 调试和日志记录:启用详细的日志记录以诊断超时发生的位置。你可以按照以下方式在应用程序中启用调试日志记录:
  1. import logging
  2. import sys
  3. logging.basicConfig(stream=sys.stdout, level=logging.DEBUG)
  4. logging.getLogger().addHandler(logging.StreamHandler(stream=sys.stdout))
  1. 异步操作:如果可能,考虑使用异步操作来处理长时间运行的任务,而不阻塞主线程。
    通过遵循这些步骤,你应该能够诊断并解决多模态 RAG 聊天机器人代码中的超时问题。
  • 要继续与 Dosu 交谈,请提及 @dosu。*
展开查看全部
tpgth1q7

tpgth1q72#

所以有人帮忙,我是不是用了一些错误的功能?

tag5nh1u

tag5nh1u3#

要解决本地多模态RAG聊天机器人代码中的超时问题,请确保将 request_timeout 参数正确传递给 Client 初始化。提供的代码已经使用 request_timeout 值在 Client 初始化中设置了 timeout 参数。
以下是相关代码部分:

  1. class OllamaMultiModal(MultiModalLLM):
  2. # ... other fields and methods ...
  3. def __init__(self, **kwargs: Any) -> None:
  4. """Init params."""
  5. super().__init__(**kwargs)
  6. self._client = Client(host=self.base_url, timeout=self.request_timeout)

如果您仍然遇到超时问题,请考虑检查以下内容:

  1. 网络问题:确保没有网络问题导致超时。
  2. 服务器性能:验证托管模型的服务器是否能够在指定的超时时间内处理请求。
  3. 客户端配置:在初始化 OllamaMultiModal 示例时,请仔细检查 request_timeout 是否正确设置。
    此外,请确保 ollama 库已正确安装和导入,如 OllamaMultiModal 类所示:
  1. def __init__(self, **kwargs: Any) -> None:
  2. """Init params."""
  3. # make sure that ollama is installed
  4. try:
  5. import ollama # noqa: F401
  6. except ImportError:
  7. raise ImportError(
  8. "Ollama is not installed. Please install it using `pip install ollama`."
  9. )
  10. super().__init__(**kwargs)

如果所有配置都正确,问题仍然存在,您可能需要进一步调查服务器日志或网络条件,以确定超时的根源。
此外,请确保 httpx.ClientTimeout 对象正确使用,如 Ollama 类所示(来自 llama-index 库):

  1. with httpx.Client(timeout=Timeout(self.request_timeout)) as client:
  2. response = client.post(
  3. url=f"{self.base_url}/api/chat",
  4. json=payload,
  5. )
  6. response.raise_for_status()
  7. raw = response.json()
  8. message = raw["message"]
  9. return ChatResponse(
  10. message=ChatMessage(
  11. content=message.get("content"),
  12. role=MessageRole(message.get("role")),
  13. additional_kwargs=get_additional_kwargs(
  14. message, ("content", "role")
  15. ),
  16. ),
  17. raw=raw,
  18. additional_kwargs=get_additional_kwargs(raw, ("message",)),
  19. )

请确保正确示例化并将 Timeout 对象传递给 httpx.Client 以正确处理请求超时。要继续与 Dosu 交谈,请提及 @dosu。

展开查看全部
9njqaruj

9njqaruj4#

你好,我想使用 clip 来嵌入我的图片和文本,我该如何使用它?你能给我一个例子吗?

isr3a4wc

isr3a4wc5#

要切换到使用CLIP将您的图像和文本嵌入到本地多模态RAG聊天机器人中,您可以使用llama_index/embeddings/clip/base.py文件中的ClipEmbedding类。以下是逐步指南:

  1. 安装所需软件包:
  1. pip install git+https://github.com/openai/CLIP.git
  2. pip install torch pillow
  1. 初始化ClipEmbedding:
  1. from llama_index.embeddings.clip import ClipEmbedding
  2. clip_embedding = ClipEmbedding(
  3. embed_batch_size=10, # You can adjust the batch size as needed
  4. model_name="ViT-B/32" # You can choose from the available CLIP models
  5. )
  1. 生成文本嵌入:
  1. text = "Your text here"
  2. text_embedding = clip_embedding._get_text_embedding(text)
  1. 生成图像嵌入:
  1. img_file_path = "path/to/your/image.jpg"
  2. image_embedding = await clip_embedding._aget_image_embedding(img_file_path)

以下是一个完整示例:

  1. import asyncio
  2. from llama_index.embeddings.clip import ClipEmbedding
  3. # Initialize the ClipEmbedding class
  4. clip_embedding = ClipEmbedding(
  5. embed_batch_size=10, # Adjust the batch size as needed
  6. model_name="ViT-B/32" # Choose from the available CLIP models
  7. )
  8. # Generate text embedding
  9. text = "Your text here"
  10. text_embedding = clip_embedding._get_text_embedding(text)
  11. print("Text Embedding:", text_embedding)
  12. # Generate image embedding
  13. async def get_image_embedding():
  14. img_file_path = "path/to/your/image.jpg"
  15. image_embedding = await clip_embedding._aget_image_embedding(img_file_path)
  16. print("Image Embedding:", image_embedding)
  17. # Run the async function to get image embedding
  18. asyncio.run(get_image_embedding())

此代码将初始化CLIP模型,为提供的文本和图像生成嵌入,并打印嵌入1(https://github.com/run-llama/llama_index/blob/main/llama-index-legacy/llama_index/legacy/embeddings/clip.py)2(https://github.com/run-llama/llama_index/blob/main/llama-index-integrations/embeddings/llama-index-embeddings-clip/llama_index/embeddings/clip/base.py)。

  • 要继续与Dosu交谈,请提及@dosu。*
展开查看全部
arknldoa

arknldoa6#

要切换到使用CLIP将您的图像和文本嵌入到本地多模态RAG聊天机器人中,您可以使用llama_index/embeddings/clip/base.py文件中的ClipEmbedding类。以下是逐步指南:

  1. 安装所需的包:
  1. pip install git+https://github.com/openai/CLIP.git
  2. pip install torch pillow
  1. 初始化ClipEmbedding:
  1. from llama_index.embeddings.clip import ClipEmbedding
  2. clip_embedding = ClipEmbedding(
  3. embed_batch_size=10, # You can adjust the batch size as needed
  4. model_name="ViT-B/32" # You can choose from the available CLIP models
  5. )
  1. 生成文本嵌入:
  1. text = "Your text here"
  2. text_embedding = clip_embedding._get_text_embedding(text)
  1. 生成图像嵌入:
  1. img_file_path = "path/to/your/image.jpg"
  2. image_embedding = await clip_embedding._aget_image_embedding(img_file_path)

以下是一个完整的例子:

  1. import asyncio
  2. from llama_index.embeddings.clip import ClipEmbedding
  3. # Initialize the ClipEmbedding class
  4. clip_embedding = ClipEmbedding(
  5. embed_batch_size=10, # Adjust the batch size as needed
  6. model_name="ViT-B/32" # Choose from the available CLIP models
  7. )
  8. # Generate text embedding
  9. text = "Your text here"
  10. text_embedding = clip_embedding._get_text_embedding(text)
  11. print("Text Embedding:", text_embedding)
  12. # Generate image embedding
  13. async def get_image_embedding():
  14. img_file_path = "path/to/your/image.jpg"
  15. image_embedding = await clip_embedding._aget_image_embedding(img_file_path)
  16. print("Image Embedding:", image_embedding)
  17. # Run the async function to get image embedding
  18. asyncio.run(get_image_embedding())

这段代码将初始化CLIP模型,为提供的文本和图像生成嵌入,并打印嵌入 1(https://github.com/run-llama/llama_index/blob/main/llama-index-legacy/llama_index/legacy/embeddings/clip.py) 和 2(https://github.com/run-llama/llama_index/blob/main/llama-index-integrations/embeddings/llama-index-embeddings-clip/llama_index/embeddings/clip/base.py) 。

  • 要继续与 Dosu 交谈,请提及 @dosu。*

使用clip与LanceDBVectorStore的示例

展开查看全部
w8f9ii69

w8f9ii697#

将当前的嵌入模型替换为CLIP并在本地多模态RAG聊天机器人中使用它,请按照以下步骤操作:

  1. 安装所需的包:
  1. pip install git+https://github.com/openai/CLIP.git
  2. pip install torch pillow
  1. 定义 ClipEmbedding:
    使用提供的 ClipEmbedding 类,使用CLIP模型生成嵌入。这里是完整的类定义:
  1. import logging
  2. from typing import Any, List
  3. from llama_index.core.bridge.pydantic import Field, PrivateAttr
  4. from llama_index.core.constants import DEFAULT_EMBED_BATCH_SIZE
  5. from llama_index.core.embeddings.multi_modal_base import MultiModalEmbedding
  6. from llama_index.core.schema import ImageType
  7. from PIL import Image
  8. import os
  9. logger = logging.getLogger(__name__)
  10. AVAILABLE_CLIP_MODELS = (
  11. "RN50",
  12. "RN101",
  13. "RN50x4",
  14. "RN50x16",
  15. "RN50x64",
  16. "ViT-B/32",
  17. "ViT-B/16",
  18. "ViT-L/14",
  19. "ViT-L/14@336px",
  20. )
  21. DEFAULT_CLIP_MODEL = "ViT-B/32"
  22. class ClipEmbedding(MultiModalEmbedding):
  23. """CLIP embedding models for encoding text and image for Multi-Modal purpose.
  24. This class provides an interface to generate embeddings using a model
  25. deployed in OpenAI CLIP. At the initialization it requires a model name
  26. of CLIP.
  27. Note:
  28. Requires `clip` package to be available in the PYTHONPATH. It can be installed with
  29. `pip install git+https://github.com/openai/CLIP.git`.
  30. """
  31. embed_batch_size: int = Field(default=DEFAULT_EMBED_BATCH_SIZE, gt=0)
  32. _clip: Any = PrivateAttr()
  33. _model: Any = PrivateAttr()
  34. _preprocess: Any = PrivateAttr()
  35. _device: Any = PrivateAttr()
  36. @classmethod
  37. def class_name(cls) -> str:
  38. return "ClipEmbedding"
  39. def __init__(
  40. self,
  41. *,
  42. embed_batch_size: int = DEFAULT_EMBED_BATCH_SIZE,
  43. model_name: str = DEFAULT_CLIP_MODEL,
  44. **kwargs: Any,
  45. ):
  46. """Initializes the ClipEmbedding class.
  47. During the initialization the `clip` package is imported.
  48. Args:
  49. embed_batch_size (int, optional): The batch size for embedding generation. Defaults to 10,
  50. must be > 0 and <= 100.
  51. model_name (str): The model name of Clip model.
  52. Raises:
  53. ImportError: If the `clip` package is not available in the PYTHONPATH.
  54. ValueError: If the model cannot be fetched from Open AI. or if the embed_batch_size
  55. is not in the range (0, 100].
  56. """
  57. if embed_batch_size <= 0:
  58. raise ValueError(f"Embed batch size {embed_batch_size} must be > 0.")
  59. try:
  60. import clip
  61. import torch
  62. except ImportError:
  63. raise ImportError(
  64. "ClipEmbedding requires `pip install git+https://github.com/openai/CLIP.git` and torch."
  65. )
  66. super().__init__(
  67. embed_batch_size=embed_batch_size, model_name=model_name, **kwargs
  68. )
  69. try:
  70. self._device = "cuda" if torch.cuda.is_available() else "cpu"
  71. is_local_path = os.path.exists(self.model_name)
  72. if not is_local_path and self.model_name not in AVAILABLE_CLIP_MODELS:
  73. raise ValueError(
  74. f"Model name {self.model_name} is not available in CLIP."
  75. )
  76. self._model, self._preprocess = clip.load(
  77. self.model_name, device=self._device
  78. )
  79. except Exception as e:
  80. logger.error("Error while loading clip model.")
  81. raise ValueError("Unable to fetch the requested embeddings model") from e
  82. # TEXT EMBEDDINGS
  83. async def _aget_query_embedding(self, query: str) -> Embedding:
  84. return self._get_query_embedding(query)
  85. def _get_text_embedding(self, text: str) -> Embedding:
  86. return self._get_text_embeddings([text])[0]
  87. def _get_text_embeddings(self, texts: List[str]) -> List<Embedding]:
  88. results = []
  89. for text in texts:
  90. try:
  91. import clip
  92. except ImportError:
  93. raise ImportError(
  94. "ClipEmbedding requires `pip install git+https://github.com/openai/CLIP.git` and torch."
  95. )
  96. text_embedding = self._model.encode_text(
  97. clip.tokenize(text).to(self._device)
  98. )
  99. results.append(text_embedding.tolist()[0])
  100. return results
  101. def _get_query_embedding(self, query: str) -> Embedding:
  102. return self._get_text_embedding(query)
  103. # IMAGE EMBEDDINGS
  104. async def _aget_image_embedding(self, img_file_path: ImageType) -> Embedding:
  105. return self._get_image_embedding(img_file_path)
  106. def _get_image_embedding(self, img_file_path: ImageType) -> Embedding:
  107. import torch
  108. with torch.no_grad():
  109. image = (
  110. self._preprocess(Image.open(img_file_path))
  111. .unsqueeze(0)
  112. .to(self._device)
  113. )
  114. return self._model.encode_image(image).tolist()[0]
  1. LanceDBVectorStore 集成:
    假设你有一个 LanceDBVectorStore 类,你需要将其与 ClipEmbedding 类集成。下面是一个简化的示例,展示了如何进行此操作:
  1. from lance_db_vector_store import LanceDBVectorStore # Assuming you have this class
  2. from llama_index.embeddings.clip import ClipEmbedding # Importing ClipEmbedding from llama_index
  3. # Initialize the ClipEmbedding
  4. clip_embedding = ClipEmbedding(model_name="ViT-B/32")
  5. # Create an instance of LanceDBVectorStore with the ClipEmbedding
  6. vector_store = LanceDBVectorStore(embedding_model=clip_embedding)
  7. # Example usage
  8. text = "A sample text to encode"
  9. text_embedding = clip_embedding._get_text_embedding(text)
  10. vector_store.add_embedding(text, text_embedding)
  11. # For image embeddings
  12. image_path = "path/to/your/image.jpg"
  13. image_embedding = clip_embedding._get_image_embedding(image_path)
  14. vector_store.add_embedding(image_path, image_embedding)

这段代码演示了如何初始化 ClipEmbedding 类,生成文本和图像嵌入,并将它们添加到 LanceDBVectorStore 中。根据你对 LanceDBVectorStore1(https://github.com/run-llama/llama_index/blob/main/llama-index-legacy/llama_index/legacy/embeddings/clip.py)2(https://github.com/run-llama/llama_index/blob/main/llama-index-integrations/embeddings/llama-index-embeddings-clip/llama_index/embeddings/clip/base.py)3(https://github.com/run-llama/llama_index/blob/main/llama-index-integrations/embeddings/llama-index-embeddings-clip/llama_index/embeddings/clip/init.py) 的具体实现,调整集成方式。

  • 要继续与 Dosu 对话,请提及 @dosu。*
展开查看全部

相关问题