123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- from langchain.vectorstores import Chroma
- from langchain.embeddings.huggingface import HuggingFaceEmbeddings
- import os
- embeddings = HuggingFaceEmbeddings(model_name="/mnt/sdb/zhaoyuan/rongrunxiang/acge_text_embedding")
- persist_directory = 'data_base/vector_db/chroma'
- vectordb = Chroma(
- persist_directory=persist_directory,
- embedding_function=embeddings
- )
- from LLM import ChatGLM_LLM
- modelPath = "/mnt/sdb/zhaoyuan/rongrunxiang/glm-4-9b-chat"
- llm = ChatGLM_LLM(model_path = modelPath)
- llm.predict("你是谁")
- from langchain.prompts import PromptTemplate
- template = """根据用户的问题,从提供的上下文中找到相应的知识,并据此创作一个适合于3-6岁小孩的绘本文本。尽量生动有趣。
- {context}
- 问题: {question}
- 文本:"""
- QA_CHAIN_PROMPT = PromptTemplate(input_variables=["context","question"],template=template)
- from langchain.chains import RetrievalQA
- qa_chain = RetrievalQA.from_chain_type(llm,retriever=vectordb.as_retriever(),return_source_documents=True,chain_type_kwargs={"prompt":QA_CHAIN_PROMPT})
- question = "什么是哺乳动物"
- result = qa_chain({"query": question})
- print("检索问答链回答 question 的结果:")
- print(result["result"])
- if "source_documents" in result:
- print("\n找到的文档片段:")
- for doc in result["source_documents"]:
- print(doc)
- result_2 = llm(question)
- print("大模型回答 question 的结果:")
- print(result_2)
|