crfm-helm 0.5.4__py3-none-any.whl → 0.5.5__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.

Potentially problematic release.


This version of crfm-helm might be problematic. Click here for more details.

Files changed (580) hide show
  1. crfm_helm-0.5.5.dist-info/METADATA +413 -0
  2. crfm_helm-0.5.5.dist-info/RECORD +894 -0
  3. {crfm_helm-0.5.4.dist-info → crfm_helm-0.5.5.dist-info}/WHEEL +1 -1
  4. helm/benchmark/adaptation/adapter_spec.py +13 -1
  5. helm/benchmark/adaptation/adapters/adapter_factory.py +15 -1
  6. helm/benchmark/adaptation/adapters/binary_ranking_adapter.py +1 -1
  7. helm/benchmark/adaptation/adapters/chat_adapter.py +49 -0
  8. helm/benchmark/adaptation/adapters/ehr_instruction_adapter.py +108 -0
  9. helm/benchmark/adaptation/adapters/generation_adapter.py +1 -1
  10. helm/benchmark/adaptation/adapters/in_context_learning_adapter.py +1 -1
  11. helm/benchmark/adaptation/adapters/language_modeling_adapter.py +1 -1
  12. helm/benchmark/adaptation/adapters/multimodal/generation_multimodal_adapter.py +4 -2
  13. helm/benchmark/adaptation/adapters/multimodal/in_context_learning_multimodal_adapter.py +1 -1
  14. helm/benchmark/adaptation/adapters/multimodal/multiple_choice_joint_multimodal_adapter.py +1 -1
  15. helm/benchmark/adaptation/adapters/multimodal/test_in_context_learning_multimodal_adapter.py +4 -2
  16. helm/benchmark/adaptation/adapters/multimodal/test_multimodal_prompt.py +1 -1
  17. helm/benchmark/adaptation/adapters/multiple_choice_calibrated_adapter.py +1 -1
  18. helm/benchmark/adaptation/adapters/multiple_choice_joint_adapter.py +2 -2
  19. helm/benchmark/adaptation/adapters/multiple_choice_joint_chain_of_thought_adapter.py +87 -0
  20. helm/benchmark/adaptation/adapters/multiple_choice_separate_adapter.py +1 -1
  21. helm/benchmark/adaptation/adapters/test_generation_adapter.py +3 -3
  22. helm/benchmark/adaptation/adapters/test_language_modeling_adapter.py +2 -2
  23. helm/benchmark/adaptation/adapters/test_multiple_choice_joint_adapter.py +2 -2
  24. helm/benchmark/adaptation/common_adapter_specs.py +69 -4
  25. helm/benchmark/adaptation/prompt.py +1 -1
  26. helm/benchmark/annotation/aci_bench_annotator.py +95 -0
  27. helm/benchmark/annotation/air_bench_annotator.py +20 -5
  28. helm/benchmark/annotation/annotator.py +5 -0
  29. helm/benchmark/annotation/annotator_factory.py +3 -20
  30. helm/benchmark/annotation/autobencher_capabilities_annotator.py +107 -0
  31. helm/benchmark/annotation/autobencher_safety_annotator.py +98 -0
  32. helm/benchmark/annotation/bigcodebench_annotator.py +108 -0
  33. helm/benchmark/annotation/bird_sql_annotator.py +58 -0
  34. helm/benchmark/annotation/chw_care_plan_annotator.py +98 -0
  35. helm/benchmark/annotation/czech_bank_qa_annotator.py +78 -0
  36. helm/benchmark/annotation/dischargeme_annotator.py +107 -0
  37. helm/benchmark/annotation/ehr_sql_annotator.py +87 -0
  38. helm/benchmark/annotation/helpdesk_call_summarization_annotator.py +131 -0
  39. helm/benchmark/annotation/image2struct/image_compiler_annotator.py +6 -1
  40. helm/benchmark/annotation/live_qa_annotator.py +1 -1
  41. helm/benchmark/annotation/med_dialog_annotator.py +99 -0
  42. helm/benchmark/annotation/medalign_annotator.py +100 -0
  43. helm/benchmark/annotation/medi_qa_annotator.py +98 -0
  44. helm/benchmark/annotation/medication_qa_annotator.py +87 -63
  45. helm/benchmark/annotation/mental_health_annotator.py +98 -0
  46. helm/benchmark/annotation/mimic_rrs_annotator.py +100 -0
  47. helm/benchmark/annotation/model_as_judge.py +218 -6
  48. helm/benchmark/annotation/mtsamples_procedures_annotator.py +98 -0
  49. helm/benchmark/annotation/mtsamples_replicate_annotator.py +101 -0
  50. helm/benchmark/annotation/omni_math/gpt_evaluation_template.txt +152 -0
  51. helm/benchmark/annotation/omni_math/gpt_evaluation_zero_shot_template.txt +36 -0
  52. helm/benchmark/annotation/omni_math_annotator.py +132 -0
  53. helm/benchmark/annotation/spider_annotator.py +18 -0
  54. helm/benchmark/annotation/starr_patient_instructions_annotator.py +98 -0
  55. helm/benchmark/annotation/wildbench/eval_template.pairwise.v2.md +75 -0
  56. helm/benchmark/annotation/wildbench/eval_template.score.v2.md +66 -0
  57. helm/benchmark/annotation/wildbench_annotator.py +119 -0
  58. helm/benchmark/annotation_executor.py +35 -15
  59. helm/benchmark/augmentations/cleva_perturbation.py +9 -8
  60. helm/benchmark/augmentations/contraction_expansion_perturbation.py +2 -2
  61. helm/benchmark/augmentations/contrast_sets_perturbation.py +2 -2
  62. helm/benchmark/augmentations/dialect_perturbation.py +4 -5
  63. helm/benchmark/augmentations/extra_space_perturbation.py +2 -2
  64. helm/benchmark/augmentations/filler_words_perturbation.py +2 -2
  65. helm/benchmark/augmentations/gender_perturbation.py +2 -2
  66. helm/benchmark/augmentations/lowercase_perturbation.py +2 -2
  67. helm/benchmark/augmentations/mild_mix_perturbation.py +6 -6
  68. helm/benchmark/augmentations/misspelling_perturbation.py +2 -2
  69. helm/benchmark/augmentations/person_name_perturbation.py +4 -5
  70. helm/benchmark/augmentations/perturbation.py +1 -1
  71. helm/benchmark/augmentations/space_perturbation.py +2 -2
  72. helm/benchmark/augmentations/suffix_perturbation.py +2 -2
  73. helm/benchmark/augmentations/synonym_perturbation.py +4 -3
  74. helm/benchmark/augmentations/test_perturbation.py +16 -13
  75. helm/benchmark/augmentations/translate_perturbation.py +2 -2
  76. helm/benchmark/augmentations/typos_perturbation.py +2 -2
  77. helm/benchmark/data_preprocessor.py +2 -2
  78. helm/benchmark/huggingface_registration.py +2 -7
  79. helm/benchmark/metrics/aci_bench_metrics.py +34 -0
  80. helm/benchmark/metrics/basic_metrics.py +6 -6
  81. helm/benchmark/metrics/bbq_metrics.py +2 -2
  82. helm/benchmark/metrics/bias_metrics.py +12 -3
  83. helm/benchmark/metrics/bigcodebench_metrics.py +25 -0
  84. helm/benchmark/metrics/bird_sql_metrics.py +28 -0
  85. helm/benchmark/metrics/chw_care_plan_metrics.py +34 -0
  86. helm/benchmark/metrics/classification_metrics.py +76 -12
  87. helm/benchmark/metrics/cleva_harms_metrics.py +8 -7
  88. helm/benchmark/metrics/code_metrics.py +5 -5
  89. helm/benchmark/metrics/comet_metric.py +125 -0
  90. helm/benchmark/metrics/common_metric_specs.py +9 -2
  91. helm/benchmark/metrics/conv_fin_qa_calc_metrics.py +72 -0
  92. helm/benchmark/metrics/copyright_metrics.py +4 -4
  93. helm/benchmark/metrics/czech_bank_qa_metrics.py +29 -0
  94. helm/benchmark/metrics/decodingtrust_fairness_metrics.py +2 -2
  95. helm/benchmark/metrics/decodingtrust_privacy_metrics.py +2 -2
  96. helm/benchmark/metrics/decodingtrust_stereotype_bias_metrics.py +2 -2
  97. helm/benchmark/metrics/dischargeme_metrics.py +34 -0
  98. helm/benchmark/metrics/disinformation_metrics.py +4 -4
  99. helm/benchmark/metrics/dry_run_metrics.py +5 -5
  100. helm/benchmark/metrics/efficiency_metrics.py +3 -3
  101. helm/benchmark/metrics/ehr_sql_metrics.py +103 -0
  102. helm/benchmark/metrics/evaluate_instances_metric.py +3 -3
  103. helm/benchmark/metrics/evaluate_reference_metrics.py +144 -16
  104. helm/benchmark/metrics/gpqa_chain_of_thought_metric.py +103 -0
  105. helm/benchmark/metrics/gpt4_audio_critique_metrics.py +167 -0
  106. helm/benchmark/metrics/helpdesk_call_summarization_metrics.py +36 -0
  107. helm/benchmark/metrics/ifeval/__init__.py +0 -0
  108. helm/benchmark/metrics/ifeval/instructions.py +1574 -0
  109. helm/benchmark/metrics/ifeval/instructions_registry.py +182 -0
  110. helm/benchmark/metrics/ifeval/instructions_registry.pyi +3 -0
  111. helm/benchmark/metrics/ifeval/instructions_util.py +153 -0
  112. helm/benchmark/metrics/ifeval_metrics.py +55 -0
  113. helm/benchmark/metrics/image_generation/aesthetics_metrics.py +1 -1
  114. helm/benchmark/metrics/image_generation/detection_metrics.py +1 -1
  115. helm/benchmark/metrics/image_generation/detectors/vitdet.py +1 -1
  116. helm/benchmark/metrics/image_generation/fractal_dimension/test_fractal_dimension_util.py +1 -1
  117. helm/benchmark/metrics/image_generation/fractal_dimension_metric.py +1 -1
  118. helm/benchmark/metrics/image_generation/nsfw_metrics.py +1 -1
  119. helm/benchmark/metrics/image_generation/q16/test_q16.py +3 -1
  120. helm/benchmark/metrics/image_generation/q16_toxicity_metrics.py +1 -1
  121. helm/benchmark/metrics/image_generation/skin_tone_metrics.py +2 -2
  122. helm/benchmark/metrics/image_generation/watermark/test_watermark_detector.py +1 -1
  123. helm/benchmark/metrics/image_generation/watermark_metrics.py +1 -1
  124. helm/benchmark/metrics/instruction_following_critique_metrics.py +4 -4
  125. helm/benchmark/metrics/language_modeling_metrics.py +4 -4
  126. helm/benchmark/metrics/machine_translation_metrics.py +2 -2
  127. helm/benchmark/metrics/med_dialog_metrics.py +34 -0
  128. helm/benchmark/metrics/medalign_metrics.py +34 -0
  129. helm/benchmark/metrics/medcalc_bench_metrics.py +124 -0
  130. helm/benchmark/metrics/medec_metrics.py +101 -0
  131. helm/benchmark/metrics/medi_qa_metrics.py +34 -0
  132. helm/benchmark/metrics/medication_qa_metrics.py +15 -4
  133. helm/benchmark/metrics/mental_health_metrics.py +34 -0
  134. helm/benchmark/metrics/metric.py +3 -3
  135. helm/benchmark/metrics/mimic_rrs_metrics.py +34 -0
  136. helm/benchmark/metrics/mimiciv_billing_code_metrics.py +96 -0
  137. helm/benchmark/metrics/mtsamples_procedures_metrics.py +34 -0
  138. helm/benchmark/metrics/mtsamples_replicate_metrics.py +34 -0
  139. helm/benchmark/metrics/nltk_helper.py +32 -0
  140. helm/benchmark/metrics/numeracy_metrics.py +4 -4
  141. helm/benchmark/metrics/omni_math_metrics.py +32 -0
  142. helm/benchmark/metrics/output_processing_metric.py +60 -0
  143. helm/benchmark/metrics/output_processors.py +15 -0
  144. helm/benchmark/metrics/paraphrase_generation_metrics.py +2 -2
  145. helm/benchmark/metrics/ranking_metrics.py +3 -3
  146. helm/benchmark/metrics/reference_metric.py +3 -3
  147. helm/benchmark/metrics/{bhasa_metrics.py → seahelm_metrics.py} +3 -3
  148. helm/benchmark/metrics/seahelm_metrics_specs.py +10 -0
  149. helm/benchmark/metrics/spider_metrics.py +7 -0
  150. helm/benchmark/metrics/starr_patient_instructions_metrics.py +34 -0
  151. helm/benchmark/metrics/statistic.py +1 -1
  152. helm/benchmark/metrics/summac/model_summac.py +1 -1
  153. helm/benchmark/metrics/summarization_critique_metrics.py +4 -4
  154. helm/benchmark/metrics/summarization_metrics.py +19 -9
  155. helm/benchmark/metrics/test_bias_metrics.py +5 -1
  156. helm/benchmark/metrics/test_classification_metrics.py +140 -68
  157. helm/benchmark/metrics/test_evaluate_reference_metrics.py +15 -0
  158. helm/benchmark/metrics/test_metric.py +1 -1
  159. helm/benchmark/metrics/test_statistic.py +2 -2
  160. helm/benchmark/metrics/tokens/ai21_token_cost_estimator.py +1 -1
  161. helm/benchmark/metrics/tokens/auto_token_cost_estimator.py +6 -6
  162. helm/benchmark/metrics/tokens/cohere_token_cost_estimator.py +1 -1
  163. helm/benchmark/metrics/tokens/free_token_cost_estimator.py +1 -1
  164. helm/benchmark/metrics/tokens/gooseai_token_cost_estimator.py +1 -1
  165. helm/benchmark/metrics/tokens/openai_token_cost_estimator.py +1 -1
  166. helm/benchmark/metrics/tokens/test_ai21_token_cost_estimator.py +1 -1
  167. helm/benchmark/metrics/tokens/test_openai_token_cost_estimator.py +1 -1
  168. helm/benchmark/metrics/toxicity_metrics.py +4 -4
  169. helm/benchmark/metrics/unitxt_metrics.py +4 -1
  170. helm/benchmark/metrics/vision_language/image_metrics.py +1 -1
  171. helm/benchmark/metrics/wildbench_metrics.py +34 -0
  172. helm/benchmark/model_metadata_registry.py +16 -0
  173. helm/benchmark/presentation/summarize.py +23 -10
  174. helm/benchmark/presentation/torr_robustness_summarizer.py +178 -0
  175. helm/benchmark/reeval_run.py +203 -0
  176. helm/benchmark/reeval_runner.py +355 -0
  177. helm/benchmark/run.py +8 -17
  178. helm/benchmark/run_expander.py +78 -8
  179. helm/benchmark/run_spec_factory.py +12 -0
  180. helm/benchmark/run_specs/air_bench_run_specs.py +21 -3
  181. helm/benchmark/run_specs/audio_run_specs.py +613 -0
  182. helm/benchmark/run_specs/call_center_run_specs.py +49 -0
  183. helm/benchmark/run_specs/capabilities_run_specs.py +308 -0
  184. helm/benchmark/run_specs/classic_run_specs.py +1 -69
  185. helm/benchmark/run_specs/enem_challenge_specs.py +31 -0
  186. helm/benchmark/run_specs/enterprise_run_specs.py +260 -0
  187. helm/benchmark/run_specs/experimental_run_specs.py +112 -3
  188. helm/benchmark/run_specs/imdb_ptbr_run_specs.py +30 -0
  189. helm/benchmark/run_specs/lite_run_specs.py +2 -2
  190. helm/benchmark/run_specs/long_context_run_specs.py +89 -0
  191. helm/benchmark/run_specs/medhelm_run_specs.py +1155 -0
  192. helm/benchmark/run_specs/mmlu_clinical_afr_run_specs.py +49 -0
  193. helm/benchmark/run_specs/oab_exams_specs.py +32 -0
  194. helm/benchmark/run_specs/safety_run_specs.py +37 -0
  195. helm/benchmark/run_specs/{bhasa_run_specs.py → seahelm_run_specs.py} +44 -44
  196. helm/benchmark/run_specs/sql_run_specs.py +54 -0
  197. helm/benchmark/run_specs/tweetsentbr_run_specs.py +32 -0
  198. helm/benchmark/run_specs/unitxt_run_specs.py +14 -5
  199. helm/benchmark/run_specs/vlm_run_specs.py +75 -2
  200. helm/benchmark/run_specs/winogrande_afr_run_specs.py +47 -0
  201. helm/benchmark/scenarios/aci_bench_scenario.py +120 -0
  202. helm/benchmark/scenarios/air_bench_scenario.py +6 -1
  203. helm/benchmark/scenarios/anthropic_hh_rlhf_scenario.py +5 -3
  204. helm/benchmark/scenarios/anthropic_red_team_scenario.py +1 -1
  205. helm/benchmark/scenarios/audio_language/__init__.py +0 -0
  206. helm/benchmark/scenarios/audio_language/air_bench_chat_scenario.py +128 -0
  207. helm/benchmark/scenarios/audio_language/air_bench_foundation_scenario.py +154 -0
  208. helm/benchmark/scenarios/audio_language/ami_scenario.py +96 -0
  209. helm/benchmark/scenarios/audio_language/audio_mnist_scenario.py +62 -0
  210. helm/benchmark/scenarios/audio_language/audio_pairs_scenario.py +62 -0
  211. helm/benchmark/scenarios/audio_language/audiocaps_scenario.py +59 -0
  212. helm/benchmark/scenarios/audio_language/casual_conversations2_scenario.py +152 -0
  213. helm/benchmark/scenarios/audio_language/common_voice_15_scenario.py +99 -0
  214. helm/benchmark/scenarios/audio_language/covost2_scenario.py +163 -0
  215. helm/benchmark/scenarios/audio_language/fleurs_fairness_scenario.py +83 -0
  216. helm/benchmark/scenarios/audio_language/fleurs_scenario.py +312 -0
  217. helm/benchmark/scenarios/audio_language/iemocap_audio_scenario.py +83 -0
  218. helm/benchmark/scenarios/audio_language/librispeech_fairness_scenario.py +96 -0
  219. helm/benchmark/scenarios/audio_language/librispeech_scenario.py +80 -0
  220. helm/benchmark/scenarios/audio_language/meld_audio_scenario.py +113 -0
  221. helm/benchmark/scenarios/audio_language/multilingual_librispeech_scenario.py +80 -0
  222. helm/benchmark/scenarios/audio_language/mustard_scenario.py +142 -0
  223. helm/benchmark/scenarios/audio_language/mutox_scenario.py +254 -0
  224. helm/benchmark/scenarios/audio_language/parade_scenario.py +97 -0
  225. helm/benchmark/scenarios/audio_language/speech_robust_bench_scenario.py +124 -0
  226. helm/benchmark/scenarios/audio_language/vocal_sound_scenario.py +69 -0
  227. helm/benchmark/scenarios/audio_language/voice_jailbreak_attacks_scenario.py +87 -0
  228. helm/benchmark/scenarios/audio_language/voxceleb2_scenario.py +106 -0
  229. helm/benchmark/scenarios/autobencher_capabilities_scenario.py +68 -0
  230. helm/benchmark/scenarios/autobencher_safety_scenario.py +51 -0
  231. helm/benchmark/scenarios/babi_qa_scenario.py +1 -1
  232. helm/benchmark/scenarios/banking77_scenario.py +6 -1
  233. helm/benchmark/scenarios/bbq_scenario.py +1 -1
  234. helm/benchmark/scenarios/big_bench_scenario.py +11 -1
  235. helm/benchmark/scenarios/bigcodebench_scenario.py +58 -0
  236. helm/benchmark/scenarios/bird_sql_scenario.py +94 -0
  237. helm/benchmark/scenarios/bird_sql_scenario_helper.py +118 -0
  238. helm/benchmark/scenarios/blimp_scenario.py +1 -1
  239. helm/benchmark/scenarios/bold_scenario.py +1 -1
  240. helm/benchmark/scenarios/boolq_scenario.py +1 -1
  241. helm/benchmark/scenarios/casehold_scenario.py +79 -0
  242. helm/benchmark/scenarios/chw_care_plan_scenario.py +105 -0
  243. helm/benchmark/scenarios/civil_comments_scenario.py +1 -1
  244. helm/benchmark/scenarios/clear_scenario.py +153 -0
  245. helm/benchmark/scenarios/cleva_scenario.py +2 -2
  246. helm/benchmark/scenarios/code_scenario.py +17 -4
  247. helm/benchmark/scenarios/commonsense_scenario.py +1 -1
  248. helm/benchmark/scenarios/conv_fin_qa_calc_scenario.py +97 -0
  249. helm/benchmark/scenarios/copyright_scenario.py +1 -1
  250. helm/benchmark/scenarios/covid_dialog_scenario.py +10 -1
  251. helm/benchmark/scenarios/cti_to_mitre_scenario.py +240 -0
  252. helm/benchmark/scenarios/custom_mcqa_scenario.py +1 -1
  253. helm/benchmark/scenarios/czech_bank_qa_scenario.py +130 -0
  254. helm/benchmark/scenarios/decodingtrust_adv_demonstration_scenario.py +1 -1
  255. helm/benchmark/scenarios/decodingtrust_privacy_scenario.py +1 -1
  256. helm/benchmark/scenarios/decodingtrust_stereotype_bias_scenario.py +1 -1
  257. helm/benchmark/scenarios/decodingtrust_toxicity_prompts_scenario.py +1 -1
  258. helm/benchmark/scenarios/dialogue_scenarios.py +13 -2
  259. helm/benchmark/scenarios/dischargeme_scenario.py +157 -0
  260. helm/benchmark/scenarios/disinformation_scenario.py +10 -1
  261. helm/benchmark/scenarios/dyck_language_scenario.py +10 -1
  262. helm/benchmark/scenarios/echr_judgment_classification_scenario.py +113 -0
  263. helm/benchmark/scenarios/ehr_sql_scenario.py +131 -0
  264. helm/benchmark/scenarios/ehrshot_scenario.py +1546 -0
  265. helm/benchmark/scenarios/enem_challenge_scenario.py +58 -0
  266. helm/benchmark/scenarios/entity_data_imputation_scenario.py +11 -1
  267. helm/benchmark/scenarios/entity_matching_scenario.py +12 -2
  268. helm/benchmark/scenarios/financial_phrasebank_scenario.py +94 -0
  269. helm/benchmark/scenarios/gold_commodity_news_scenario.py +124 -0
  270. helm/benchmark/scenarios/gpqa_scenario.py +80 -0
  271. helm/benchmark/scenarios/grammar_scenario.py +2 -2
  272. helm/benchmark/scenarios/gsm_scenario.py +10 -1
  273. helm/benchmark/scenarios/harm_bench_gcg_transfer_scenario.py +50 -0
  274. helm/benchmark/scenarios/harm_bench_scenario.py +1 -1
  275. helm/benchmark/scenarios/headqa_scenario.py +131 -0
  276. helm/benchmark/scenarios/helpdesk_call_summarization_scenario.py +37 -0
  277. helm/benchmark/scenarios/ice_scenario.py +8 -4
  278. helm/benchmark/scenarios/ifeval_scenario.py +53 -0
  279. helm/benchmark/scenarios/imdb_ptbr_scenario.py +60 -0
  280. helm/benchmark/scenarios/imdb_scenario.py +11 -2
  281. helm/benchmark/scenarios/infinite_bench_sum_scenario.py +82 -0
  282. helm/benchmark/scenarios/interactive_qa_mmlu_scenario.py +2 -2
  283. helm/benchmark/scenarios/koala_scenario.py +1 -1
  284. helm/benchmark/scenarios/legal_contract_summarization_scenario.py +129 -0
  285. helm/benchmark/scenarios/legal_opinion_sentiment_classification_scenario.py +77 -0
  286. helm/benchmark/scenarios/legal_summarization_scenario.py +11 -1
  287. helm/benchmark/scenarios/legal_support_scenario.py +11 -1
  288. helm/benchmark/scenarios/legalbench_scenario.py +22 -3
  289. helm/benchmark/scenarios/lex_glue_scenario.py +12 -2
  290. helm/benchmark/scenarios/lextreme_scenario.py +11 -1
  291. helm/benchmark/scenarios/live_qa_scenario.py +1 -1
  292. helm/benchmark/scenarios/lm_entry_scenario.py +1 -1
  293. helm/benchmark/scenarios/lsat_qa_scenario.py +1 -1
  294. helm/benchmark/scenarios/math_scenario.py +9 -1
  295. helm/benchmark/scenarios/me_q_sum_scenario.py +10 -1
  296. helm/benchmark/scenarios/med_dialog_scenario.py +22 -24
  297. helm/benchmark/scenarios/med_mcqa_scenario.py +10 -1
  298. helm/benchmark/scenarios/med_paragraph_simplification_scenario.py +10 -1
  299. helm/benchmark/scenarios/med_qa_scenario.py +10 -1
  300. helm/benchmark/scenarios/medalign_scenario.py +88 -0
  301. helm/benchmark/scenarios/medalign_scenario_helper.py +429 -0
  302. helm/benchmark/scenarios/medbullets_scenario.py +140 -0
  303. helm/benchmark/scenarios/medcalc_bench_scenario.py +125 -0
  304. helm/benchmark/scenarios/medec_scenario.py +120 -0
  305. helm/benchmark/scenarios/medhallu_scenario.py +66 -0
  306. helm/benchmark/scenarios/medi_qa_scenario.py +105 -0
  307. helm/benchmark/scenarios/medication_qa_scenario.py +2 -2
  308. helm/benchmark/scenarios/mental_health_scenario.py +112 -0
  309. helm/benchmark/scenarios/mimic_bhc_scenario.py +98 -0
  310. helm/benchmark/scenarios/mimic_rrs_scenario.py +89 -0
  311. helm/benchmark/scenarios/mimiciv_billing_code_scenario.py +71 -0
  312. helm/benchmark/scenarios/mmlu_clinical_afr_scenario.py +74 -0
  313. helm/benchmark/scenarios/mmlu_pro_scenario.py +95 -0
  314. helm/benchmark/scenarios/mmlu_scenario.py +11 -1
  315. helm/benchmark/scenarios/msmarco_scenario.py +1 -1
  316. helm/benchmark/scenarios/mtsamples_procedures_scenario.py +141 -0
  317. helm/benchmark/scenarios/mtsamples_replicate_scenario.py +141 -0
  318. helm/benchmark/scenarios/n2c2_ct_matching_scenario.py +271 -0
  319. helm/benchmark/scenarios/narrativeqa_scenario.py +1 -1
  320. helm/benchmark/scenarios/natural_qa_scenario.py +1 -1
  321. helm/benchmark/scenarios/newsqa_scenario.py +1 -1
  322. helm/benchmark/scenarios/numeracy_scenario.py +10 -1
  323. helm/benchmark/scenarios/oab_exams_scenario.py +57 -0
  324. helm/benchmark/scenarios/omni_math_scenario.py +53 -0
  325. helm/benchmark/scenarios/open_assistant_scenario.py +11 -2
  326. helm/benchmark/scenarios/opinions_qa_scenario.py +1 -1
  327. helm/benchmark/scenarios/pubmed_qa_scenario.py +54 -43
  328. helm/benchmark/scenarios/quac_scenario.py +10 -1
  329. helm/benchmark/scenarios/race_based_med_scenario.py +142 -0
  330. helm/benchmark/scenarios/raft_scenario.py +17 -2
  331. helm/benchmark/scenarios/real_toxicity_prompts_scenario.py +1 -1
  332. helm/benchmark/scenarios/ruler_qa_scenario_helper.py +171 -0
  333. helm/benchmark/scenarios/ruler_qa_scenarios.py +88 -0
  334. helm/benchmark/scenarios/scenario.py +9 -1
  335. helm/benchmark/scenarios/{bhasa_scenario.py → seahelm_scenario.py} +7 -2
  336. helm/benchmark/scenarios/self_instruct_scenario.py +1 -1
  337. helm/benchmark/scenarios/shc_bmt_scenario.py +69 -0
  338. helm/benchmark/scenarios/shc_cdi_scenario.py +70 -0
  339. helm/benchmark/scenarios/shc_conf_scenario.py +70 -0
  340. helm/benchmark/scenarios/shc_ent_scenario.py +72 -0
  341. helm/benchmark/scenarios/shc_gip_scenario.py +66 -0
  342. helm/benchmark/scenarios/shc_ptbm_scenario.py +76 -0
  343. helm/benchmark/scenarios/shc_sei_scenario.py +89 -0
  344. helm/benchmark/scenarios/shc_sequoia_scenario.py +69 -0
  345. helm/benchmark/scenarios/simple_safety_tests_scenario.py +1 -1
  346. helm/benchmark/scenarios/spider_scenario.py +91 -0
  347. helm/benchmark/scenarios/starr_patient_instructions_scenario.py +90 -0
  348. helm/benchmark/scenarios/summarization_scenario.py +11 -1
  349. helm/benchmark/scenarios/sumosum_scenario.py +157 -0
  350. helm/benchmark/scenarios/synthetic_efficiency_scenario.py +1 -1
  351. helm/benchmark/scenarios/synthetic_reasoning_natural_scenario.py +11 -1
  352. helm/benchmark/scenarios/synthetic_reasoning_scenario.py +11 -1
  353. helm/benchmark/scenarios/test_bigcodebench_scenario.py +26 -0
  354. helm/benchmark/scenarios/test_czech_bank_qa_scenario.py +18 -0
  355. helm/benchmark/scenarios/test_enem_challenge_scenario.py +53 -0
  356. helm/benchmark/scenarios/test_ewok_scenario.py +6 -2
  357. helm/benchmark/scenarios/test_gold_commodity_news_scenario.py +18 -0
  358. helm/benchmark/scenarios/test_gpqa_scenario.py +44 -0
  359. helm/benchmark/scenarios/test_ifeval_scenario.py +36 -0
  360. helm/benchmark/scenarios/test_imdb_ptbr_scenario.py +27 -0
  361. helm/benchmark/scenarios/test_infinite_bench_sum_scenario.py +46 -0
  362. helm/benchmark/scenarios/test_math_scenario.py +1 -0
  363. helm/benchmark/scenarios/test_mmlu_clinical_afr_scenario.py +21 -0
  364. helm/benchmark/scenarios/test_mmlu_pro_scenario.py +53 -0
  365. helm/benchmark/scenarios/test_oab_exams_scenario.py +51 -0
  366. helm/benchmark/scenarios/test_omni_math_scenario.py +27 -0
  367. helm/benchmark/scenarios/test_tweetsentbr_scenario.py +24 -0
  368. helm/benchmark/scenarios/test_wildbench_scenario.py +15 -0
  369. helm/benchmark/scenarios/test_winogrande_afr_scenario.py +19 -0
  370. helm/benchmark/scenarios/thai_exam_scenario.py +10 -1
  371. helm/benchmark/scenarios/the_pile_scenario.py +1 -1
  372. helm/benchmark/scenarios/truthful_qa_scenario.py +10 -1
  373. helm/benchmark/scenarios/tweetsentbr_scenario.py +66 -0
  374. helm/benchmark/scenarios/twitter_aae_scenario.py +1 -1
  375. helm/benchmark/scenarios/unitxt_scenario.py +8 -2
  376. helm/benchmark/scenarios/verifiability_judgment_scenario.py +1 -1
  377. helm/benchmark/scenarios/vicuna_scenario.py +1 -1
  378. helm/benchmark/scenarios/vision_language/blink_scenario.py +140 -0
  379. helm/benchmark/scenarios/vision_language/mm_star_scenario.py +95 -0
  380. helm/benchmark/scenarios/vision_language/vqa_rad_scenario.py +88 -0
  381. helm/benchmark/scenarios/wikifact_scenario.py +11 -1
  382. helm/benchmark/scenarios/wikitext_103_scenario.py +1 -1
  383. helm/benchmark/scenarios/wildbench_scenario.py +83 -0
  384. helm/benchmark/scenarios/winogrande_afr_scenario.py +78 -0
  385. helm/benchmark/scenarios/wmt_14_scenario.py +14 -2
  386. helm/benchmark/scenarios/xstest_scenario.py +1 -1
  387. helm/benchmark/server.py +11 -0
  388. helm/benchmark/slurm_runner.py +1 -1
  389. helm/benchmark/static/schema_audio.yaml +752 -0
  390. helm/benchmark/static/schema_autobencher.yaml +150 -0
  391. helm/benchmark/static/schema_call_center.yaml +97 -60
  392. helm/benchmark/static/schema_capabilities.yaml +254 -0
  393. helm/benchmark/static/schema_czech_bank.yaml +148 -0
  394. helm/benchmark/static/schema_enem_challenge.yaml +146 -0
  395. helm/benchmark/static/schema_enterprise.yaml +298 -0
  396. helm/benchmark/static/schema_finance.yaml +14 -12
  397. helm/benchmark/static/schema_heim.yaml +1389 -0
  398. helm/benchmark/static/{schema_medical.yaml → schema_long_context.yaml} +67 -82
  399. helm/benchmark/static/schema_medhelm.yaml +1081 -0
  400. helm/benchmark/static/schema_mmlu_winogrande_afr.yaml +1045 -0
  401. helm/benchmark/static/schema_safety.yaml +18 -1
  402. helm/benchmark/static/{schema_bhasa.yaml → schema_seahelm.yaml} +30 -16
  403. helm/benchmark/static/schema_social_audio.yaml +224 -0
  404. helm/benchmark/static/schema_sql.yaml +171 -0
  405. helm/benchmark/static/{schema_tables.yaml → schema_torr.yaml} +169 -36
  406. helm/benchmark/static/schema_tweetsentbr.yaml +146 -0
  407. helm/benchmark/static/schema_vhelm.yaml +109 -36
  408. helm/benchmark/static_build/assets/helm-safety-2907a7b6.png +0 -0
  409. helm/benchmark/static_build/assets/index-262903c1.js +10 -0
  410. helm/benchmark/static_build/assets/index-42060d71.css +1 -0
  411. helm/benchmark/static_build/assets/medhelm-overview-3ddfcd65.png +0 -0
  412. helm/benchmark/static_build/assets/{react-d4a0b69b.js → react-f82877fd.js} +1 -1
  413. helm/benchmark/static_build/assets/{recharts-6d337683.js → recharts-4037aff0.js} +1 -1
  414. helm/benchmark/static_build/assets/{tremor-54a99cc4.js → tremor-9cefc3c5.js} +1 -1
  415. helm/benchmark/static_build/config.js +1 -1
  416. helm/benchmark/static_build/index.html +5 -5
  417. helm/benchmark/window_services/default_window_service.py +1 -1
  418. helm/benchmark/window_services/encoder_decoder_window_service.py +1 -1
  419. helm/benchmark/window_services/ice_window_service.py +1 -1
  420. helm/benchmark/window_services/image_generation/lexica_search_window_service.py +1 -1
  421. helm/benchmark/window_services/image_generation/openai_dalle_window_service.py +1 -1
  422. helm/benchmark/window_services/local_window_service.py +2 -2
  423. helm/benchmark/window_services/test_anthropic_window_service.py +3 -3
  424. helm/benchmark/window_services/test_bloom_window_service.py +3 -3
  425. helm/benchmark/window_services/test_gpt2_window_service.py +7 -2
  426. helm/benchmark/window_services/test_gpt4_window_service.py +8 -3
  427. helm/benchmark/window_services/test_gptj_window_service.py +8 -3
  428. helm/benchmark/window_services/test_gptneox_window_service.py +3 -3
  429. helm/benchmark/window_services/test_openai_window_service.py +8 -3
  430. helm/benchmark/window_services/test_opt_window_service.py +3 -3
  431. helm/benchmark/window_services/test_palmyra_window_service.py +3 -3
  432. helm/benchmark/window_services/test_t0pp_window_service.py +3 -3
  433. helm/benchmark/window_services/test_t511b_window_service.py +3 -3
  434. helm/benchmark/window_services/test_ul2_window_service.py +3 -3
  435. helm/benchmark/window_services/test_utils.py +1 -1
  436. helm/benchmark/window_services/test_yalm_window_service.py +3 -3
  437. helm/benchmark/window_services/yalm_window_service.py +1 -1
  438. helm/clients/ai21_client.py +3 -3
  439. helm/clients/aleph_alpha_client.py +1 -1
  440. helm/clients/audio_language/__init__.py +0 -0
  441. helm/clients/audio_language/diva_llama_client.py +118 -0
  442. helm/clients/audio_language/llama_omni_client.py +198 -0
  443. helm/clients/audio_language/qwen2_audiolm_client.py +188 -0
  444. helm/clients/audio_language/qwen_audiolm_client.py +150 -0
  445. helm/clients/auto_client.py +4 -2
  446. helm/clients/azure_openai_client.py +55 -0
  447. helm/clients/bedrock_client.py +201 -7
  448. helm/clients/bedrock_utils.py +33 -0
  449. helm/clients/clip_scorers/clip_scorer.py +1 -1
  450. helm/clients/clip_scorers/multilingual_clip_scorer.py +1 -1
  451. helm/clients/cohere_client.py +3 -3
  452. helm/clients/google_client.py +1 -1
  453. helm/clients/http_model_client.py +1 -1
  454. helm/clients/huggingface_client.py +10 -18
  455. helm/clients/ibm_client.py +267 -0
  456. helm/clients/image_generation/adobe_vision_client.py +1 -1
  457. helm/clients/image_generation/aleph_alpha_image_generation_client.py +1 -1
  458. helm/clients/image_generation/cogview2/sr_pipeline/__init__.py +3 -3
  459. helm/clients/image_generation/cogview2/sr_pipeline/direct_sr.py +5 -2
  460. helm/clients/image_generation/cogview2/sr_pipeline/iterative_sr.py +5 -2
  461. helm/clients/image_generation/cogview2/sr_pipeline/sr_group.py +2 -2
  462. helm/clients/image_generation/cogview2_client.py +1 -1
  463. helm/clients/image_generation/dalle2_client.py +1 -1
  464. helm/clients/image_generation/dalle3_client.py +2 -2
  465. helm/clients/image_generation/dalle_mini/__init__.py +1 -1
  466. helm/clients/image_generation/dalle_mini/data.py +1 -1
  467. helm/clients/image_generation/dalle_mini/model/__init__.py +5 -5
  468. helm/clients/image_generation/dalle_mini/model/configuration.py +1 -1
  469. helm/clients/image_generation/dalle_mini/model/modeling.py +2 -2
  470. helm/clients/image_generation/dalle_mini/model/processor.py +4 -4
  471. helm/clients/image_generation/dalle_mini/model/tokenizer.py +1 -1
  472. helm/clients/image_generation/dalle_mini/vqgan_jax/__init__.py +1 -1
  473. helm/clients/image_generation/dalle_mini/vqgan_jax/convert_pt_model_to_jax.py +2 -2
  474. helm/clients/image_generation/dalle_mini/vqgan_jax/modeling_flax_vqgan.py +1 -1
  475. helm/clients/image_generation/dalle_mini_client.py +1 -1
  476. helm/clients/image_generation/deep_floyd_client.py +1 -1
  477. helm/clients/image_generation/huggingface_diffusers_client.py +1 -1
  478. helm/clients/image_generation/lexica_client.py +1 -1
  479. helm/clients/image_generation/mindalle/models/__init__.py +6 -6
  480. helm/clients/image_generation/mindalle/models/stage1/vqgan.py +1 -1
  481. helm/clients/image_generation/mindalle/models/stage2/transformer.py +1 -1
  482. helm/clients/image_generation/mindalle/utils/__init__.py +3 -3
  483. helm/clients/image_generation/mindalle_client.py +1 -1
  484. helm/clients/image_generation/together_image_generation_client.py +1 -1
  485. helm/clients/lit_gpt_client.py +2 -2
  486. helm/clients/mistral_client.py +62 -18
  487. helm/clients/nvidia_nim_client.py +0 -3
  488. helm/clients/openai_client.py +241 -22
  489. helm/clients/palmyra_client.py +1 -4
  490. helm/clients/reka_client.py +1 -1
  491. helm/clients/stanfordhealthcare_azure_openai_client.py +58 -0
  492. helm/clients/stanfordhealthcare_claude_client.py +31 -0
  493. helm/clients/stanfordhealthcare_google_client.py +43 -0
  494. helm/clients/stanfordhealthcare_http_model_client.py +93 -0
  495. helm/clients/stanfordhealthcare_openai_client.py +62 -0
  496. helm/clients/stanfordhealthcare_shc_openai_client.py +42 -0
  497. helm/clients/test_client.py +1 -1
  498. helm/clients/test_together_client.py +6 -1
  499. helm/clients/together_client.py +47 -7
  500. helm/clients/upstage_client.py +23 -0
  501. helm/clients/vertexai_client.py +39 -13
  502. helm/clients/vision_language/open_flamingo/__init__.py +2 -2
  503. helm/clients/vision_language/open_flamingo/src/factory.py +3 -3
  504. helm/clients/vision_language/open_flamingo/src/flamingo.py +2 -2
  505. helm/clients/vision_language/open_flamingo/src/flamingo_lm.py +2 -2
  506. helm/clients/vision_language/qwen2_vlm_client.py +175 -0
  507. helm/clients/vllm_client.py +4 -6
  508. helm/clients/yi_client.py +0 -3
  509. helm/common/audio_utils.py +111 -0
  510. helm/common/file_caches/local_file_cache.py +1 -1
  511. helm/common/file_caches/test_local_file_cache.py +1 -1
  512. helm/common/images_utils.py +2 -2
  513. helm/common/media_object.py +2 -2
  514. helm/common/multimodal_request_utils.py +26 -0
  515. helm/common/reeval_parameters.py +12 -0
  516. helm/common/request.py +6 -2
  517. helm/common/response_format.py +18 -0
  518. helm/common/test_media_object.py +1 -1
  519. helm/config/model_deployments.yaml +1112 -19
  520. helm/config/model_metadata.yaml +985 -44
  521. helm/config/tokenizer_configs.yaml +379 -3
  522. helm/proxy/cli.py +2 -2
  523. helm/proxy/example_queries.py +1 -1
  524. helm/proxy/server.py +11 -4
  525. helm/proxy/services/remote_service.py +1 -1
  526. helm/proxy/services/server_service.py +1 -1
  527. helm/proxy/services/test_remote_service.py +2 -2
  528. helm/proxy/services/test_service.py +1 -1
  529. helm/proxy/static/general.js +122 -0
  530. helm/proxy/static/help.html +99 -0
  531. helm/proxy/static/index.css +57 -0
  532. helm/proxy/static/index.html +40 -0
  533. helm/proxy/static/index.js +456 -0
  534. helm/proxy/static/info-icon.png +0 -0
  535. helm/proxy/test_retry.py +1 -1
  536. helm/proxy/token_counters/auto_token_counter.py +1 -1
  537. helm/tokenizers/aleph_alpha_tokenizer.py +1 -1
  538. helm/tokenizers/caching_tokenizer.py +2 -30
  539. helm/tokenizers/http_model_tokenizer.py +1 -1
  540. helm/tokenizers/huggingface_tokenizer.py +2 -2
  541. helm/tokenizers/lit_gpt_tokenizer.py +1 -1
  542. helm/tokenizers/test_anthropic_tokenizer.py +6 -2
  543. helm/tokenizers/test_huggingface_tokenizer.py +1 -1
  544. helm/tokenizers/test_yalm_tokenizer.py +1 -1
  545. helm/tokenizers/tiktoken_tokenizer.py +1 -1
  546. helm/tokenizers/tokenizer.py +3 -1
  547. helm/tokenizers/yalm_tokenizer.py +3 -3
  548. helm/tokenizers/yalm_tokenizer_data/test_yalm_tokenizer.py +1 -1
  549. crfm_helm-0.5.4.dist-info/METADATA +0 -350
  550. crfm_helm-0.5.4.dist-info/RECORD +0 -697
  551. helm/benchmark/metrics/bhasa_metrics_specs.py +0 -10
  552. helm/benchmark/static_build/assets/01-694cb9b7.png +0 -0
  553. helm/benchmark/static_build/assets/accenture-6f97eeda.png +0 -0
  554. helm/benchmark/static_build/assets/ai21-0eb91ec3.png +0 -0
  555. helm/benchmark/static_build/assets/aisingapore-6dfc9acf.png +0 -0
  556. helm/benchmark/static_build/assets/aleph-alpha-7ce10034.png +0 -0
  557. helm/benchmark/static_build/assets/anthropic-70d8bc39.png +0 -0
  558. helm/benchmark/static_build/assets/bigscience-7f0400c0.png +0 -0
  559. helm/benchmark/static_build/assets/cohere-3550c6cb.png +0 -0
  560. helm/benchmark/static_build/assets/cresta-9e22b983.png +0 -0
  561. helm/benchmark/static_build/assets/cuhk-8c5631e9.png +0 -0
  562. helm/benchmark/static_build/assets/eleutherai-b9451114.png +0 -0
  563. helm/benchmark/static_build/assets/google-06d997ad.png +0 -0
  564. helm/benchmark/static_build/assets/index-05c76bb1.css +0 -1
  565. helm/benchmark/static_build/assets/index-3ee38b3d.js +0 -10
  566. helm/benchmark/static_build/assets/meta-5580e9f1.png +0 -0
  567. helm/benchmark/static_build/assets/microsoft-f5ee5016.png +0 -0
  568. helm/benchmark/static_build/assets/mistral-18e1be23.png +0 -0
  569. helm/benchmark/static_build/assets/nvidia-86fa75c1.png +0 -0
  570. helm/benchmark/static_build/assets/openai-3f8653e4.png +0 -0
  571. helm/benchmark/static_build/assets/scb10x-204bd786.png +0 -0
  572. helm/benchmark/static_build/assets/tii-24de195c.png +0 -0
  573. helm/benchmark/static_build/assets/together-a665a35b.png +0 -0
  574. helm/benchmark/static_build/assets/tsinghua-keg-97d4b395.png +0 -0
  575. helm/benchmark/static_build/assets/wellsfargo-a86a6c4a.png +0 -0
  576. helm/benchmark/static_build/assets/yandex-38e09d70.png +0 -0
  577. helm/tokenizers/anthropic_tokenizer.py +0 -52
  578. {crfm_helm-0.5.4.dist-info → crfm_helm-0.5.5.dist-info}/entry_points.txt +0 -0
  579. {crfm_helm-0.5.4.dist-info → crfm_helm-0.5.5.dist-info/licenses}/LICENSE +0 -0
  580. {crfm_helm-0.5.4.dist-info → crfm_helm-0.5.5.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,613 @@
1
+ """Run spec functions for audio scenarios."""
2
+
3
+ from typing import List, Optional
4
+ from helm.benchmark.adaptation.adapter_spec import (
5
+ AdapterSpec,
6
+ )
7
+ from helm.benchmark.adaptation.adapters.adapter_factory import (
8
+ ADAPT_GENERATION_MULTIMODAL,
9
+ ADAPT_MULTIPLE_CHOICE_JOINT_MULTIMODAL,
10
+ )
11
+ from helm.benchmark.metrics.common_metric_specs import (
12
+ get_classification_metric_specs,
13
+ get_exact_match_metric_specs,
14
+ get_generative_harms_metric_specs,
15
+ get_basic_metric_specs,
16
+ )
17
+ from helm.benchmark.metrics.metric import MetricSpec
18
+ from helm.benchmark.run_spec import RunSpec, run_spec_function
19
+ from helm.benchmark.scenarios.scenario import ScenarioSpec
20
+
21
+
22
+ ########################################################################################################################
23
+ # Constants
24
+ ASR_INSTRUCTIONS: str = (
25
+ "Listen to the audio and transcribe the spoken content to text. "
26
+ "Respond with only the transcript text and nothing else."
27
+ )
28
+
29
+
30
+ ########################################################################################################################
31
+ # AdapterSpecs
32
+
33
+
34
+ def _get_generation_adapter_spec(
35
+ max_tokens: int,
36
+ instructions: str = "",
37
+ max_train_instances: int = 0,
38
+ temperature: float = 0.0,
39
+ stop_sequences: Optional[List[str]] = None,
40
+ ) -> AdapterSpec:
41
+ return AdapterSpec(
42
+ method=ADAPT_GENERATION_MULTIMODAL,
43
+ instructions=instructions,
44
+ input_prefix="",
45
+ input_suffix="",
46
+ output_prefix="",
47
+ output_suffix="",
48
+ instance_prefix="",
49
+ max_train_instances=max_train_instances,
50
+ num_outputs=1,
51
+ max_tokens=max_tokens,
52
+ temperature=temperature,
53
+ stop_sequences=stop_sequences if stop_sequences is not None else [],
54
+ )
55
+
56
+
57
+ def _get_multiple_choice_joint_adapter_spec(
58
+ input_noun: Optional[str],
59
+ output_noun: str,
60
+ max_train_instances: int = 0,
61
+ num_outputs: int = 1,
62
+ ) -> AdapterSpec:
63
+ return AdapterSpec(
64
+ method=ADAPT_MULTIPLE_CHOICE_JOINT_MULTIMODAL,
65
+ global_prefix="",
66
+ instructions="Answer the multiple choice question by just giving the letter of the correct answer "
67
+ "and nothing else.",
68
+ input_prefix=f"{input_noun}: " if input_noun is not None else "",
69
+ input_suffix="\n",
70
+ output_prefix=f"{output_noun}: ",
71
+ output_suffix="\n",
72
+ instance_prefix="\n",
73
+ max_train_instances=max_train_instances,
74
+ num_outputs=num_outputs,
75
+ max_tokens=1,
76
+ stop_sequences=["\n"],
77
+ temperature=0.0,
78
+ random=None,
79
+ )
80
+
81
+
82
+ ########################################################################################################################
83
+ # MetricSpecs
84
+
85
+
86
+ def get_machine_translation_metric_specs() -> List[MetricSpec]:
87
+ return [MetricSpec(class_name="helm.benchmark.metrics.machine_translation_metrics.MachineTranslationMetric")]
88
+
89
+
90
+ def _get_audio_recognition_metric_specs() -> List[MetricSpec]:
91
+ return get_basic_metric_specs(["wer_score", "mer_score", "wip_score", "cer_score"])
92
+
93
+
94
+ def _get_open_ended_generation_metric_specs() -> List[MetricSpec]:
95
+ return get_basic_metric_specs(
96
+ ["exact_match", "quasi_exact_match", "f1_score", "rouge_l", "bleu_1", "bleu_4", "cider"]
97
+ )
98
+
99
+
100
+ def _get_chinese_audio_recognition_metric_specs() -> List[MetricSpec]:
101
+ return get_basic_metric_specs(["chinese_wer_score", "chinese_mer_score", "chinese_wip_score", "chinese_cer_score"])
102
+
103
+
104
+ def _get_gpt4_critique_metric_specs(num_respondents: int, max_tokens: int) -> List[MetricSpec]:
105
+ return [
106
+ MetricSpec(
107
+ class_name="helm.benchmark.metrics.gpt4_audio_critique_metrics.GPT4AudioCritiqueMetric",
108
+ args={
109
+ "num_respondents": num_respondents,
110
+ "max_tokens": max_tokens,
111
+ },
112
+ )
113
+ ]
114
+
115
+
116
+ ########################################################################################################################
117
+ # RunSpecs
118
+
119
+
120
+ @run_spec_function("audio_mnist")
121
+ def get_audio_mnist_run_spec() -> RunSpec:
122
+ scenario_spec = ScenarioSpec(
123
+ class_name="helm.benchmark.scenarios.audio_language.audio_mnist_scenario.AudioMNISTScenario"
124
+ )
125
+ adapter_spec = _get_generation_adapter_spec(
126
+ instructions="Classify the spoken digit. Respond with only a single digit.",
127
+ max_tokens=5,
128
+ )
129
+ metric_specs = get_exact_match_metric_specs() + get_classification_metric_specs()
130
+ run_spec_name: str = "audio_mnist"
131
+ return RunSpec(
132
+ name=run_spec_name,
133
+ scenario_spec=scenario_spec,
134
+ adapter_spec=adapter_spec,
135
+ metric_specs=metric_specs,
136
+ groups=[run_spec_name],
137
+ )
138
+
139
+
140
+ @run_spec_function("iemocap_audio")
141
+ def get_iemocap_audio_run_spec() -> RunSpec:
142
+ scenario_spec = ScenarioSpec(
143
+ class_name="helm.benchmark.scenarios.audio_language.iemocap_audio_scenario.IEMOCAPAudioScenario"
144
+ )
145
+ adapter_spec = _get_generation_adapter_spec(
146
+ instructions='Classify the emotion of the speaker(s) in the audio as "angry", "happy", "neutral", or "sad". Answer with only the emotion.', # noqa: E501
147
+ max_tokens=5,
148
+ )
149
+ metric_specs = get_exact_match_metric_specs() + get_classification_metric_specs()
150
+ run_spec_name: str = "iemocap_audio"
151
+ return RunSpec(
152
+ name=run_spec_name,
153
+ scenario_spec=scenario_spec,
154
+ adapter_spec=adapter_spec,
155
+ metric_specs=metric_specs,
156
+ groups=[run_spec_name],
157
+ )
158
+
159
+
160
+ @run_spec_function("meld_audio")
161
+ def get_meld_audio_run_spec() -> RunSpec:
162
+ scenario_spec = ScenarioSpec(
163
+ class_name="helm.benchmark.scenarios.audio_language.meld_audio_scenario.MELDAudioScenario"
164
+ )
165
+ adapter_spec = _get_generation_adapter_spec(
166
+ instructions='Classify the emotion of the speaker in the audio as "anger", "disgust", "fear", "joy", "neutral", "sadness", or "surprise". Answer with only the emotion.', # noqa: E501
167
+ max_tokens=5,
168
+ )
169
+ metric_specs = get_exact_match_metric_specs() + get_classification_metric_specs()
170
+ run_spec_name: str = "meld_audio"
171
+ return RunSpec(
172
+ name=run_spec_name,
173
+ scenario_spec=scenario_spec,
174
+ adapter_spec=adapter_spec,
175
+ metric_specs=metric_specs,
176
+ groups=[run_spec_name],
177
+ )
178
+
179
+
180
+ @run_spec_function("mutox")
181
+ def get_mutox_audio_run_spec(language: str) -> RunSpec:
182
+ scenario_spec = ScenarioSpec(
183
+ class_name="helm.benchmark.scenarios.audio_language.mutox_scenario.MuToxScenario",
184
+ args={"language": language},
185
+ )
186
+ adapter_spec: AdapterSpec = _get_multiple_choice_joint_adapter_spec(
187
+ input_noun=None, output_noun="Answer", max_train_instances=0
188
+ )
189
+ metric_specs: List[MetricSpec] = get_exact_match_metric_specs()
190
+ run_spec_name: str = "mutox"
191
+ return RunSpec(
192
+ name=f"{run_spec_name}:language={language}",
193
+ scenario_spec=scenario_spec,
194
+ adapter_spec=adapter_spec,
195
+ metric_specs=metric_specs,
196
+ groups=[run_spec_name],
197
+ )
198
+
199
+
200
+ @run_spec_function("mustard")
201
+ def get_mustard_audio_run_spec() -> RunSpec:
202
+ scenario_spec = ScenarioSpec(class_name="helm.benchmark.scenarios.audio_language.mustard_scenario.MUStARDScenario")
203
+ adapter_spec: AdapterSpec = _get_multiple_choice_joint_adapter_spec(
204
+ input_noun=None, output_noun="Answer", max_train_instances=0
205
+ )
206
+ metric_specs: List[MetricSpec] = get_exact_match_metric_specs()
207
+ run_spec_name: str = "mustard"
208
+ return RunSpec(
209
+ name=run_spec_name,
210
+ scenario_spec=scenario_spec,
211
+ adapter_spec=adapter_spec,
212
+ metric_specs=metric_specs,
213
+ groups=[run_spec_name],
214
+ )
215
+
216
+
217
+ @run_spec_function("voice_jailbreak_attacks")
218
+ def get_voice_jailbreak_attacks_run_spec(subset: str) -> RunSpec:
219
+ scenario_spec = ScenarioSpec(
220
+ class_name="helm.benchmark.scenarios.audio_language.voice_jailbreak_attacks_scenario."
221
+ "VoiceJailbreakAttacksScenario",
222
+ args={"subset": subset},
223
+ )
224
+ adapter_spec = _get_generation_adapter_spec(max_tokens=1024)
225
+ metric_specs: List[MetricSpec] = get_generative_harms_metric_specs(
226
+ include_basic_metrics=True, include_generative_harms_metrics=True
227
+ )
228
+
229
+ run_spec_name: str = "voice_jailbreak_attacks"
230
+ return RunSpec(
231
+ name=f"{run_spec_name}:subset={subset}",
232
+ scenario_spec=scenario_spec,
233
+ adapter_spec=adapter_spec,
234
+ metric_specs=metric_specs,
235
+ groups=[run_spec_name],
236
+ )
237
+
238
+
239
+ @run_spec_function("covost2")
240
+ def get_covost2_run_spec(source_language: str, target_language: str) -> RunSpec:
241
+ scenario_spec = ScenarioSpec(
242
+ class_name="helm.benchmark.scenarios.audio_language.covost2_scenario.CoVoST2Scenario",
243
+ args={"source_language": source_language, "target_language": target_language},
244
+ )
245
+ adapter_spec = _get_generation_adapter_spec(
246
+ instructions=f"Translate from {source_language} to {target_language}. "
247
+ "Just give the translation and nothing else.",
248
+ max_tokens=50,
249
+ )
250
+ metric_specs = get_machine_translation_metric_specs()
251
+ return RunSpec(
252
+ name=f"covost2:source_language={source_language},target_language={target_language}",
253
+ scenario_spec=scenario_spec,
254
+ adapter_spec=adapter_spec,
255
+ metric_specs=metric_specs,
256
+ groups=["covost2"],
257
+ )
258
+
259
+
260
+ @run_spec_function("vocal_sound")
261
+ def get_vocal_sound_run_spec() -> RunSpec:
262
+ scenario_spec = ScenarioSpec(
263
+ class_name="helm.benchmark.scenarios.audio_language.vocal_sound_scenario.VocalSoundScenario",
264
+ )
265
+ adapter_spec = _get_generation_adapter_spec(
266
+ instructions="Listen to the audio and classify the speaker behavior. Choose only from these options:"
267
+ '"Cough", "Laughter", "Sigh", "Sneeze", "Sniff", or "Throat clearing". Respond with just the behavior.',
268
+ max_tokens=5,
269
+ )
270
+ metric_specs = get_exact_match_metric_specs() + get_classification_metric_specs()
271
+ run_spec_name: str = "vocal_sound"
272
+ return RunSpec(
273
+ name=run_spec_name,
274
+ scenario_spec=scenario_spec,
275
+ adapter_spec=adapter_spec,
276
+ metric_specs=metric_specs,
277
+ groups=[run_spec_name],
278
+ )
279
+
280
+
281
+ @run_spec_function("multilingual_librispeech")
282
+ def get_multilingual_librispeech_run_spec(language: str) -> RunSpec:
283
+ scenario_spec = ScenarioSpec(
284
+ class_name="helm.benchmark.scenarios.audio_language.multilingual_librispeech_scenario."
285
+ "MultilingualLibriSpeechScenario",
286
+ args={"language": language},
287
+ )
288
+ adapter_spec = _get_generation_adapter_spec(
289
+ instructions=ASR_INSTRUCTIONS,
290
+ max_tokens=100,
291
+ )
292
+ if "chinese" in language.lower():
293
+ metric_specs = _get_chinese_audio_recognition_metric_specs()
294
+ else:
295
+ metric_specs = _get_audio_recognition_metric_specs()
296
+ run_spec_name: str = "multilingual_librispeech"
297
+ return RunSpec(
298
+ name=f"{run_spec_name}:language={language}",
299
+ scenario_spec=scenario_spec,
300
+ adapter_spec=adapter_spec,
301
+ metric_specs=metric_specs,
302
+ groups=[run_spec_name],
303
+ )
304
+
305
+
306
+ @run_spec_function("fleurs")
307
+ def get_fleurs_run_spec(language: str) -> RunSpec:
308
+ scenario_spec = ScenarioSpec(
309
+ class_name="helm.benchmark.scenarios.audio_language.fleurs_scenario.FLEURSScenario",
310
+ args={"language": language},
311
+ )
312
+ adapter_spec = _get_generation_adapter_spec(
313
+ instructions=ASR_INSTRUCTIONS,
314
+ max_tokens=100,
315
+ )
316
+ # Chinese characters are not supported in the default metrics
317
+ if "chinese" in language.lower():
318
+ metric_specs = _get_chinese_audio_recognition_metric_specs()
319
+ else:
320
+ metric_specs = _get_audio_recognition_metric_specs()
321
+ run_spec_name: str = "fleurs"
322
+ return RunSpec(
323
+ name=f"{run_spec_name}:language={language}",
324
+ scenario_spec=scenario_spec,
325
+ adapter_spec=adapter_spec,
326
+ metric_specs=metric_specs,
327
+ groups=[run_spec_name],
328
+ )
329
+
330
+
331
+ @run_spec_function("fleurs_fairness")
332
+ def get_fleurs_fairness_run_spec(gender: str) -> RunSpec:
333
+ scenario_spec = ScenarioSpec(
334
+ class_name="helm.benchmark.scenarios.audio_language.fleurs_fairness_scenario.FLEURSFairnessScenario",
335
+ args={"gender": gender},
336
+ )
337
+ adapter_spec = _get_generation_adapter_spec(
338
+ instructions=ASR_INSTRUCTIONS,
339
+ max_tokens=100,
340
+ )
341
+ metric_specs = _get_audio_recognition_metric_specs()
342
+ run_spec_name: str = "fleurs_fairness"
343
+ return RunSpec(
344
+ name=f"{run_spec_name}:gender={gender}",
345
+ scenario_spec=scenario_spec,
346
+ adapter_spec=adapter_spec,
347
+ metric_specs=metric_specs,
348
+ groups=[run_spec_name],
349
+ )
350
+
351
+
352
+ @run_spec_function("audiocaps")
353
+ def get_audiocaps_run_spec(num_respondents: int = 1) -> RunSpec:
354
+ scenario_spec = ScenarioSpec(
355
+ class_name="helm.benchmark.scenarios.audio_language.audiocaps_scenario.AudioCapsScenario"
356
+ )
357
+ adapter_spec = _get_generation_adapter_spec(
358
+ instructions="Generate a caption describing what you hear in the following audio. "
359
+ "The caption should be short and does not need to be a complete sentence. Respond with "
360
+ "only the caption and nothing else.",
361
+ max_tokens=50,
362
+ )
363
+ metric_specs: List[MetricSpec] = (
364
+ _get_gpt4_critique_metric_specs(
365
+ num_respondents=num_respondents,
366
+ max_tokens=200,
367
+ )
368
+ + _get_open_ended_generation_metric_specs()
369
+ )
370
+ run_spec_name: str = "audiocaps"
371
+ return RunSpec(
372
+ name=run_spec_name,
373
+ scenario_spec=scenario_spec,
374
+ adapter_spec=adapter_spec,
375
+ metric_specs=metric_specs,
376
+ groups=[run_spec_name],
377
+ )
378
+
379
+
380
+ @run_spec_function("voxceleb2")
381
+ def get_voxceleb2_run_spec() -> RunSpec:
382
+ scenario_spec = ScenarioSpec(
383
+ class_name="helm.benchmark.scenarios.audio_language.voxceleb2_scenario.VoxCeleb2Scenario"
384
+ )
385
+ adapter_spec: AdapterSpec = _get_multiple_choice_joint_adapter_spec(
386
+ input_noun=None, output_noun="Answer", max_train_instances=0
387
+ )
388
+ metric_specs: List[MetricSpec] = get_exact_match_metric_specs()
389
+ run_spec_name: str = "voxceleb2"
390
+ return RunSpec(
391
+ name=run_spec_name,
392
+ scenario_spec=scenario_spec,
393
+ adapter_spec=adapter_spec,
394
+ metric_specs=metric_specs,
395
+ groups=[run_spec_name],
396
+ )
397
+
398
+
399
+ @run_spec_function("common_voice_15")
400
+ def get_common_voice_15_run_spec(language: str) -> RunSpec:
401
+ scenario_spec = ScenarioSpec(
402
+ class_name="helm.benchmark.scenarios.audio_language.common_voice_15_scenario.CommonVoice15Scenario",
403
+ args={"language": language},
404
+ )
405
+ adapter_spec = _get_generation_adapter_spec(
406
+ instructions=ASR_INSTRUCTIONS,
407
+ max_tokens=100,
408
+ )
409
+ # Chinese characters are not supported in the default metrics
410
+ if "chinese" in language.lower():
411
+ metric_specs = _get_chinese_audio_recognition_metric_specs()
412
+ else:
413
+ metric_specs = _get_audio_recognition_metric_specs()
414
+ run_spec_name: str = "common_voice_15"
415
+ return RunSpec(
416
+ name=f"{run_spec_name}:language={language}",
417
+ scenario_spec=scenario_spec,
418
+ adapter_spec=adapter_spec,
419
+ metric_specs=metric_specs,
420
+ groups=[run_spec_name],
421
+ )
422
+
423
+
424
+ @run_spec_function("speech_robust_bench")
425
+ def get_speech_robust_bench_run_spec(subject: str, level: int) -> RunSpec:
426
+ scenario_spec = ScenarioSpec(
427
+ class_name="helm.benchmark.scenarios.audio_language.speech_robust_bench_scenario.SpeechRobustBenchScenario",
428
+ args={"subject": subject, "level": level},
429
+ )
430
+ adapter_spec = _get_generation_adapter_spec(
431
+ instructions=ASR_INSTRUCTIONS,
432
+ max_tokens=100,
433
+ )
434
+ metric_specs = _get_audio_recognition_metric_specs()
435
+ run_spec_name: str = "speech_robust_bench"
436
+ return RunSpec(
437
+ name=f"{run_spec_name}:subject={subject},level={level}",
438
+ scenario_spec=scenario_spec,
439
+ adapter_spec=adapter_spec,
440
+ metric_specs=metric_specs,
441
+ groups=[run_spec_name],
442
+ )
443
+
444
+
445
+ @run_spec_function("audio_pairs")
446
+ def get_audio_pairs_run_spec(subject: str) -> RunSpec:
447
+ scenario_spec = ScenarioSpec(
448
+ class_name="helm.benchmark.scenarios.audio_language.audio_pairs_scenario.AudioPAIRSScenario",
449
+ args={"subject": subject},
450
+ )
451
+ adapter_spec = _get_generation_adapter_spec(
452
+ instructions="Listen to the audio and answer the question with provided options.",
453
+ max_tokens=5,
454
+ )
455
+ metric_specs: List[MetricSpec] = get_exact_match_metric_specs() + get_classification_metric_specs()
456
+ run_spec_name: str = "audio_pairs"
457
+ return RunSpec(
458
+ name=f"{run_spec_name}:subject={subject}",
459
+ scenario_spec=scenario_spec,
460
+ adapter_spec=adapter_spec,
461
+ metric_specs=metric_specs,
462
+ groups=[run_spec_name],
463
+ )
464
+
465
+
466
+ @run_spec_function("casual_conversations2")
467
+ def get_casual_conversations2_run_spec(subject: str) -> RunSpec:
468
+ scenario_spec = ScenarioSpec(
469
+ class_name="helm.benchmark.scenarios.audio_language.casual_conversations2_scenario."
470
+ "CasualConversations2Scenario",
471
+ args={"subject": subject},
472
+ )
473
+ adapter_spec: AdapterSpec = _get_multiple_choice_joint_adapter_spec(
474
+ input_noun=None, output_noun="Answer", max_train_instances=0
475
+ )
476
+ metric_specs: List[MetricSpec] = get_exact_match_metric_specs()
477
+ run_spec_name: str = "casual_conversations2"
478
+ return RunSpec(
479
+ name=f"{run_spec_name}:subject={subject}",
480
+ scenario_spec=scenario_spec,
481
+ adapter_spec=adapter_spec,
482
+ metric_specs=metric_specs,
483
+ groups=[run_spec_name],
484
+ )
485
+
486
+
487
+ @run_spec_function("air_bench_chat")
488
+ def get_air_bench_chat_run_spec(subject: str, num_respondents: int = 1) -> RunSpec:
489
+ scenario_spec = ScenarioSpec(
490
+ class_name="helm.benchmark.scenarios.audio_language.air_bench_chat_scenario." "AirBenchChatScenario",
491
+ args={"subject": subject},
492
+ )
493
+ adapter_spec = _get_generation_adapter_spec(
494
+ instructions="",
495
+ max_tokens=200,
496
+ )
497
+ metric_specs: List[MetricSpec] = (
498
+ _get_gpt4_critique_metric_specs(
499
+ num_respondents=num_respondents,
500
+ max_tokens=200,
501
+ )
502
+ + _get_open_ended_generation_metric_specs()
503
+ )
504
+ run_spec_name: str = "air_bench_chat"
505
+ return RunSpec(
506
+ name=f"{run_spec_name}:subject={subject}",
507
+ scenario_spec=scenario_spec,
508
+ adapter_spec=adapter_spec,
509
+ metric_specs=metric_specs,
510
+ groups=[run_spec_name],
511
+ )
512
+
513
+
514
+ @run_spec_function("ami")
515
+ def get_ami_run_spec(subject: str) -> RunSpec:
516
+ scenario_spec = ScenarioSpec(
517
+ class_name="helm.benchmark.scenarios.audio_language.ami_scenario.AMIScenario",
518
+ args={"subject": subject},
519
+ )
520
+ adapter_spec = _get_generation_adapter_spec(
521
+ instructions=ASR_INSTRUCTIONS,
522
+ max_tokens=100,
523
+ )
524
+ metric_specs = _get_audio_recognition_metric_specs()
525
+ run_spec_name: str = "ami"
526
+ return RunSpec(
527
+ name=f"{run_spec_name}:subject={subject}",
528
+ scenario_spec=scenario_spec,
529
+ adapter_spec=adapter_spec,
530
+ metric_specs=metric_specs,
531
+ groups=[run_spec_name],
532
+ )
533
+
534
+
535
+ @run_spec_function("librispeech")
536
+ def get_librispeech_run_spec() -> RunSpec:
537
+ scenario_spec = ScenarioSpec(
538
+ class_name="helm.benchmark.scenarios.audio_language.librispeech_scenario.LibriSpeechScenario",
539
+ )
540
+ adapter_spec = _get_generation_adapter_spec(
541
+ instructions=ASR_INSTRUCTIONS,
542
+ max_tokens=100,
543
+ )
544
+ metric_specs = _get_audio_recognition_metric_specs()
545
+ run_spec_name: str = "librispeech"
546
+ return RunSpec(
547
+ name=f"{run_spec_name}",
548
+ scenario_spec=scenario_spec,
549
+ adapter_spec=adapter_spec,
550
+ metric_specs=metric_specs,
551
+ groups=[run_spec_name],
552
+ )
553
+
554
+
555
+ @run_spec_function("librispeech_fairness")
556
+ def get_librispeech_fairness_run_spec(gender: str) -> RunSpec:
557
+ scenario_spec = ScenarioSpec(
558
+ class_name="helm.benchmark.scenarios.audio_language.librispeech_fairness_scenario.LibriSpeechFairnessScenario",
559
+ args={"gender": gender},
560
+ )
561
+ adapter_spec = _get_generation_adapter_spec(
562
+ instructions=ASR_INSTRUCTIONS,
563
+ max_tokens=100,
564
+ )
565
+ metric_specs = _get_audio_recognition_metric_specs()
566
+ run_spec_name: str = "librispeech_fairness"
567
+ return RunSpec(
568
+ name=f"{run_spec_name}:gender={gender}",
569
+ scenario_spec=scenario_spec,
570
+ adapter_spec=adapter_spec,
571
+ metric_specs=metric_specs,
572
+ groups=[run_spec_name],
573
+ )
574
+
575
+
576
+ @run_spec_function("air_bench_foundation")
577
+ def get_air_bench_foundation_run_spec(subject: str) -> RunSpec:
578
+ scenario_spec = ScenarioSpec(
579
+ class_name="helm.benchmark.scenarios.audio_language.air_bench_foundation_scenario.AirBenchFoundationScenario",
580
+ args={"subject": subject},
581
+ )
582
+ adapter_spec: AdapterSpec = _get_multiple_choice_joint_adapter_spec(
583
+ input_noun=None, output_noun="Answer", max_train_instances=0
584
+ )
585
+ metric_specs = get_exact_match_metric_specs()
586
+ run_spec_name: str = "air_bench_foundation"
587
+ return RunSpec(
588
+ name=f"{run_spec_name},subject={subject}",
589
+ scenario_spec=scenario_spec,
590
+ adapter_spec=adapter_spec,
591
+ metric_specs=metric_specs,
592
+ groups=[run_spec_name],
593
+ )
594
+
595
+
596
+ @run_spec_function("parade")
597
+ def get_parade_run_spec(voice: str, subset: str) -> RunSpec:
598
+ scenario_spec = ScenarioSpec(
599
+ class_name="helm.benchmark.scenarios.audio_language.parade_scenario.PARADEScenario",
600
+ args={"subset": subset, "voice": voice},
601
+ )
602
+ adapter_spec: AdapterSpec = _get_multiple_choice_joint_adapter_spec(
603
+ input_noun=None, output_noun="Answer", max_train_instances=0
604
+ )
605
+ metric_specs = get_exact_match_metric_specs()
606
+ run_spec_name: str = "parade"
607
+ return RunSpec(
608
+ name=f"{run_spec_name},voice={voice},subset={subset}",
609
+ scenario_spec=scenario_spec,
610
+ adapter_spec=adapter_spec,
611
+ metric_specs=metric_specs,
612
+ groups=[run_spec_name],
613
+ )
@@ -150,3 +150,52 @@ def get_call_center_summarization_key_points_recall_spec() -> RunSpec:
150
150
  annotators=annotator_specs,
151
151
  groups=["call_center_summarization_key_points_recall"],
152
152
  )
153
+
154
+
155
+ @run_spec_function("helpdesk_call_summarization")
156
+ def get_helpdesk_call_summarization_spec() -> RunSpec:
157
+ scenario_spec = ScenarioSpec(
158
+ class_name="helm.benchmark.scenarios.helpdesk_call_summarization_scenario.HelpdeskCallSummarizationScenario",
159
+ )
160
+ annotator_specs = annotator_specs = [
161
+ AnnotatorSpec(
162
+ class_name="helm.benchmark.annotation.helpdesk_call_summarization_annotator.HelpdeskCallSummarizationAnnotator" # noqa: E501
163
+ )
164
+ ]
165
+
166
+ instructions = "The following is a call transcript of a call between a compnay's employee and the company's IT helpdesk. Summarize the call transcript in under 200 words." # noqa: E501
167
+
168
+ adapter_spec = AdapterSpec(
169
+ method=ADAPT_GENERATION,
170
+ instructions=instructions,
171
+ input_prefix="### Call Transcript\n",
172
+ input_suffix="",
173
+ output_prefix="",
174
+ output_suffix="",
175
+ max_train_instances=0,
176
+ temperature=0.0,
177
+ max_tokens=512,
178
+ num_outputs=1,
179
+ )
180
+
181
+ # annotator_specs = annotator_specs = [
182
+ # AnnotatorSpec(class_name="helm.benchmark.annotation.call_center_annotator.CallCenterSummarizationAnnotator")
183
+ # ]
184
+ annotation_metric_specs = [
185
+ MetricSpec(
186
+ class_name="helm.benchmark.metrics.helpdesk_call_summarization_metrics.HelpdeskCallSummarizationMetric",
187
+ ),
188
+ ]
189
+
190
+ metric_specs = get_basic_metric_specs([]) + annotation_metric_specs
191
+
192
+ group = "helpdesk_call_summarization"
193
+
194
+ return RunSpec(
195
+ name="helpdesk_call_summarization",
196
+ scenario_spec=scenario_spec,
197
+ adapter_spec=adapter_spec,
198
+ metric_specs=metric_specs,
199
+ annotators=annotator_specs,
200
+ groups=[group],
201
+ )