capbility.py 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. import time
  2. from agent.cdss.models.schemas import CDSSDict, CDSSInput,CDSSInt,CDSSOutput,CDSSText
  3. from agent.cdss.libs.cdss_helper2 import CDSSHelper
  4. import logging
  5. logger = logging.getLogger(__name__)
  6. class CDSSCapability:
  7. cdss_helper: CDSSHelper = None
  8. def __init__(self):
  9. self.cdss_helper = CDSSHelper()
  10. logger.debug("CDSSCapability initialized")
  11. def process(self, input: CDSSInput, embeding_search:bool = True) -> CDSSOutput:
  12. start_nodes = []
  13. chief_complaint = input.get_value("chief_complaint")
  14. logger.info(f"process input: {input}")
  15. output = CDSSOutput()
  16. if chief_complaint:
  17. start_time = time.time()
  18. for keyword in chief_complaint:
  19. results = self.cdss_helper.node_search(
  20. keyword, limit=10, node_type="症状"
  21. )
  22. for item in results:
  23. if item['score']>1.9:
  24. start_nodes.append(item['id'])
  25. end_time = time.time()
  26. print(f"node_search执行完成,耗时:{end_time - start_time:.2f}秒")
  27. logger.info(f"cdss start from {start_nodes}")
  28. result = self.cdss_helper.cdss_travel(input, start_nodes,max_hops=2)
  29. # for item in result["details"]:
  30. # name, data = item
  31. # output.departments.value[name] = data
  32. for item in result["score_diags"]:
  33. output.diagnosis.value[item[0]] = item[1]
  34. # for item in result["checks"][:5]:
  35. # item[1]['score'] = item[1]['count'] / result["total_checks"]
  36. # output.checks.value[item[0]] = item[1]
  37. # for item in result["drugs"][:5]:
  38. # item[1]['score'] = item[1]['count'] / result["total_checks"]
  39. # output.drugs.value[item[0]] = item[1]
  40. #print(f"\t药品:{item[0]} {item[1]['count'] / result["total_drugs"] * 100:.2f} %")
  41. return output