File size: 20,478 Bytes
5006d94
1
2
{"cells":[{"cell_type":"code","execution_count":1,"metadata":{"executionInfo":{"elapsed":476,"status":"ok","timestamp":1720679526275,"user":{"displayName":"HUANG DONGHAO _","userId":"00977795705617022768"},"user_tz":-480},"id":"uWKRSV6eZsCn"},"outputs":[],"source":["%load_ext autoreload\n","%autoreload 2"]},{"cell_type":"code","execution_count":2,"metadata":{"application/vnd.databricks.v1+cell":{"cellMetadata":{"byteLimit":2048000,"rowLimit":10000},"inputWidgets":{},"nuid":"eb33b19f-1206-41ee-84e2-e6258a12eef7","showTitle":false,"title":""},"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":2534,"status":"ok","timestamp":1720679529344,"user":{"displayName":"HUANG DONGHAO _","userId":"00977795705617022768"},"user_tz":-480},"id":"xwFh14uiZBrI","outputId":"d767799c-34c2-46a5-f052-378146a55321"},"outputs":[],"source":["from pathlib import Path\n","\n","try:\n","    from google.colab import drive\n","\n","    drive.mount(\"/content/drive\")\n","    workding_dir = \"/content/drive/MyDrive/logical-reasoning/\"\n","except ModuleNotFoundError:\n","    workding_dir = str(Path.cwd().parent)"]},{"cell_type":"code","execution_count":3,"metadata":{"application/vnd.databricks.v1+cell":{"cellMetadata":{"byteLimit":2048000,"rowLimit":10000},"inputWidgets":{},"nuid":"6d394937-6c99-4a7c-9d32-7600a280032f","showTitle":false,"title":""},"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":5,"status":"ok","timestamp":1720679529345,"user":{"displayName":"HUANG DONGHAO _","userId":"00977795705617022768"},"user_tz":-480},"id":"G5pNu3zgZBrL","outputId":"160a554f-fb08-4aa0-bc00-0422fb7c1fac"},"outputs":[{"name":"stdout","output_type":"stream","text":["workding dir: /Users/inflaton/code/engd/projects/logical-reasoning\n"]}],"source":["import os\n","import sys\n","from pathlib import Path\n","\n","os.chdir(workding_dir)\n","sys.path.append(workding_dir)\n","print(\"workding dir:\", workding_dir)"]},{"cell_type":"code","execution_count":4,"metadata":{"application/vnd.databricks.v1+cell":{"cellMetadata":{"byteLimit":2048000,"rowLimit":10000},"inputWidgets":{},"nuid":"9f67ec60-2f24-411c-84eb-0dd664b44775","showTitle":false,"title":""},"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":3,"status":"ok","timestamp":1720679529345,"user":{"displayName":"HUANG DONGHAO _","userId":"00977795705617022768"},"user_tz":-480},"id":"hPCC-6m7ZBrM","outputId":"c7aa2c96-5e99-440a-c148-201d79465ff9"},"outputs":[{"name":"stdout","output_type":"stream","text":["loading env vars from: /Users/inflaton/code/engd/projects/logical-reasoning/.env\n"]},{"data":{"text/plain":["True"]},"execution_count":4,"metadata":{},"output_type":"execute_result"}],"source":["from dotenv import find_dotenv, load_dotenv\n","\n","found_dotenv = find_dotenv(\".env\")\n","\n","if len(found_dotenv) == 0:\n","    found_dotenv = find_dotenv(\".env.example\")\n","print(f\"loading env vars from: {found_dotenv}\")\n","load_dotenv(found_dotenv, override=True)"]},{"cell_type":"code","execution_count":5,"metadata":{"application/vnd.databricks.v1+cell":{"cellMetadata":{"byteLimit":2048000,"rowLimit":10000},"inputWidgets":{},"nuid":"f1597656-8042-4878-9d3b-9ebfb8dd86dc","showTitle":false,"title":""},"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":3,"status":"ok","timestamp":1720679529345,"user":{"displayName":"HUANG DONGHAO _","userId":"00977795705617022768"},"user_tz":-480},"id":"1M3IraVtZBrM","outputId":"29ab35f6-2970-4ade-d85d-3174acf8cda0"},"outputs":[{"name":"stdout","output_type":"stream","text":["llama-factory/merged_models/internlm2_5-7b-chat-1m_sft_bf16_p2_full None False datasets/mgtv results/mgtv-results_merged_model.csv\n"]}],"source":["import os\n","\n","model_name = os.getenv(\"MODEL_NAME\")\n","adapter_name_or_path = os.getenv(\"ADAPTER_NAME_OR_PATH\")\n","load_in_4bit = os.getenv(\"LOAD_IN_4BIT\") == \"true\"\n","data_path = os.getenv(\"LOGICAL_REASONING_DATA_PATH\")\n","results_path = os.getenv(\"LOGICAL_REASONING_RESULTS_PATH\")\n","use_english_datasets = os.getenv(\"USE_ENGLISH_DATASETS\") == \"true\"\n","\n","\n","print(model_name, adapter_name_or_path, load_in_4bit, data_path, results_path)"]},{"cell_type":"code","execution_count":6,"metadata":{"application/vnd.databricks.v1+cell":{"cellMetadata":{"byteLimit":2048000,"rowLimit":10000},"inputWidgets":{},"nuid":"b2a43943-9324-4839-9a47-cfa72de2244b","showTitle":false,"title":""},"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":564,"status":"ok","timestamp":1720679529907,"user":{"displayName":"HUANG DONGHAO _","userId":"00977795705617022768"},"user_tz":-480},"id":"UgMvt6dIZBrM","outputId":"ce37581c-fd26-46c2-ad87-d933d99f68f7"},"outputs":[{"name":"stdout","output_type":"stream","text":["Python 3.11.9\n","\u001b[33mWARNING: Package(s) not found: flash-attn\u001b[0m\u001b[33m\n","\u001b[0mCPU times: user 3.75 ms, sys: 6.43 ms, total: 10.2 ms\n","Wall time: 710 ms\n"]}],"source":["%%time\n","!python --version\n","!pip show flash-attn"]},{"cell_type":"code","execution_count":7,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":1685,"status":"ok","timestamp":1720679531591,"user":{"displayName":"HUANG DONGHAO _","userId":"00977795705617022768"},"user_tz":-480},"id":"ZuS_FsLyZBrN","outputId":"2cba0105-c505-4395-afbd-2f2fee6581d0"},"outputs":[{"name":"stdout","output_type":"stream","text":["loading /Users/inflaton/code/engd/projects/logical-reasoning/llm_toolkit/logical_reasoning_utils.py\n","MPS is available\n"]}],"source":["from llm_toolkit.llm_utils import *\n","from llm_toolkit.logical_reasoning_utils import *\n","\n","device = check_gpu()"]},{"cell_type":"code","execution_count":8,"metadata":{},"outputs":[{"name":"stderr","output_type":"stream","text":["Special tokens have been added in the vocabulary, make sure the associated word embeddings are fine-tuned or trained.\n"]},{"name":"stdout","output_type":"stream","text":["loading model: llama-factory/merged_models/internlm2_5-7b-chat-1m_sft_bf16_p2_full\n"]},{"data":{"application/vnd.jupyter.widget-view+json":{"model_id":"ec3b6439270240d6a057e324cd55fb02","version_major":2,"version_minor":0},"text/plain":["Loading checkpoint shards:   0%|          | 0/8 [00:00<?, ?it/s]"]},"metadata":{},"output_type":"display_data"},{"name":"stdout","output_type":"stream","text":["CPU times: user 810 ms, sys: 3.84 s, total: 4.65 s\n","Wall time: 24.4 s\n"]}],"source":["%%time\n","\n","model, tokenizer = load_model(model_name)"]},{"cell_type":"code","execution_count":9,"metadata":{},"outputs":[{"name":"stdout","output_type":"stream","text":["loading train/test data files\n","DatasetDict({\n","    train: Dataset({\n","        features: ['text', 'label', 'answer', 'title', 'puzzle', 'truth', 'train_text', 'prompt'],\n","        num_rows: 25000\n","    })\n","    test: Dataset({\n","        features: ['text', 'label', 'answer', 'title', 'puzzle', 'truth', 'train_text', 'prompt'],\n","        num_rows: 3000\n","    })\n","})\n"]}],"source":["datasets = load_logical_reasoning_dataset(\n","    data_path,\n","    tokenizer=tokenizer,\n","    chinese_prompt=not use_english_datasets,\n","    using_p1=False,\n",")"]},{"cell_type":"code","execution_count":10,"metadata":{},"outputs":[{"name":"stdout","output_type":"stream","text":["<s><|im_start|>system\n","You are an expert in logical reasoning.<|im_end|>\n","<|im_start|>user\n","你是一个情景猜谜游戏的主持人。游戏规则如下:\n","\n","1. 参与者会得到一个谜面,谜面会描述一个简单又难以理解的事件。\n","2. 主持人知道谜底,谜底是谜面的答案。\n","3. 参与者可以询问任何封闭式问题来找寻事件的真相。\n","4. 对于每个问题,主持人将根据实际情况回答以下五个选项之一:是、不是、不重要、回答正确、问法错误。各回答的判断标准如下:\n","   - 若谜面和谜底能找到问题的答案,回答:是或者不是\n","   - 若谜面和谜底不能直接或者间接推断出问题的答案,回答:不重要\n","   - 若参与者提问不是一个封闭式问题或者问题难以理解,回答:问法错误\n","   - 若参与者提问基本还原了谜底真相,回答:回答正确\n","5. 回答中不能添加任何其它信息,也不能省略选项中的任何一个字。例如,不可以把“不是”省略成“不”。\n","\n","请严格按照这些规则回答参与者提出的问题。\n","\n","**谜面:** 在一个安静的夜晚,小村庄的湖边突然传来了阵阵哭泣声。第二天早晨,村长甄锐发现湖边的石头上放着一顶破旧的帽子,但没有人知道这顶帽子是从哪里来的,哭泣声又是为何。请还原故事真相。\n","\n","**谜底:** 原来,这顶破旧的帽子属于一个小男孩,他小时候与爷爷在湖边生活。爷爷教他钓鱼、游泳,还告诉他湖中的海龟是他们的朋友。后来,小男孩随父母去了城市生活,但每年夏天都会回到村子探望爷爷。然而,去年夏天,爷爷因病去世,小男孩伤心欲绝。今年夏天,他回到村子,来到湖边,想起和爷爷的美好回忆,忍不住哭泣。他将爷爷的帽子放在湖边的石头上,希望能让爷爷的在天之灵得到安慰。那晚的哭泣声正是小男孩在祭莫他亲爱的爷爷。\n","\n","**参与者提出的问题:** 哭泣和村庄有关系吗\n","<|im_end|>\n","<|im_start|>assistant\n","\n","----------------------------------------\n","<s><s><|im_start|>system\n","You are an expert in logical reasoning.<|im_end|>\n","<|im_start|>user\n","你是一个情景猜谜游戏的主持人。游戏规则如下:\n","\n","1. 参与者会得到一个谜面,谜面会描述一个简单又难以理解的事件。\n","2. 主持人知道谜底,谜底是谜面的答案。\n","3. 参与者可以询问任何封闭式问题来找寻事件的真相。\n","4. 对于每个问题,主持人将根据实际情况回答以下五个选项之一:是、不是、不重要、回答正确、问法错误。各回答的判断标准如下:\n","   - 若谜面和谜底能找到问题的答案,回答:是或者不是\n","   - 若谜面和谜底不能直接或者间接推断出问题的答案,回答:不重要\n","   - 若参与者提问不是一个封闭式问题或者问题难以理解,回答:问法错误\n","   - 若参与者提问基本还原了谜底真相,回答:回答正确\n","5. 回答中不能添加任何其它信息,也不能省略选项中的任何一个字。例如,不可以把“不是”省略成“不”。\n","\n","请严格按照这些规则回答参与者提出的问题。\n","\n","**谜面:** 在一个安静的夜晚,小村庄的湖边突然传来了阵阵哭泣声。第二天早晨,村长甄锐发现湖边的石头上放着一顶破旧的帽子,但没有人知道这顶帽子是从哪里来的,哭泣声又是为何。请还原故事真相。\n","\n","**谜底:** 原来,这顶破旧的帽子属于一个小男孩,他小时候与爷爷在湖边生活。爷爷教他钓鱼、游泳,还告诉他湖中的海龟是他们的朋友。后来,小男孩随父母去了城市生活,但每年夏天都会回到村子探望爷爷。然而,去年夏天,爷爷因病去世,小男孩伤心欲绝。今年夏天,他回到村子,来到湖边,想起和爷爷的美好回忆,忍不住哭泣。他将爷爷的帽子放在湖边的石头上,希望能让爷爷的在天之灵得到安慰。那晚的哭泣声正是小男孩在祭莫他亲爱的爷爷。\n","\n","**参与者提出的问题:** 哭泣和村庄有关系吗\n","<|im_end|>\n","<|im_start|>assistant\n","是</s>\n","CPU times: user 532 ms, sys: 237 ms, total: 769 ms\n","Wall time: 1.87 s\n"]}],"source":["%%time\n","\n","prompt1 = datasets[\"test\"][\"prompt\"][1000]\n","print(prompt1)\n","print(\"--\" * 20)\n","test_model(model, tokenizer, prompt1, device=device)"]},{"cell_type":"code","execution_count":11,"metadata":{},"outputs":[{"name":"stderr","output_type":"stream","text":[" 12%|█▎        | 1/8 [00:02<00:17,  2.47s/it]"]},{"name":"stdout","output_type":"stream","text":["--------\n","step 1: 不是</s>\n","--------\n","step 2: 不是\n","--------\n","step 3: 不是\n","--------\n","step 4: 不是\n","--------\n","step 5: 不是\n"]},{"name":"stderr","output_type":"stream","text":["100%|██████████| 8/8 [00:16<00:00,  2.09s/it]"]},{"name":"stdout","output_type":"stream","text":["CPU times: user 1.51 s, sys: 296 ms, total: 1.8 s\n","Wall time: 16.7 s\n"]},{"name":"stderr","output_type":"stream","text":["\n"]},{"data":{"text/plain":["['不是', '是', '是', '是', '不是', '是', '不重要', '不是']"]},"execution_count":11,"metadata":{},"output_type":"execute_result"}],"source":["%%time\n","\n","eval_model(model, tokenizer, datasets[\"test\"][:10], device=device)"]},{"cell_type":"code","execution_count":12,"metadata":{"id":"L370pvGTZBrN"},"outputs":[],"source":["def evaluate_model(model, tokenizer, model_name, dataset):\n","    print(\"Evaluating model: \" + model_name)\n","    predictions = eval_model(model, tokenizer, dataset, device=device)\n","\n","    model_name += \"_M3\"\n","\n","    save_results(\n","        model_name,\n","        results_path,\n","        dataset,\n","        predictions,\n","        debug=True,\n","    )\n","\n","    metrics = calc_metrics(dataset[\"label\"], predictions, debug=True)\n","    print(metrics)"]},{"cell_type":"code","execution_count":13,"metadata":{"id":"WUFjhxmiZBrN"},"outputs":[{"name":"stdout","output_type":"stream","text":["Evaluating model: llama-factory/merged_models/internlm2_5-7b-chat-1m_sft_bf16_p2_full\n"]},{"name":"stderr","output_type":"stream","text":["  0%|          | 1/3000 [00:01<1:39:04,  1.98s/it]"]},{"name":"stdout","output_type":"stream","text":["--------\n","step 1: 不是</s>\n","--------\n","step 2: 不是\n","--------\n","step 3: 不是\n","--------\n","step 4: 不是\n","--------\n","step 5: 不是\n"]},{"name":"stderr","output_type":"stream","text":["100%|██████████| 3000/3000 [6:43:24<00:00,  8.07s/it]     "]},{"name":"stdout","output_type":"stream","text":["      text label title                                             puzzle  \\\n","0  甄加索是自杀吗    不是  海岸之谜  在远离城市喧嚣的海边小屋,一天清晨,邻居发现甄加索僵卧在沙滩上,已无生命迹象。现场没有发现任...   \n","\n","                                               truth  \\\n","0  甄加索是一位热爱自然的画家,他每年都会来到这个海边小屋寻找灵感。在他生命的最后几天,他一直在...   \n","\n","  llama-factory/merged_models/internlm2_5-7b-chat-1m_sft_bf16_p2_full_epoch_6_NV4080  \\\n","0                                                 不是                                   \n","\n","  llama-factory/merged_models/internlm2_5-7b-chat-1m_sft_bf16_p2_full_epoch_6_M3  \\\n","0                                                 不是                               \n","\n","  llama-factory/merged_models/internlm2_5-7b-chat-1m_sft_bf16_p2_full_NV4080  \\\n","0                                                 不是                           \n","\n","  llama-factory/merged_models/internlm2_5-7b-chat-1m_sft_bf16_p2_full_M3  \n","0                                                 不是                      \n","{'accuracy': 0.7853333333333333, 'incorrect_ids': [9, 24, 29, 31, 34, 36, 55, 58, 59, 61, 65, 66, 67, 78, 81, 82, 83, 88, 91, 93, 96, 99, 103, 104, 106, 112, 117, 121, 128, 129, 135, 137, 138, 139, 143, 149, 150, 153, 155, 161, 164, 170, 173, 179, 190, 199, 200, 202, 218, 222, 224, 228, 236, 245, 250, 252, 259, 260, 269, 271, 275, 276, 284, 286, 299, 304, 314, 317, 318, 321, 323, 330, 334, 335, 337, 338, 346, 350, 353, 355, 356, 360, 361, 368, 370, 371, 373, 377, 383, 386, 389, 395, 397, 410, 414, 416, 428, 429, 430, 432, 438, 445, 447, 450, 452, 454, 456, 457, 458, 465, 471, 472, 476, 479, 480, 490, 492, 493, 494, 495, 497, 501, 502, 506, 507, 508, 510, 511, 514, 517, 518, 519, 520, 530, 536, 540, 560, 566, 570, 571, 579, 581, 589, 591, 593, 596, 597, 601, 612, 613, 614, 621, 622, 625, 628, 632, 636, 644, 647, 666, 671, 682, 690, 695, 701, 702, 708, 720, 721, 727, 729, 730, 734, 740, 754, 758, 766, 770, 772, 774, 778, 788, 791, 794, 795, 798, 799, 801, 803, 805, 809, 817, 818, 819, 820, 821, 823, 824, 826, 828, 837, 840, 844, 847, 856, 859, 861, 862, 866, 869, 870, 875, 889, 890, 899, 904, 913, 927, 935, 937, 942, 945, 952, 958, 962, 964, 966, 969, 970, 980, 989, 991, 994, 998, 1001, 1003, 1005, 1006, 1007, 1011, 1012, 1014, 1015, 1019, 1022, 1036, 1038, 1040, 1043, 1051, 1053, 1057, 1069, 1071, 1075, 1076, 1077, 1080, 1083, 1087, 1089, 1091, 1096, 1107, 1108, 1120, 1125, 1126, 1129, 1138, 1160, 1161, 1166, 1167, 1172, 1173, 1174, 1178, 1180, 1181, 1183, 1185, 1198, 1203, 1212, 1228, 1232, 1239, 1240, 1241, 1251, 1252, 1254, 1258, 1259, 1266, 1282, 1289, 1300, 1305, 1308, 1311, 1313, 1315, 1317, 1324, 1331, 1337, 1339, 1342, 1346, 1349, 1353, 1363, 1364, 1367, 1385, 1387, 1388, 1389, 1391, 1392, 1393, 1395, 1400, 1406, 1409, 1417, 1420, 1422, 1426, 1440, 1444, 1451, 1453, 1454, 1455, 1459, 1462, 1469, 1476, 1478, 1486, 1490, 1493, 1494, 1496, 1501, 1504, 1512, 1517, 1518, 1525, 1526, 1533, 1544, 1547, 1554, 1559, 1560, 1562, 1580, 1585, 1590, 1593, 1594, 1603, 1604, 1605, 1613, 1622, 1627, 1633, 1637, 1641, 1645, 1647, 1648, 1650, 1654, 1655, 1658, 1659, 1668, 1669, 1672, 1673, 1674, 1676, 1679, 1683, 1686, 1690, 1691, 1695, 1712, 1716, 1718, 1721, 1726, 1727, 1734, 1736, 1751, 1755, 1756, 1780, 1786, 1791, 1796, 1798, 1812, 1816, 1827, 1835, 1841, 1854, 1858, 1860, 1867, 1869, 1877, 1879, 1888, 1897, 1914, 1945, 1953, 1958, 1963, 1964, 1971, 1973, 1978, 1981, 1984, 1989, 1990, 1991, 1992, 1994, 1995, 2001, 2017, 2021, 2028, 2035, 2036, 2049, 2054, 2062, 2064, 2067, 2070, 2072, 2076, 2077, 2092, 2100, 2106, 2109, 2110, 2112, 2118, 2119, 2120, 2121, 2126, 2133, 2139, 2141, 2147, 2159, 2161, 2162, 2164, 2167, 2169, 2172, 2174, 2177, 2181, 2185, 2186, 2188, 2192, 2193, 2194, 2195, 2197, 2208, 2212, 2222, 2223, 2226, 2230, 2233, 2237, 2240, 2243, 2247, 2249, 2250, 2257, 2262, 2265, 2274, 2278, 2281, 2285, 2297, 2304, 2311, 2312, 2313, 2317, 2320, 2322, 2324, 2330, 2333, 2335, 2339, 2344, 2348, 2360, 2364, 2366, 2378, 2389, 2395, 2396, 2400, 2404, 2409, 2410, 2420, 2423, 2425, 2429, 2437, 2440, 2442, 2454, 2463, 2469, 2484, 2488, 2511, 2512, 2515, 2517, 2522, 2529, 2530, 2532, 2535, 2538, 2539, 2546, 2547, 2548, 2549, 2555, 2556, 2559, 2560, 2562, 2574, 2575, 2589, 2590, 2616, 2626, 2629, 2632, 2644, 2660, 2663, 2667, 2676, 2678, 2707, 2714, 2716, 2731, 2736, 2742, 2744, 2745, 2746, 2749, 2754, 2757, 2762, 2764, 2766, 2777, 2788, 2791, 2797, 2798, 2801, 2803, 2806, 2807, 2812, 2815, 2816, 2820, 2823, 2837, 2843, 2854, 2857, 2860, 2861, 2870, 2877, 2880, 2882, 2884, 2888, 2899, 2902, 2905, 2912, 2913, 2915, 2916, 2921, 2927, 2933, 2938, 2939, 2944, 2949, 2953, 2975, 2977, 2979, 2985, 2995, 2998]}\n","CPU times: user 8min 27s, sys: 12min 7s, total: 20min 35s\n","Wall time: 6h 43min 24s\n"]},{"name":"stderr","output_type":"stream","text":["\n"]},{"ename":"","evalue":"","output_type":"error","traceback":["\u001b[1;31mThe Kernel crashed while executing code in the current cell or a previous cell. \n","\u001b[1;31mPlease review the code in the cell(s) to identify a possible cause of the failure. \n","\u001b[1;31mClick <a href='https://aka.ms/vscodeJupyterKernelCrash'>here</a> for more info. \n","\u001b[1;31mView Jupyter <a href='command:jupyter.viewOutput'>log</a> for further details."]}],"source":["%%time\n","\n","evaluate_model(model, tokenizer, model_name, datasets[\"test\"])"]}],"metadata":{"accelerator":"GPU","application/vnd.databricks.v1+notebook":{"dashboards":[],"environmentMetadata":null,"language":"python","notebookMetadata":{"mostRecentlyExecutedCommandWithImplicitDF":{"commandId":-1,"dataframes":["_sqldf"]},"pythonIndentUnit":4},"notebookName":"10_eval-lf-medium-py3.11","widgets":{}},"colab":{"gpuType":"L4","provenance":[]},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"codemirror_mode":{"name":"ipython","version":3},"file_extension":".py","mimetype":"text/x-python","name":"python","nbconvert_exporter":"python","pygments_lexer":"ipython3","version":"3.11.9"}},"nbformat":4,"nbformat_minor":0}