cnhkmcp 2.1.3__py3-none-any.whl → 2.1.4__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (192) hide show
  1. cnhkmcp/__init__.py +126 -0
  2. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/README.md +38 -0
  3. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/ace.log +0 -0
  4. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/config.json +6 -0
  5. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/get_knowledgeBase_tool/ace_lib.py +1514 -0
  6. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/get_knowledgeBase_tool/fetch_all_datasets.py +157 -0
  7. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/get_knowledgeBase_tool/fetch_all_documentation.py +132 -0
  8. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/get_knowledgeBase_tool/fetch_all_operators.py +99 -0
  9. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/get_knowledgeBase_tool/helpful_functions.py +180 -0
  10. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/icon.ico +0 -0
  11. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/icon.png +0 -0
  12. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/001_10_Steps_to_Start_on_BRAIN_documentation.json +14 -0
  13. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/001_Intermediate_Pack_-_Improve_your_Alpha_2_2_documentation.json +174 -0
  14. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/001_Intermediate_Pack_-_Understand_Results_1_2_documentation.json +167 -0
  15. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/001_Introduction_to_Alphas_documentation.json +145 -0
  16. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/001_Introduction_to_BRAIN_Expression_Language_documentation.json +107 -0
  17. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/001_WorldQuant_Challenge_documentation.json +56 -0
  18. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/001__Read_this_First_-_Starter_Pack_documentation.json +404 -0
  19. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/002_How_to_choose_the_Simulation_Settings_documentation.json +268 -0
  20. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/002_Simulate_your_first_Alpha_documentation.json +88 -0
  21. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/002__Alpha_Examples_for_Beginners_documentation.json +254 -0
  22. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/002__Alpha_Examples_for_Bronze_Users_documentation.json +114 -0
  23. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/002__Alpha_Examples_for_Silver_Users_documentation.json +79 -0
  24. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/002__How_BRAIN_works_documentation.json +184 -0
  25. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/003_Clear_these_tests_before_submitting_an_Alpha_documentation.json +388 -0
  26. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/003_Parameters_in_the_Simulation_results_documentation.json +243 -0
  27. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/004_Group_Data_Fields_documentation.json +69 -0
  28. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/004_How_to_use_the_Data_Explorer_documentation.json +142 -0
  29. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/004_Model77_dataset_documentation.json +14 -0
  30. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/004_Sentiment1_dataset_documentation.json +14 -0
  31. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/004_Understanding_Data_in_BRAIN_Key_Concepts_and_Tips_documentation.json +182 -0
  32. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/004_Vector_Data_Fields_documentation.json +30 -0
  33. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_Crowding_Risk-Neutralized_Alphas_documentation.json +64 -0
  34. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_D0_documentation.json +66 -0
  35. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_Double_Neutralization_documentation.json +53 -0
  36. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_Fast_D1_Documentation_documentation.json +304 -0
  37. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_Investability_Constrained_Metrics_documentation.json +129 -0
  38. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_Must-read_posts_How_to_improve_your_Alphas_documentation.json +14 -0
  39. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_Neutralization_documentation.json +29 -0
  40. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_RAM_Risk-Neutralized_Alphas_documentation.json +64 -0
  41. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_Risk_Neutralization_Default_setting_documentation.json +75 -0
  42. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_Risk_Neutralized_Alphas_documentation.json +171 -0
  43. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/005_Statistical_Risk-Neutralized_Alphas_documentation.json +51 -0
  44. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/006_EUR_TOP2500_Universe_documentation.json +35 -0
  45. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/006_GLB_TOPDIV3000_Universe_documentation.json +48 -0
  46. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/006_Getting_Started_China_Research_for_Consultants_Gold_documentation.json +142 -0
  47. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/006_Getting_started_on_Illiquid_Universes_Gold_documentation.json +46 -0
  48. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/006_Getting_started_with_USA_TOPSP500_universe_Gold_documentation.json +62 -0
  49. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/006_Global_Alphas_Gold_documentation.json +66 -0
  50. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/006_India_Alphas_documentation.json +35 -0
  51. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007_Consultant_Dos_and_Don_ts_documentation.json +35 -0
  52. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007_Consultant_Features_documentation.json +239 -0
  53. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007_Consultant_Simulation_Features_documentation.json +149 -0
  54. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007_Consultant_Submission_Tests_documentation.json +363 -0
  55. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007_Finding_Consultant_Alphas_documentation.json +333 -0
  56. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007_Power_Pool_Alphas_documentation.json +14 -0
  57. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007_Research_Advisory_Program_documentation.json +35 -0
  58. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007_Starting_Guide_for_Research_Consultants_documentation.json +14 -0
  59. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007_Visualization_Tool_documentation.json +99 -0
  60. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007_Your_Advisor_-_Kunqi_Jiang_documentation.json +53 -0
  61. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007__Brain_Genius_documentation.json +288 -0
  62. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/007__Single_Dataset_Alphas_documentation.json +41 -0
  63. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/008_Advisory_Theme_Calendar_documentation.json +14 -0
  64. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/008_Multiplier_Rules_documentation.json +14 -0
  65. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/008_Overview_of_Themes_documentation.json +14 -0
  66. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/008_Theme_Calendar_documentation.json +14 -0
  67. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/009_Combo_Expression_documentation.json +272 -0
  68. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/009_Global_SuperAlphas_documentation.json +14 -0
  69. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/009_Helpful_Tips_documentation.json +58 -0
  70. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/009_Selection_Expression_documentation.json +1546 -0
  71. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/009_SuperAlpha_Operators_documentation.json +890 -0
  72. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/009_SuperAlpha_Results_documentation.json +83 -0
  73. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/009_What_is_a_SuperAlpha_documentation.json +261 -0
  74. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/010_BRAIN_API_documentation.json +515 -0
  75. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/010_Documentation_for_ACE_API_Library_Gold_documentation.json +27 -0
  76. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/010__Understanding_simulation_limits_documentation.json +210 -0
  77. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/arithmetic_operators.json +209 -0
  78. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/cross_sectional_operators.json +98 -0
  79. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/group_operators.json +121 -0
  80. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/logical_operators.json +145 -0
  81. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/reduce_operators.json +156 -0
  82. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/special_operators.json +35 -0
  83. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/test.txt +1 -0
  84. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/time_series_operators.json +386 -0
  85. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/transformational_operators.json +61 -0
  86. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/knowledge/vector_operators.json +38 -0
  87. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/main.py +576 -0
  88. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/process_knowledge_base.py +281 -0
  89. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/rag_engine.py +408 -0
  90. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/requirements.txt +7 -0
  91. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/run.bat +3 -0
  92. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/vector_db/_manifest.json +302 -0
  93. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/vector_db/_meta.json +1 -0
  94. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242/vector_db/chroma.sqlite3 +0 -0
  95. cnhkmcp/untracked/AI/321/206/320/261/320/234/321/211/320/255/320/262/321/206/320/237/320/242/321/204/342/225/227/342/225/242//321/211/320/266/320/246/321/206/320/274/320/261/321/210/342/224/220/320/240/321/210/320/261/320/234/321/206/320/231/320/243/321/205/342/225/235/320/220/321/206/320/230/320/241.py +265 -0
  96. cnhkmcp/untracked/APP/.gitignore +32 -0
  97. cnhkmcp/untracked/APP/MODULAR_STRUCTURE.md +112 -0
  98. cnhkmcp/untracked/APP/README.md +309 -0
  99. cnhkmcp/untracked/APP/Tranformer/Transformer.py +4989 -0
  100. cnhkmcp/untracked/APP/Tranformer/ace.log +0 -0
  101. cnhkmcp/untracked/APP/Tranformer/ace_lib.py +1514 -0
  102. cnhkmcp/untracked/APP/Tranformer/helpful_functions.py +180 -0
  103. cnhkmcp/untracked/APP/Tranformer/output/Alpha_candidates.json +7187 -0
  104. cnhkmcp/untracked/APP/Tranformer/output/Alpha_candidates_/321/207/320/264/342/225/221/321/204/342/225/233/320/233.json +654 -0
  105. cnhkmcp/untracked/APP/Tranformer/output/Alpha_generated_expressions_error.json +1 -0
  106. cnhkmcp/untracked/APP/Tranformer/output/Alpha_generated_expressions_success.json +47312 -0
  107. cnhkmcp/untracked/APP/Tranformer/output/Alpha_generated_expressions_/321/207/320/264/342/225/221/321/204/342/225/233/320/233/321/205/320/237/320/277/321/207/320/253/342/224/244/321/206/320/236/320/265/321/210/342/225/234/342/225/234/321/205/320/225/320/265Machine_lib.json +22 -0
  108. cnhkmcp/untracked/APP/Tranformer/parsetab.py +60 -0
  109. cnhkmcp/untracked/APP/Tranformer/template_summary.txt +3182 -0
  110. cnhkmcp/untracked/APP/Tranformer/transformer_config.json +7 -0
  111. cnhkmcp/untracked/APP/Tranformer/validator.py +889 -0
  112. cnhkmcp/untracked/APP/ace.log +69 -0
  113. cnhkmcp/untracked/APP/ace_lib.py +1514 -0
  114. cnhkmcp/untracked/APP/blueprints/__init__.py +6 -0
  115. cnhkmcp/untracked/APP/blueprints/feature_engineering.py +347 -0
  116. cnhkmcp/untracked/APP/blueprints/idea_house.py +221 -0
  117. cnhkmcp/untracked/APP/blueprints/inspiration_house.py +432 -0
  118. cnhkmcp/untracked/APP/blueprints/paper_analysis.py +570 -0
  119. cnhkmcp/untracked/APP/custom_templates/templates.json +1257 -0
  120. cnhkmcp/untracked/APP/give_me_idea/BRAIN_Alpha_Template_Expert_SystemPrompt.md +400 -0
  121. cnhkmcp/untracked/APP/give_me_idea/ace_lib.py +1514 -0
  122. cnhkmcp/untracked/APP/give_me_idea/alpha_data_specific_template_master.py +252 -0
  123. cnhkmcp/untracked/APP/give_me_idea/fetch_all_datasets.py +157 -0
  124. cnhkmcp/untracked/APP/give_me_idea/fetch_all_operators.py +99 -0
  125. cnhkmcp/untracked/APP/give_me_idea/helpful_functions.py +180 -0
  126. cnhkmcp/untracked/APP/give_me_idea/what_is_Alpha_template.md +11 -0
  127. cnhkmcp/untracked/APP/helpful_functions.py +180 -0
  128. cnhkmcp/untracked/APP/hkSimulator/ace_lib.py +1501 -0
  129. cnhkmcp/untracked/APP/hkSimulator/autosimulator.py +447 -0
  130. cnhkmcp/untracked/APP/hkSimulator/helpful_functions.py +180 -0
  131. cnhkmcp/untracked/APP/mirror_config.txt +20 -0
  132. cnhkmcp/untracked/APP/operaters.csv +129 -0
  133. cnhkmcp/untracked/APP/requirements.txt +53 -0
  134. cnhkmcp/untracked/APP/run_app.bat +28 -0
  135. cnhkmcp/untracked/APP/run_app.sh +34 -0
  136. cnhkmcp/untracked/APP/setup_tsinghua.bat +39 -0
  137. cnhkmcp/untracked/APP/setup_tsinghua.sh +43 -0
  138. cnhkmcp/untracked/APP/simulator/alpha_submitter.py +404 -0
  139. cnhkmcp/untracked/APP/simulator/simulator_wqb.py +618 -0
  140. cnhkmcp/untracked/APP/simulator/wqb20260107015647.log +57 -0
  141. cnhkmcp/untracked/APP/ssrn-3332513.pdf +109188 -19
  142. cnhkmcp/untracked/APP/static/brain.js +589 -0
  143. cnhkmcp/untracked/APP/static/decoder.js +1540 -0
  144. cnhkmcp/untracked/APP/static/feature_engineering.js +1729 -0
  145. cnhkmcp/untracked/APP/static/idea_house.js +937 -0
  146. cnhkmcp/untracked/APP/static/inspiration.js +465 -0
  147. cnhkmcp/untracked/APP/static/inspiration_house.js +868 -0
  148. cnhkmcp/untracked/APP/static/paper_analysis.js +390 -0
  149. cnhkmcp/untracked/APP/static/script.js +3082 -0
  150. cnhkmcp/untracked/APP/static/simulator.js +597 -0
  151. cnhkmcp/untracked/APP/static/styles.css +3127 -0
  152. cnhkmcp/untracked/APP/static/usage_widget.js +508 -0
  153. cnhkmcp/untracked/APP/templates/alpha_inspector.html +511 -0
  154. cnhkmcp/untracked/APP/templates/feature_engineering.html +960 -0
  155. cnhkmcp/untracked/APP/templates/idea_house.html +564 -0
  156. cnhkmcp/untracked/APP/templates/index.html +932 -0
  157. cnhkmcp/untracked/APP/templates/inspiration_house.html +861 -0
  158. cnhkmcp/untracked/APP/templates/paper_analysis.html +91 -0
  159. cnhkmcp/untracked/APP/templates/simulator.html +343 -0
  160. cnhkmcp/untracked/APP/templates/transformer_web.html +580 -0
  161. cnhkmcp/untracked/APP/usage.md +351 -0
  162. cnhkmcp/untracked/APP//321/207/342/225/235/320/250/321/205/320/230/320/226/321/204/342/225/225/320/220/321/211/320/221/320/243/321/206/320/261/320/265/ace_lib.py +1514 -0
  163. cnhkmcp/untracked/APP//321/207/342/225/235/320/250/321/205/320/230/320/226/321/204/342/225/225/320/220/321/211/320/221/320/243/321/206/320/261/320/265/brain_alpha_inspector.py +712 -0
  164. cnhkmcp/untracked/APP//321/207/342/225/235/320/250/321/205/320/230/320/226/321/204/342/225/225/320/220/321/211/320/221/320/243/321/206/320/261/320/265/helpful_functions.py +180 -0
  165. cnhkmcp/untracked/APP//321/210/342/224/220/320/240/321/210/320/261/320/234/321/206/320/231/320/243/321/205/342/225/235/320/220/321/206/320/230/320/241.py +2460 -0
  166. cnhkmcp/untracked/__init__.py +0 -0
  167. cnhkmcp/untracked/arXiv_API_Tool_Manual.md +490 -0
  168. cnhkmcp/untracked/arxiv_api.py +229 -0
  169. cnhkmcp/untracked/forum_functions.py +998 -0
  170. cnhkmcp/untracked/mcp/321/206/320/246/320/227/321/204/342/225/227/342/225/242/321/210/320/276/342/225/221/321/205/320/255/320/253/321/207/320/231/320/2302_/321/205/320/266/320/222/321/206/320/256/320/254/321/205/320/236/320/257/321/207/320/231/320/230/321/205/320/240/320/277/321/205/320/232/320/270/321/204/342/225/225/320/235/321/204/342/225/221/320/226/321/206/342/225/241/320/237/321/210/320/267/320/230/321/205/320/251/320/270/321/205/342/226/221/342/226/222/321/210/320/277/320/245/321/210/342/224/220/320/251/321/204/342/225/225/320/272/forum_functions.py +407 -0
  171. cnhkmcp/untracked/mcp/321/206/320/246/320/227/321/204/342/225/227/342/225/242/321/210/320/276/342/225/221/321/205/320/255/320/253/321/207/320/231/320/2302_/321/205/320/266/320/222/321/206/320/256/320/254/321/205/320/236/320/257/321/207/320/231/320/230/321/205/320/240/320/277/321/205/320/232/320/270/321/204/342/225/225/320/235/321/204/342/225/221/320/226/321/206/342/225/241/320/237/321/210/320/267/320/230/321/205/320/251/320/270/321/205/342/226/221/342/226/222/321/210/320/277/320/245/321/210/342/224/220/320/251/321/204/342/225/225/320/272/platform_functions.py +2601 -0
  172. cnhkmcp/untracked/mcp/321/206/320/246/320/227/321/204/342/225/227/342/225/242/321/210/320/276/342/225/221/321/205/320/255/320/253/321/207/320/231/320/2302_/321/205/320/266/320/222/321/206/320/256/320/254/321/205/320/236/320/257/321/207/320/231/320/230/321/205/320/240/320/277/321/205/320/232/320/270/321/204/342/225/225/320/235/321/204/342/225/221/320/226/321/206/342/225/241/320/237/321/210/320/267/320/230/321/205/320/251/320/270/321/205/342/226/221/342/226/222/321/210/320/277/320/245/321/210/342/224/220/320/251/321/204/342/225/225/320/272/user_config.json +31 -0
  173. cnhkmcp/untracked/mcp/321/206/320/246/320/227/321/204/342/225/227/342/225/242/321/210/320/276/342/225/221/321/205/320/255/320/253/321/207/320/231/320/2302_/321/205/320/266/320/222/321/206/320/256/320/254/321/205/320/236/320/257/321/207/320/231/320/230/321/205/320/240/320/277/321/205/320/232/320/270/321/204/342/225/225/320/235/321/204/342/225/221/320/226/321/206/342/225/241/320/237/321/210/320/267/320/230/321/205/320/251/320/270/321/205/342/226/221/342/226/222/321/210/320/277/320/245/321/210/342/224/220/320/251/321/204/342/225/225/320/272//321/210/320/276/320/271AI/321/210/320/277/342/225/227/321/210/342/224/220/320/251/321/204/342/225/225/320/272/321/206/320/246/320/227/321/206/320/261/320/263/321/206/320/255/320/265/321/205/320/275/320/266/321/204/342/225/235/320/252/321/204/342/225/225/320/233/321/210/342/225/234/342/225/234/321/206/342/225/241/320/237/321/210/320/267/320/230/321/205/320/251/320/270.md +101 -0
  174. cnhkmcp/untracked/mcp/321/206/320/246/320/227/321/204/342/225/227/342/225/242/321/210/320/276/342/225/221/321/205/320/255/320/253/321/207/320/231/320/2302_/321/205/320/266/320/222/321/206/320/256/320/254/321/205/320/236/320/257/321/207/320/231/320/230/321/205/320/240/320/277/321/205/320/232/320/270/321/204/342/225/225/320/235/321/204/342/225/221/320/226/321/206/342/225/241/320/237/321/210/320/267/320/230/321/205/320/251/320/270/321/205/342/226/221/342/226/222/321/210/320/277/320/245/321/210/342/224/220/320/251/321/204/342/225/225/320/272//321/211/320/225/320/235/321/207/342/225/234/320/276/321/205/320/231/320/235/321/210/342/224/220/320/240/321/210/320/261/320/234/321/206/320/230/320/241_/321/205/320/276/320/231/321/210/320/263/320/225/321/205/342/224/220/320/225/321/210/320/266/320/221/321/204/342/225/233/320/255/321/210/342/225/241/320/246/321/205/320/234/320/225.py +190 -0
  175. cnhkmcp/untracked/platform_functions.py +2886 -0
  176. cnhkmcp/untracked/sample_mcp_config.json +11 -0
  177. cnhkmcp/untracked/user_config.json +31 -0
  178. cnhkmcp/untracked//321/207/320/264/342/225/221/321/204/342/225/233/320/233/321/205/320/237/320/222/321/210/320/220/320/223/321/206/320/246/320/227/321/206/320/261/320/263_BRAIN_Alpha_Test_Requirements_and_Tips.md +202 -0
  179. cnhkmcp/untracked//321/207/320/264/342/225/221/321/204/342/225/233/320/233/321/205/342/225/226/320/265/321/204/342/225/234/320/254/321/206/342/225/241/320/221_Alpha_explaination_workflow.md +56 -0
  180. cnhkmcp/untracked//321/207/320/264/342/225/221/321/204/342/225/233/320/233/321/205/342/225/226/320/265/321/204/342/225/234/320/254/321/206/342/225/241/320/221_BRAIN_6_Tips_Datafield_Exploration_Guide.md +194 -0
  181. cnhkmcp/untracked//321/207/320/264/342/225/221/321/204/342/225/233/320/233/321/205/342/225/226/320/265/321/204/342/225/234/320/254/321/206/342/225/241/320/221_BRAIN_Alpha_Improvement_Workflow.md +101 -0
  182. cnhkmcp/untracked//321/207/320/264/342/225/221/321/204/342/225/233/320/233/321/205/342/225/226/320/265/321/204/342/225/234/320/254/321/206/342/225/241/320/221_Dataset_Exploration_Expert_Manual.md +436 -0
  183. cnhkmcp/untracked//321/207/320/264/342/225/221/321/204/342/225/233/320/233/321/205/342/225/226/320/265/321/204/342/225/234/320/254/321/206/342/225/241/320/221_daily_report_workflow.md +128 -0
  184. cnhkmcp/untracked//321/211/320/225/320/235/321/207/342/225/234/320/276/321/205/320/231/320/235/321/210/342/224/220/320/240/321/210/320/261/320/234/321/206/320/230/320/241_/321/205/320/276/320/231/321/210/320/263/320/225/321/205/342/224/220/320/225/321/210/320/266/320/221/321/204/342/225/233/320/255/321/210/342/225/241/320/246/321/205/320/234/320/225.py +190 -0
  185. {cnhkmcp-2.1.3.dist-info → cnhkmcp-2.1.4.dist-info}/METADATA +1 -1
  186. cnhkmcp-2.1.4.dist-info/RECORD +190 -0
  187. cnhkmcp-2.1.4.dist-info/top_level.txt +1 -0
  188. cnhkmcp-2.1.3.dist-info/RECORD +0 -6
  189. cnhkmcp-2.1.3.dist-info/top_level.txt +0 -1
  190. {cnhkmcp-2.1.3.dist-info → cnhkmcp-2.1.4.dist-info}/WHEEL +0 -0
  191. {cnhkmcp-2.1.3.dist-info → cnhkmcp-2.1.4.dist-info}/entry_points.txt +0 -0
  192. {cnhkmcp-2.1.3.dist-info → cnhkmcp-2.1.4.dist-info}/licenses/LICENSE +0 -0
@@ -0,0 +1,432 @@
1
+ from flask import Blueprint, render_template, request, jsonify
2
+ import requests
3
+ import json
4
+ import logging
5
+ import threading
6
+ from concurrent.futures import ThreadPoolExecutor, as_completed
7
+
8
+ inspiration_house_bp = Blueprint('inspiration_house', __name__)
9
+
10
+ # Configure logging
11
+ logging.basicConfig(level=logging.INFO)
12
+ logger = logging.getLogger(__name__)
13
+
14
+ @inspiration_house_bp.route('/')
15
+ def inspiration_house():
16
+ """Main inspiration house page"""
17
+ return render_template('inspiration_house.html')
18
+
19
+ @inspiration_house_bp.route('/api/test-deepseek', methods=['POST'])
20
+ def test_deepseek_api():
21
+ """Test API connection for both Deepseek and Kimi"""
22
+ try:
23
+ api_key = request.headers.get('X-API-Key')
24
+ if not api_key:
25
+ return jsonify({'success': False, 'error': 'API key is required'}), 400
26
+
27
+ data = request.get_json()
28
+ provider = data.get('provider', 'deepseek')
29
+ model_name = data.get('model_name', 'deepseek-chat')
30
+
31
+ # Test API with a simple request
32
+ headers = {
33
+ 'Authorization': f'Bearer {api_key}',
34
+ 'Content-Type': 'application/json'
35
+ }
36
+
37
+ test_data = {
38
+ 'model': model_name,
39
+ 'messages': [
40
+ {'role': 'user', 'content': 'Hello, this is a test message.'}
41
+ ],
42
+ 'max_tokens': 10
43
+ }
44
+
45
+ # Choose API endpoint based on provider
46
+ if provider == 'kimi':
47
+ # Use the correct Kimi API endpoint that was tested and confirmed working
48
+ api_url = 'https://api.moonshot.cn/v1/chat/completions'
49
+
50
+ kimi_data = {
51
+ 'model': model_name,
52
+ 'messages': [
53
+ {'role': 'user', 'content': 'Hello, this is a test message.'}
54
+ ],
55
+ 'max_tokens': 10,
56
+ 'stream': False
57
+ }
58
+
59
+ logger.info(f"Testing Kimi API with correct endpoint: {api_url}")
60
+ response = requests.post(api_url, headers=headers, json=kimi_data, timeout=10)
61
+ logger.info(f"Kimi response status: {response.status_code}")
62
+
63
+ else:
64
+ # Default to Deepseek
65
+ api_url = 'https://api.deepseek.com/chat/completions'
66
+ response = requests.post(api_url, headers=headers, json=test_data, timeout=10)
67
+
68
+ if response.status_code == 200:
69
+ return jsonify({'success': True, 'message': f'{provider.capitalize()} API connection successful'})
70
+ else:
71
+ error_detail = response.text
72
+ return jsonify({'success': False, 'error': f'API returned status {response.status_code}: {error_detail}'}), 400
73
+
74
+ except requests.exceptions.RequestException as e:
75
+ logger.error(f"API test error: {str(e)}")
76
+ return jsonify({'success': False, 'error': f'Network error: {str(e)}'}), 500
77
+ except Exception as e:
78
+ logger.error(f"Unexpected error in API test: {str(e)}")
79
+ return jsonify({'success': False, 'error': f'Unexpected error: {str(e)}'}), 500
80
+
81
+ @inspiration_house_bp.route('/api/evaluate-operator', methods=['POST'])
82
+ def evaluate_operator():
83
+ """Evaluate a single operator against the research target"""
84
+ try:
85
+ api_key = request.headers.get('X-API-Key')
86
+ if not api_key:
87
+ return jsonify({'success': False, 'error': 'API key is required'}), 400
88
+
89
+ data = request.get_json()
90
+ operator = data.get('operator', {})
91
+ research_target = data.get('research_target', '')
92
+ current_expression = data.get('current_expression', '')
93
+ expression_context = data.get('expression_context', '')
94
+ provider = data.get('provider', 'deepseek')
95
+ model_name = data.get('model_name', 'deepseek-chat')
96
+
97
+ if not operator or not research_target:
98
+ return jsonify({'success': False, 'error': 'Operator and research target are required'}), 400
99
+
100
+ # Build the evaluation prompt
101
+ system_prompt = get_evaluation_system_prompt()
102
+ user_prompt = build_evaluation_prompt(operator, research_target, current_expression, expression_context)
103
+
104
+ # Make API call based on provider
105
+ headers = {
106
+ 'Authorization': f'Bearer {api_key}',
107
+ 'Content-Type': 'application/json'
108
+ }
109
+
110
+ if provider == 'kimi':
111
+ # Use the correct Kimi API endpoint that was tested and confirmed working
112
+ api_url = 'https://api.moonshot.cn/v1/chat/completions'
113
+
114
+ api_data = {
115
+ 'model': model_name,
116
+ 'messages': [
117
+ {'role': 'system', 'content': system_prompt},
118
+ {'role': 'user', 'content': user_prompt}
119
+ ],
120
+ 'max_tokens': 4096,
121
+ 'temperature': 0.3
122
+ }
123
+
124
+ response = requests.post(api_url, headers=headers, json=api_data, timeout=30)
125
+
126
+ else:
127
+ # Deepseek API structure
128
+ api_url = 'https://api.deepseek.com/chat/completions'
129
+ api_data = {
130
+ 'model': model_name,
131
+ 'messages': [
132
+ {'role': 'system', 'content': system_prompt},
133
+ {'role': 'user', 'content': user_prompt}
134
+ ],
135
+ 'max_tokens': 4096,
136
+ 'temperature': 0.3
137
+ }
138
+ response = requests.post(api_url, headers=headers, json=api_data, timeout=30)
139
+
140
+ if response.status_code == 200:
141
+ response_data = response.json()
142
+
143
+ # Both Kimi and Deepseek use the same OpenAI-compatible response structure
144
+ ai_response = response_data['choices'][0]['message']['content']
145
+
146
+ # Parse the AI response to extract score and reason
147
+ score, reason = parse_evaluation_response(ai_response)
148
+
149
+ return jsonify({
150
+ 'success': True,
151
+ 'score': score,
152
+ 'reason': reason,
153
+ 'operator': operator.get('name', 'Unknown'),
154
+ 'research_target': research_target
155
+ })
156
+ else:
157
+ error_detail = response.text
158
+ logger.error(f"{provider.capitalize()} API error: {response.status_code} - {error_detail}")
159
+ return jsonify({'success': False, 'error': f'API returned status {response.status_code}: {error_detail}'}), 400
160
+
161
+ except requests.exceptions.RequestException as e:
162
+ logger.error(f"API request error: {str(e)}")
163
+ return jsonify({'success': False, 'error': f'Network error: {str(e)}'}), 500
164
+ except Exception as e:
165
+ logger.error(f"Unexpected error in operator evaluation: {str(e)}")
166
+ return jsonify({'success': False, 'error': f'Unexpected error: {str(e)}'}), 500
167
+
168
+ def get_evaluation_system_prompt():
169
+ """Get the system prompt for operator evaluation"""
170
+ return """You are an expert quantitative researcher and data scientist specializing in financial data analysis and algorithmic trading. Your task is to evaluate how well a specific BRAIN operator could be ADDED to the current expression to help achieve a given quant research target.
171
+
172
+ IMPORTANT: You are NOT suggesting replacements for the current expression. You are evaluating how each operator could be COMBINED with or applied AFTER the current expression to move closer to the target.
173
+
174
+ Your evaluation should be based on:
175
+ 1. How the operator could be applied AFTER the current expression (e.g., ts_rank(current_expression))
176
+ 2. The operator's mathematical and statistical properties when combined with the current expression
177
+ 3. How this combination would better achieve the stated research target
178
+ 4. The synergistic effects of applying this operator to the current expression
179
+
180
+ You must provide:
181
+ 1. A score from 0-10 (where 10 is perfect synergistic addition to achieve the target)
182
+ 2. A clear, concise reason explaining how this operator could be added to improve the current expression
183
+
184
+ Scoring Guidelines:
185
+ - 8-10: Excellent addition - operator would significantly enhance the current expression for the target
186
+ - 6-7: Good addition - operator would meaningfully improve the current expression
187
+ - 4-5: Moderate addition - operator could provide some benefit when combined
188
+ - 2-3: Weak addition - operator would add little value to the current expression
189
+ - 0-1: No value - operator would not help or might even hurt the current expression
190
+
191
+ Response Format:
192
+ Score: [number from 0-10]
193
+ Reason: [provide a detailed explanation of how this operator could be added to the current expression to better achieve the target. Include specific examples of how the combination would work and why it would be effective.]
194
+
195
+ Focus on combination effects and how the operator would enhance the current expression rather than replace it. Be thorough in your explanation."""
196
+
197
+ def build_evaluation_prompt(operator, research_target, current_expression, expression_context):
198
+ """Build the user prompt for operator evaluation"""
199
+
200
+ operator_info = f"""
201
+ Operator Name: {operator.get('name', 'Unknown')}
202
+ Operator Category: {operator.get('category', 'Unknown')}
203
+ Operator Description: {operator.get('description', 'No description available')}
204
+ """
205
+
206
+ context_info = f"""
207
+ Research Target: {research_target}
208
+ Current Expression: {current_expression if current_expression else 'None provided'}
209
+ Expression Context: {expression_context if expression_context else 'None provided'}
210
+ """
211
+
212
+ return f"""Please evaluate how well this BRAIN operator could be ADDED to the current expression to help achieve the research target.
213
+
214
+ {operator_info}
215
+
216
+ {context_info}
217
+
218
+ IMPORTANT: Consider how this operator could be applied AFTER the current expression (e.g., {operator.get('name', 'operator')}(current_expression)) to enhance the strategy. Do NOT suggest replacing the current expression.
219
+
220
+ Think about:
221
+ - How would applying this operator to the current expression improve the strategy?
222
+ - What synergistic effects would this combination create?
223
+ - How would this addition move us closer to the research target?
224
+
225
+ Response Format:
226
+ Score: [number from 0-10]
227
+ Reason: [provide a detailed explanation of how this operator could be added to the current expression to better achieve the target. Include specific examples of how the combination would work and why it would be effective.]"""
228
+
229
+ def parse_evaluation_response(response):
230
+ """Parse the AI response to extract score and reason"""
231
+ try:
232
+ lines = response.strip().split('\n')
233
+ score = 0
234
+ reason = "No reason provided"
235
+ in_reason_section = False
236
+ reason_lines = []
237
+
238
+ for line in lines:
239
+ line = line.strip()
240
+ if line.lower().startswith('score:'):
241
+ try:
242
+ score_text = line.split(':', 1)[1].strip()
243
+ score = int(score_text)
244
+ # Ensure score is within valid range
245
+ score = max(0, min(10, score))
246
+ except (ValueError, IndexError):
247
+ score = 0
248
+ elif line.lower().startswith('reason:'):
249
+ in_reason_section = True
250
+ reason_text = line.split(':', 1)[1].strip()
251
+ if reason_text:
252
+ reason_lines.append(reason_text)
253
+ elif in_reason_section and line:
254
+ # Continue collecting reason lines until we hit another section or empty line
255
+ if line.lower().startswith(('score:', 'operator:', 'category:')):
256
+ break
257
+ reason_lines.append(line)
258
+
259
+ if reason_lines:
260
+ reason = ' '.join(reason_lines)
261
+
262
+ return score, reason
263
+ except Exception as e:
264
+ logger.error(f"Error parsing evaluation response: {str(e)}")
265
+ return 0, f"Error parsing response: {str(e)}"
266
+
267
+ @inspiration_house_bp.route('/api/batch-evaluate', methods=['POST'])
268
+ def batch_evaluate_operators():
269
+ """Evaluate multiple operators in parallel"""
270
+ try:
271
+ api_key = request.headers.get('X-API-Key')
272
+ if not api_key:
273
+ return jsonify({'success': False, 'error': 'API key is required'}), 400
274
+
275
+ data = request.get_json()
276
+ operators = data.get('operators', [])
277
+ research_target = data.get('research_target', '')
278
+ current_expression = data.get('current_expression', '')
279
+ expression_context = data.get('expression_context', '')
280
+ batch_size = data.get('batch_size', 100) # Get batch size from request
281
+ provider = data.get('provider', 'deepseek')
282
+ model_name = data.get('model_name', 'deepseek-chat')
283
+
284
+ if not operators or not research_target:
285
+ return jsonify({'success': False, 'error': 'Operators and research target are required'}), 400
286
+
287
+ # Use ThreadPoolExecutor for parallel processing
288
+ # Use full parallelization for all providers
289
+ max_workers = len(operators)
290
+ logger.info(f"Using {max_workers} workers for API evaluation")
291
+
292
+ results = []
293
+ with ThreadPoolExecutor(max_workers=max_workers) as executor:
294
+ # Submit all evaluation tasks
295
+ future_to_operator = {
296
+ executor.submit(
297
+ evaluate_single_operator_async,
298
+ api_key,
299
+ operator,
300
+ research_target,
301
+ current_expression,
302
+ expression_context,
303
+ provider,
304
+ model_name
305
+ ): operator for operator in operators
306
+ }
307
+
308
+ # Collect results as they complete
309
+ for future in as_completed(future_to_operator):
310
+ operator = future_to_operator[future]
311
+ try:
312
+ result = future.result()
313
+ results.append(result)
314
+ except Exception as e:
315
+ logger.error(f"Error evaluating operator {operator.get('name', 'Unknown')}: {str(e)}")
316
+ results.append({
317
+ 'operator': operator.get('name', 'Unknown'),
318
+ 'category': operator.get('category', 'Unknown'),
319
+ 'score': 0,
320
+ 'reason': f'Error: {str(e)}',
321
+ 'timestamp': None
322
+ })
323
+
324
+ return jsonify({
325
+ 'success': True,
326
+ 'results': results,
327
+ 'total_evaluated': len(results),
328
+ 'workers_used': max_workers,
329
+ 'total_operators': len(operators)
330
+ })
331
+
332
+ except Exception as e:
333
+ logger.error(f"Unexpected error in batch evaluation: {str(e)}")
334
+ return jsonify({'success': False, 'error': f'Unexpected error: {str(e)}'}), 500
335
+
336
+ def evaluate_single_operator_async(api_key, operator, research_target, current_expression, expression_context, provider='deepseek', model_name='deepseek-chat'):
337
+ """Evaluate a single operator asynchronously"""
338
+ try:
339
+ # Build the evaluation prompt
340
+ system_prompt = get_evaluation_system_prompt()
341
+ user_prompt = build_evaluation_prompt(operator, research_target, current_expression, expression_context)
342
+
343
+ # Make API call based on provider
344
+ headers = {
345
+ 'Authorization': f'Bearer {api_key}',
346
+ 'Content-Type': 'application/json'
347
+ }
348
+
349
+ if provider == 'kimi':
350
+ # Use the correct Kimi API endpoint that was tested and confirmed working
351
+ api_url = 'https://api.moonshot.cn/v1/chat/completions'
352
+
353
+ api_data = {
354
+ 'model': model_name,
355
+ 'messages': [
356
+ {'role': 'system', 'content': system_prompt},
357
+ {'role': 'user', 'content': user_prompt}
358
+ ],
359
+ 'max_tokens': 4096,
360
+ 'temperature': 0.3
361
+ }
362
+
363
+ response = requests.post(api_url, headers=headers, json=api_data, timeout=30)
364
+
365
+ else:
366
+ # Deepseek API structure
367
+ api_url = 'https://api.deepseek.com/chat/completions'
368
+ api_data = {
369
+ 'model': model_name,
370
+ 'messages': [
371
+ {'role': 'system', 'content': system_prompt},
372
+ {'role': 'user', 'content': user_prompt}
373
+ ],
374
+ 'max_tokens': 4096,
375
+ 'temperature': 0.3
376
+ }
377
+ response = requests.post(api_url, headers=headers, json=api_data, timeout=30)
378
+
379
+ if response.status_code == 200:
380
+ response_data = response.json()
381
+
382
+ # Both Kimi and Deepseek use the same OpenAI-compatible response structure
383
+ ai_response = response_data['choices'][0]['message']['content']
384
+
385
+ # Parse the AI response to extract score and reason
386
+ score, reason = parse_evaluation_response(ai_response)
387
+
388
+ return {
389
+ 'operator': operator.get('name', 'Unknown'),
390
+ 'category': operator.get('category', 'Unknown'),
391
+ 'score': score,
392
+ 'reason': reason,
393
+ 'timestamp': None
394
+ }
395
+ else:
396
+ error_detail = response.text
397
+ logger.error(f"{provider.capitalize()} API error for operator {operator.get('name', 'Unknown')}: {response.status_code} - {error_detail}")
398
+ return {
399
+ 'operator': operator.get('name', 'Unknown'),
400
+ 'category': operator.get('category', 'Unknown'),
401
+ 'score': 0,
402
+ 'reason': f'API Error: {response.status_code}',
403
+ 'timestamp': None
404
+ }
405
+
406
+ except requests.exceptions.Timeout as e:
407
+ logger.error(f"Timeout error evaluating operator {operator.get('name', 'Unknown')}: {str(e)}")
408
+ return {
409
+ 'operator': operator.get('name', 'Unknown'),
410
+ 'category': operator.get('category', 'Unknown'),
411
+ 'score': 0,
412
+ 'reason': f'API Timeout: Request took too long to complete',
413
+ 'timestamp': None
414
+ }
415
+ except requests.exceptions.RequestException as e:
416
+ logger.error(f"Request error evaluating operator {operator.get('name', 'Unknown')}: {str(e)}")
417
+ return {
418
+ 'operator': operator.get('name', 'Unknown'),
419
+ 'category': operator.get('category', 'Unknown'),
420
+ 'score': 0,
421
+ 'reason': f'Network Error: {str(e)}',
422
+ 'timestamp': None
423
+ }
424
+ except Exception as e:
425
+ logger.error(f"Error evaluating operator {operator.get('name', 'Unknown')}: {str(e)}")
426
+ return {
427
+ 'operator': operator.get('name', 'Unknown'),
428
+ 'category': operator.get('category', 'Unknown'),
429
+ 'score': 0,
430
+ 'reason': f'Error: {str(e)}',
431
+ 'timestamp': None
432
+ }