{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import re\n",
    "import time\n",
    "from vllm import LLM, SamplingParams\n",
    "\n",
    "# 读取JSON文件\n",
    "def read_json(file_path):\n",
    "    with open(file_path, 'r') as file:\n",
    "        return json.load(file)\n",
    "\n",
    "# 解析output_blocks中特定类型的条目\n",
    "def parse_blocks(output_blocks, type):\n",
    "    type_to_block = {}\n",
    "    pattern = rf\"{type} (\\d+)\"  # 假设类型后的数字仍有用，例如标识ID或序号\n",
    "    for block in output_blocks:\n",
    "        match = re.search(pattern, block)\n",
    "        if match:\n",
    "            identifier = int(match.group(1))  # 获取类型后的数字\n",
    "            type_to_block[identifier] = block\n",
    "    return type_to_block\n",
    "\n",
    "# 生成检查内容的prompt\n",
    "def create_prompts(checks, type_to_block):\n",
    "    prompts = []\n",
    "    for identifier, event_desc in checks.items():\n",
    "        identifier = int(identifier)  # 确保转换为整数\n",
    "        if identifier in type_to_block:\n",
    "            prompts.append(type_to_block[identifier] + f\" Does this description include the {event_desc}? Please answer with 'yes' or 'no' only.\")\n",
    "    return prompts\n",
    "\n",
    "# 主函数\n",
    "\n",
    "file_path = \"/home/yuhao/THREADING-THE-NEEDLE/Evalution/results.json\"\n",
    "datas = read_json(file_path)\n",
    "prompts_once = []\n",
    "prompts_range = []\n",
    "prompts_periodic = []\n",
    "for data in datas:\n",
    "    checks_block = parse_blocks(data['output_blocks'], data['type'])\n",
    "    # 生成once, range, periodic的prompts\n",
    "    prompts_once.extend(create_prompts(data['checks_once'], checks_block))\n",
    "    prompts_range.extend(create_prompts(data['checks_range'], checks_block))\n",
    "    prompts_periodic.extend(create_prompts(data['checks_periodic'], checks_block))\n",
    "\n",
    "    # 在此处可以添加代码处理prompts，例如发送到模型或存储结果\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[\" Week 13 (March 26th - April 1st)\\nI'm excited to finally get away from it all and take a break. This week, I'm heading to Cambodia to explore the ancient temples. It's going to be a fantastic adventure, and I'm looking forward to immersing myself in the culture and history.\\n\\n Does this description include the Exploring the ancient temples of Cambodia? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 14 (April 2nd - April 8th)\\nI'm still in Cambodia, and it's been an incredible experience so far. I've seen some breathtaking temples and learned so much about the history and culture of the area. It's been a real privilege to be here. Nothing much else happened this week.\\n\\n Does this description include the Exploring the ancient temples of Cambodia? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 11 (March 12th - March 18th)\\nExcitement this week as we embarked on an adventure to explore the ancient temples of Cambodia! It was an incredible experience, and I'm so grateful for the opportunity to see such incredible history and culture. We spent our days exploring the temples, learning about the history, and soaking up the atmosphere. No birthdays this week, but we're making the most of our travels.\\n\\n\\n Does this description include the Exploring the ancient temples of Cambodia? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 12 (March 19th - March 25th)\\nWe continued our adventure in Cambodia, exploring more temples and learning about the local culture. It was a truly enriching experience, and I'm so grateful for the opportunity to see such incredible history and architecture. We met some amazing people along the way, and even tried some local cuisine. No birthdays this week, but we're enjoying every moment of our travels.\\n\\n\\n Does this description include the Exploring the ancient temples of Cambodia? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 22 (May 28th - June 3rd)\\n\\nAva attends the family yoga retreat, surrounded by loved ones and shared experiences. This week is a testament to Ava's dedication to their family and their commitment to nurturing meaningful connections.\\n\\n Does this description include the Participating in a family yoga retreat? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 23 (June 4th - June 10th)\\n\\nThe family yoga retreat has come to an end, and Ava is still basking in the glow of the experience. The absence of birthdays or significant events allows Ava to stay in a state of contentment, reflecting on the memories forged during the retreat.\\n\\n Does this description include the Participating in a family yoga retreat? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 11 (March 12th - March 18th)\\nThis week was significant as I participated in the martial arts training camp in China. It was an incredible experience, allowing me to connect with like-minded individuals and improve my skills. I made new friends and was grateful for the opportunity to expand my horizons.\\n\\n Does this description include the Participating in a martial arts training camp in China? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 12 (March 19th - March 25th)\\nFollowing the martial arts training camp, I returned home and was welcomed back by my loving family. I reviewed notes from the camp and began planning the next steps in my martial arts journey. I spent time adjusting back to family life, catching up on work projects and reconnecting with loved ones.\\n\\n Does this description include the Participating in a martial arts training camp in China? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 16 (April 16th - April 22nd)\\n\\nThis week was a bit of a milestone. I participated in a week-long photography workshop! It was an incredible experience, and I'm still processing all that I learned. Feeling inspired and motivated.\\n\\n Does this description include the Participating in a week-long photography workshop? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 17 (April 23rd - April 29th)\\n\\nWeek 17 has been a bit of a challenge, to be honest. I had a few health issues, which kept me from doing much. On a more positive note, I did manage to get some rest and focus on self-care. Feeling grateful for my body's resilience.\\n\\n Does this description include the Participating in a week-long photography workshop? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 50 (December 10th - December 16th)\\nI've been keeping busy with historical research and family birthday preparations. I've also been reading more about historical accounts of the fjords of Norway, planning my trip for weeks 51. On a personal note, I've been reflecting on the importance of family and the joy of celebrating these special days.\\n\\n Does this description include the Exploring the fjords of Norway by kayak? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 51 (December 17th - December 23rd)\\nThis week has been about finalizing my research on historical expeditions to the fjords of Norway. I've found some inspiring stories that have motivated me to plan my own trip. I've also been thinking about the upcoming historical walking tour and the new historical insights I'll gain from it.\\n\\n Does this description include the Exploring the fjords of Norway by kayak? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 44 (October 29th - November 4th)\\n\\nIt's finally here – our film production workshop! I'm excited to learn from industry experts and network with like-minded individuals. I've been preparing for weeks, and I'm ready to dive in and learn as much as I can. This is going to be an incredible experience, and I'm grateful for the opportunity.\\n\\n Does this description include the Participating in a week-long film production workshop? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 45 (November 5th - November 11th)\\n\\nA week filled with excitement – we're in the midst of our film production workshop, and I'm learning so much. I've been attending seminars, watching screenings, and networking with industry professionals. It's an incredible experience, and I'm grateful for the opportunity to be a part of it.\\n\\n Does this description include the Participating in a week-long film production workshop? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 19 (May 7th - May 13th)\\nMy child_1 participated in their first soccer camp, and we were all so proud of them! I managed to squeeze in some writing on the weekends, and it's been helpful in clarifying my thoughts. Our running club's workouts have been pushing me to new heights, and I'm feeling great about it. We're looking forward to more family time and adventures together.\\n\\n Does this description include the Participating in a children's sports camp for soccer? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 20 (May 14th - May 20th)\\nIt was a wonderful week, as we celebrated my child_2's birthday with friends and family. My child_2 started kindergarten this week, and we're all adjusting to the new routine. I had a great meeting with a client on Monday, where we finalized the plans for their new home. Our family has been enjoying the warmer weather, and it's been great to spend more time outdoors.\\n\\n Does this description include the Participating in a children's sports camp for soccer? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 45 (November 5th - November 11th)\\n\\nI'm getting more excited about the jazz festival every day! I've been practicing my photography skills and learning more about lighting and composition. Did some research on the best camera settings for capturing the festival. Also, I started working on a project to capture the best markets in the city. I'm planning to attend the jazz festival in Montreal.\\n\\n Does this description include the Attending a week-long jazz festival in Montreal? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 46 (November 12th - November 18th)\\n\\nI'm in Montreal, and I'm attending the jazz festival! I've been capturing some amazing photos of the festival, and I'm so grateful to be here. The photo of the week: a stunning interior shot of a jazz club.\\n\\n Does this description include the Attending a week-long jazz festival in Montreal? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 33 (August 13th - August 19th)\\nThis week was a bit challenging because I went to the surfing camp in Hawaii. I was so caught up in the surfing lessons that I forgot to take some pictures for my wife and kids.\\n\\n\\n Does this description include the Participating in a surfing camp in Hawaii? Please answer with 'yes' or 'no' only.\",\n",
       " \" Week 34 (August 20th - August 26th)\\nAfter coming back from Hawaii, I was feeling quite refreshed. We went out for dinner and had a lovely family time. The kids were a bit excited about their upcoming school projects.\\n\\n\\n Does this description include the Participating in a surfing camp in Hawaii? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 33\\n{This floor is allocated to a hospital, featuring a range of medical services and facilities. The floor includes a dedicated ER department, an ICU, and various specialist clinics. A comprehensive library with a vast collection of medical books and resources is available for staff and patients. Regular medical seminars and workshops are conducted here, focusing on the latest medical advancements and treatments.}\\n\\n Does this description include the hospital with various departments? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 34\\n{The thirty-fourth floor is allocated to the hospital's radiology department, featuring state-of-the-art imaging equipment and a team of experienced radiologists. Regular imaging services, such as X-rays, CT scans, and MRI scans, are conducted here. A comprehensive library with a vast collection of medical imaging books and resources is available for staff and patients. The floor also includes a dedicated patient lounge area, perfect for relaxation and recovery.}\\n\\n Does this description include the hospital with various departments? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 35\\n{This floor is allocated to the hospital's laboratory department, featuring state-of-the-art laboratory equipment and a team of experienced laboratory technicians. Regular laboratory tests and analyses are conducted here, providing critical diagnostic information for medical professionals. A comprehensive library with a vast collection of medical laboratory books and resources is available for staff and patients. The floor also includes a dedicated patient lounge area, perfect for relaxation and recovery.}\\n\\n Does this description include the hospital with various departments? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 36\\n{The thirty-sixth floor is allocated to the hospital's surgery department, featuring state-of-the-art operating theaters and a team of experienced surgeons. Regular surgical procedures are conducted here, including elective and emergency surgeries. A comprehensive library with a vast collection of medical surgery books and resources is available for staff and patients. The floor also includes a dedicated patient recovery area, perfect for post-operative care and rehabilitation.}\\n\\n Does this description include the hospital with various departments? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 37\\n{This floor is allocated to the hospital's pediatric department, featuring a range of medical services and facilities specifically designed for children. The floor includes a dedicated pediatric ER department, pediatric clinics, and a range of children's play areas and amenities. A comprehensive library with a vast collection of pediatric medical books and resources is available for staff and patients. Regular medical seminars and workshops are conducted here, focusing on the latest pediatric medical advancements and treatments.}\\n\\n Does this description include the hospital with various departments? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 1-14\\nThese floors feature state-of-the-art research facilities, cutting-edge equipment, and a collaborative working environment. They house advanced research and academic institutions, fostering interdisciplinary learning and innovation.\\n\\n Does this description include the advanced technology and research institute? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 2\\nThis floor is an extension of the advanced research institute on Floor 1. It will host state-of-the-art nanotechnology labs, offering exceptional capabilities for testing and development in nanoscale materials and systems. This floor will be home to the Physics Department, which will undertake various experiments, simulations, and experiments in nanotechnology.\\nComplementing the research activities will be cutting-edge instrumentation workshops equipped with precision machinery, along with specially designed, sealed laboratories for testing experimental components. Enhanced safety features and high-capacity waste management systems ensure compliance with rigorous regulatory standards.\\n\\n Does this description include the advanced technology and research institute? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 3\\nThe third floor will house the Institute's vibrant social hub, fostering connections and relaxation for its members and staff. Comfortable lounge areas surrounded by transparent partitions will create spaces for spontaneous interactions. Various well-equipped facilities will support learning and development, including an 80-seat auditorium for workshops, lectures, and seminars. Informal, participatory library areas with reader-friendly designs cater to both the scholarly community and visiting researchers.\\nEducational video conferencing rooms with minimal background noise and impressive A/V equipment will be at the heart of this floor, facilitating seamless collaboration with institutions worldwide.\\n\\n Does this description include the advanced technology and research institute? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 4\\nThis floor will be dedicated to detailed digital fabrication facilities, allowing researchers to model, design, and construct intricate objects and prototypes at the micro-scale. An outstanding range of specialized equipment will enable significant productivity gains, as well as significant reductions in project timeframes and production costs. Exceptional practical workplace efficiency, vast storage options and state-of-the-art tool collection will enhance end-to-end productivity and operational workflows.\\n\\n Does this description include the advanced technology and research institute? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 37: Hospital (Department of Internal Medicine)\\n\\nThe Department of Internal Medicine is located on Floor 37, offering a comprehensive range of medical services. The department is equipped with state-of-the-art medical equipment, including digital X-ray machines and ultrasound technology. The department features a spacious waiting area, a reception desk, and several exam rooms. The department's staff includes experienced doctors, nurses, and support staff.\\n\\n Does this description include the hospital with various departments? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 38: Hospital (Department of Surgery)\\n\\nThe Department of Surgery is situated on Floor 38, offering a comprehensive range of surgical services. The department is equipped with state-of-the-art surgical equipment, including laparoscopic and robotic surgery systems. The department features a spacious operating theater, a recovery room, and several post-operative care areas. The department's staff includes experienced surgeons, nurses, and support staff.\\n\\n Does this description include the hospital with various departments? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 39: Hospital (Department of Obstetrics and Gynecology)\\n\\nThe Department of Obstetrics and Gynecology is located on Floor 39, offering a comprehensive range of maternity and gynecological services. The department is equipped with state-of-the-art medical equipment, including fetal monitoring systems and ultrasound technology. The department features a spacious labor and delivery area, a nursery, and several exam rooms. The department's staff includes experienced doctors, nurses, and support staff.\\n\\n Does this description include the hospital with various departments? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 40: Hospital (Department of Pediatrics)\\n\\nThe Department of Pediatrics is situated on Floor 40, offering a comprehensive range of pediatric services. The department is equipped with state-of-the-art medical equipment, including digital X-ray machines and ultrasound technology. The department features a spacious waiting area, a reception desk, and several exam rooms. The department's staff includes experienced pediatricians, nurses, and support staff.\\n\\n Does this description include the hospital with various departments? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 57\\n{Floor 57 Description}\\n**Theater**\\nThis floor is home to a small theater. It features a large, open stage, several private dressing rooms, and a communal area for rehearsals. The walls are painted a bright, cheerful green, and the floors are made of durable, light-colored hardwood. The windows are large and offer plenty of natural light.\\n\\n Does this description include the multi-theater cinema complex? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 58\\n{Floor 58 Description}\\nThe fifty-eighth floor is used for co-working space. It features large, open workspaces, private meeting rooms, and a communal kitchen area. The walls are painted a bright, cheerful yellow, and the floors are made of durable, light-colored hardwood. The windows are large and offer plenty of natural light.\\n\\n Does this description include the multi-theater cinema complex? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 59\\n{Floor 59 Description}\\nThis floor is designed for office space. It features private offices, open-concept workspaces, and a communal kitchen area. The walls are painted a soothing light gray, and the floors are made of durable, dark hardwood. The windows are large and offer plenty of natural light.\\n\\n Does this description include the multi-theater cinema complex? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 60\\n{Floor 60 Description}\\nThe sixtieth floor is home to a small music room. It features a large, open space for practice and performance, several private studios, and a communal area for jam sessions. The walls are painted a soothing, calming green, and the floors are made of durable, industrial-grade concrete.\\n\\n Does this description include the multi-theater cinema complex? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 61\\n{Floor 61 Description}\\nThis floor is used for meeting and event space. It features several large conference rooms, a reception area, and a catering kitchen. The walls are painted a bright, cheerful blue, and the floors are made of durable, light-colored hardwood. The windows are large and offer plenty of natural light.\\n\\n Does this description include the multi-theater cinema complex? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 62\\n{Floor 62 Description}\\nThe sixty-second floor is designed for office space. It features private offices, open-concept workspaces, and a communal kitchen area. The walls are painted a soothing light gray, and the floors are made of durable, dark hardwood. The windows are large and offer plenty of natural light.\\n\\n Does this description include the multi-theater cinema complex? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 24\\n{Floor 24 Description}\\nThe library's main collection is housed on Floors 24 to 30, with a large archive room for rare and historic materials, which offers a quiet reading area for students and scholars. \\n\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 25\\n{Floor 25 Description}\\nThe twenty-fifth floor is allocated for extended study areas and is equipped with comfortable seating, high-speed internet, and access to digital resources. This area is designed to accommodate students in need of a quiet and focused workspace.\\n\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 26\\n{Floor 26 Description}\\nThis floor features open reading spaces and comfortable seating areas, promoting social interaction and collaboration among students. It also houses a lecture theater with state-of-the-art audiovisual equipment.\\n\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 27\\n{Floor 27 Description}\\nThe twenty-seventh floor is allocated for various learning and research activities, including mini-libraries, media rooms, and online research facilities. It features a collaborative workspace for group projects and peer-to-peer learning.\\n\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 28\\n{Floor 28 Description}\\nThis floor houses an independent study area for those requiring more focused workspaces. It includes high-speed internet, charging stations, and power outlets for laptops and other devices.\\n\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 29\\n{Floor 29 Description}\\nThe twenty-ninth floor is designated for rare book storage and research facilities. It features state-of-the-art preservation techniques and climate-controlled environments to preserve valuable materials for future generations.\\n\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 30\\n{Floor 30 Description}\\nThis floor features a beautiful study lounge with a balcony offering panoramic views of the city. The lounge is equipped with comfortable seating, tables, and armchairs for quiet contemplation and relaxation.\\n\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 36\\nCorporate Headquarters for a major company\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 37\\nContinuation of Corporate Headquarters\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 38\\nFinal section of Corporate Headquarters\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 89\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 90\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 91\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 92\\n Does this description include the comprehensive library with study areas and archives? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 66\\nThis floor is allocated for the corporate headquarters of a major company. It features a large executive office, a meeting room, and a dedicated workspace for corporate staff.\\n\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 67\\nFloor 67 is used for a marketing and communications center. It includes a large marketing area, a private office for marketing managers, and a storage area for marketing supplies.\\n\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 68\\nThis floor is dedicated to a product management center. It features a large product management area, a private office for product managers, and a storage area for product equipment.\\n\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 69\\nThe sixty-ninth floor houses a sales and business development center. It includes a large sales area, a private office for sales managers, and a storage area for sales supplies.\\n\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 70\\nFloor 70 is used for a customer success center. It features a large customer success area, a private office for customer success managers, and a storage area for customer success equipment.\\n\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 71\\nThis floor is designated as the final floor of the corporate headquarters. It features a large conference room, a private office for executive leadership, and a storage area for corporate supplies.\\n\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 3\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 4\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 5\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 6\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\",\n",
       " \" Floor 7\\n Does this description include the corporate headquarters for a major company? Please answer with 'yes' or 'no' only.\"]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "prompts_range"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/yuhao/anaconda3/envs/easycontext/lib/python3.10/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n",
      "/home/yuhao/anaconda3/envs/easycontext/lib/python3.10/site-packages/transformers/utils/hub.py:127: FutureWarning: Using `PYTORCH_TRANSFORMERS_CACHE` is deprecated and will be removed in v5 of Transformers. Use `HF_HOME` instead.\n",
      "  warnings.warn(\n",
      "2024-08-02 20:08:03,769\tINFO util.py:154 -- Missing packages: ['ipywidgets']. Run `pip install -U ipywidgets`, then restart the notebook server for rich notebook output.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "INFO 08-02 20:08:04 config.py:715] Defaulting to use mp for distributed inference\n",
      "WARNING 08-02 20:08:04 arg_utils.py:762] Chunked prefill is enabled by default for models with max_model_len > 32K. Currently, chunked prefill might not work with some features or models. If you encounter any issues, please disable chunked prefill by setting --enable-chunked-prefill=False.\n",
      "INFO 08-02 20:08:04 config.py:806] Chunked prefill is enabled with max_num_batched_tokens=512.\n",
      "INFO 08-02 20:08:04 llm_engine.py:176] Initializing an LLM engine (v0.5.3.post1) with config: model='meta-llama/Meta-Llama-3.1-8B-Instruct', speculative_config=None, tokenizer='meta-llama/Meta-Llama-3.1-8B-Instruct', skip_tokenizer_init=False, tokenizer_mode=auto, revision=None, rope_scaling=None, rope_theta=None, tokenizer_revision=None, trust_remote_code=False, dtype=torch.bfloat16, max_seq_len=131072, download_dir=None, load_format=LoadFormat.AUTO, tensor_parallel_size=2, pipeline_parallel_size=1, disable_custom_all_reduce=False, quantization=None, enforce_eager=False, kv_cache_dtype=auto, quantization_param_path=None, device_config=cuda, decoding_config=DecodingConfig(guided_decoding_backend='outlines'), observability_config=ObservabilityConfig(otlp_traces_endpoint=None), seed=0, served_model_name=meta-llama/Meta-Llama-3.1-8B-Instruct, use_v2_block_manager=False, enable_prefix_caching=False)\n",
      "INFO 08-02 20:08:05 custom_cache_manager.py:17] Setting Triton cache manager to: vllm.triton_utils.custom_cache_manager:CustomCacheManager\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m INFO 08-02 20:08:05 multiproc_worker_utils.py:215] Worker ready; awaiting tasks\n",
      "INFO 08-02 20:08:05 utils.py:784] Found nccl from library libnccl.so.2\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m INFO 08-02 20:08:05 pynccl.py:63] vLLM is using nccl==2.20.5\n",
      "INFO 08-02 20:08:05 utils.py:784] Found nccl from library libnccl.so.2\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m INFO 08-02 20:08:05 pynccl.py:63] vLLM is using nccl==2.20.5\n",
      "INFO 08-02 20:08:06 custom_all_reduce_utils.py:232] reading GPU P2P access cache from /home/yuhao/.cache/vllm/gpu_p2p_access_cache_for_0,1.json\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m INFO 08-02 20:08:06 custom_all_reduce_utils.py:232] reading GPU P2P access cache from /home/yuhao/.cache/vllm/gpu_p2p_access_cache_for_0,1.json\n",
      "INFO 08-02 20:08:06 shm_broadcast.py:241] vLLM message queue communication handle: Handle(connect_ip='127.0.0.1', local_reader_ranks=[1], buffer=<vllm.distributed.device_communicators.shm_broadcast.ShmRingBuffer object at 0x7f114f30d3c0>, local_subscribe_port=49265, local_sync_port=42689, remote_subscribe_port=None, remote_sync_port=None)\n",
      "INFO 08-02 20:08:06 model_runner.py:680] Starting to load model meta-llama/Meta-Llama-3.1-8B-Instruct...\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m INFO 08-02 20:08:06 model_runner.py:680] Starting to load model meta-llama/Meta-Llama-3.1-8B-Instruct...\n",
      "INFO 08-02 20:08:07 weight_utils.py:223] Using model weights format ['*.safetensors']\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m INFO 08-02 20:08:07 weight_utils.py:223] Using model weights format ['*.safetensors']\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loading safetensors checkpoint shards:   0% Completed | 0/4 [00:00<?, ?it/s]\n",
      "Loading safetensors checkpoint shards:  25% Completed | 1/4 [00:00<00:01,  2.11it/s]\n",
      "Loading safetensors checkpoint shards:  50% Completed | 2/4 [00:01<00:01,  1.85it/s]\n",
      "Loading safetensors checkpoint shards:  75% Completed | 3/4 [00:01<00:00,  2.66it/s]\n",
      "Loading safetensors checkpoint shards: 100% Completed | 4/4 [00:01<00:00,  2.63it/s]\n",
      "Loading safetensors checkpoint shards: 100% Completed | 4/4 [00:01<00:00,  2.45it/s]\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "INFO 08-02 20:08:09 model_runner.py:692] Loading model weights took 7.5122 GB\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m INFO 08-02 20:08:09 model_runner.py:692] Loading model weights took 7.5122 GB\n",
      "INFO 08-02 20:08:10 distributed_gpu_executor.py:56] # GPU blocks: 62561, # CPU blocks: 4096\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226] Exception in worker VllmWorkerProcess while processing method initialize_cache: CUDA out of memory. Tried to allocate 1.91 GiB. GPU \u0001 has a total capacity of 79.15 GiB of which 1.70 GiB is free. Process 3944009 has 8.71 GiB memory in use. Including non-PyTorch memory, this process has 68.71 GiB memory in use. Of the allocated memory 66.76 GiB is allocated by PyTorch, and 25.36 MiB is reserved by PyTorch but unallocated. If reserved but unallocated memory is large try setting PYTORCH_CUDA_ALLOC_CONF=expandable_segments:True to avoid fragmentation.  See documentation for Memory Management  (https://pytorch.org/docs/stable/notes/cuda.html#environment-variables), Traceback (most recent call last):\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]   File \"/home/yuhao/anaconda3/envs/easycontext/lib/python3.10/site-packages/vllm/executor/multiproc_worker_utils.py\", line 223, in _run_worker_process\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]     output = executor(*args, **kwargs)\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]   File \"/home/yuhao/anaconda3/envs/easycontext/lib/python3.10/site-packages/vllm/worker/worker.py\", line 219, in initialize_cache\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]     self._init_cache_engine()\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]   File \"/home/yuhao/anaconda3/envs/easycontext/lib/python3.10/site-packages/vllm/worker/worker.py\", line 224, in _init_cache_engine\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]     self.cache_engine = [\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]   File \"/home/yuhao/anaconda3/envs/easycontext/lib/python3.10/site-packages/vllm/worker/worker.py\", line 225, in <listcomp>\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]     CacheEngine(self.cache_config, self.model_config,\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]   File \"/home/yuhao/anaconda3/envs/easycontext/lib/python3.10/site-packages/vllm/worker/cache_engine.py\", line 66, in __init__\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]     self.gpu_cache = self._allocate_kv_cache(\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]   File \"/home/yuhao/anaconda3/envs/easycontext/lib/python3.10/site-packages/vllm/worker/cache_engine.py\", line 85, in _allocate_kv_cache\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226]     torch.zeros(kv_cache_shape,\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226] torch.cuda.OutOfMemoryError: CUDA out of memory. Tried to allocate 1.91 GiB. GPU \u0001 has a total capacity of 79.15 GiB of which 1.70 GiB is free. Process 3944009 has 8.71 GiB memory in use. Including non-PyTorch memory, this process has 68.71 GiB memory in use. Of the allocated memory 66.76 GiB is allocated by PyTorch, and 25.36 MiB is reserved by PyTorch but unallocated. If reserved but unallocated memory is large try setting PYTORCH_CUDA_ALLOC_CONF=expandable_segments:True to avoid fragmentation.  See documentation for Memory Management  (https://pytorch.org/docs/stable/notes/cuda.html#environment-variables)\n",
      "\u001b[1;36m(VllmWorkerProcess pid=3944603)\u001b[0;0m ERROR 08-02 20:08:10 multiproc_worker_utils.py:226] \n",
      "INFO 08-02 20:08:12 model_runner.py:980] Capturing the model for CUDA graphs. This may lead to unexpected consequences if the model is not static. To run the model in eager mode, set 'enforce_eager=True' or use '--enforce-eager' in the CLI.\n",
      "INFO 08-02 20:08:12 model_runner.py:984] CUDA graphs can take additional 1~3 GiB memory per GPU. If you are running out of memory, consider decreasing `gpu_memory_utilization` or enforcing eager mode. You can also reduce the `max_num_seqs` as needed to decrease memory usage.\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "import time\n",
    "from vllm import LLM, SamplingParams\n",
    "import torch\n",
    "import json\n",
    "\n",
    "# Define the sampling parameters\n",
    "sampling_params = SamplingParams(temperature=0.95, top_p=0.95, max_tokens=50, seed=42)\n",
    "\n",
    "# Example lists of prompts\n",
    "\n",
    "\n",
    "# Record the start time\n",
    "start_time = time.time()\n",
    "\n",
    "# Initialize the LLM with the specified model and configuration\n",
    "llm = LLM(model=\"meta-llama/Meta-Llama-3.1-8B-Instruct\", tensor_parallel_size=2)\n",
    "\n",
    "def evaluate_accuracy(prompts, llm, sampling_params):\n",
    "    # Generate responses using the LLM\n",
    "    outputs = llm.generate(prompts, sampling_params)\n",
    "    total = len(outputs)\n",
    "    correct = sum([1 for output in outputs if 'yes' in output.outputs[0].text])\n",
    "    return correct / total if total > 0 else 0\n",
    "\n",
    "# Evaluate the accuracy for each set of prompts\n",
    "acc_once = evaluate_accuracy(prompts_once, llm, sampling_params)\n",
    "acc_range = evaluate_accuracy(prompts_range, llm, sampling_params)\n",
    "acc_periodic = evaluate_accuracy(prompts_periodic, llm, sampling_params)\n",
    "\n",
    "# Print the accuracy results\n",
    "print(\"Accuracy for once:\", acc_once)\n",
    "print(\"Accuracy for range:\", acc_range)\n",
    "print(\"Accuracy for periodic:\", acc_periodic)\n",
    "\n",
    "# Print the elapsed time\n",
    "elapsed_time = time.time() - start_time\n",
    "print(f\"Elapsed time: {elapsed_time:.2f} seconds\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " Week 28 (July 9th - July 15th)\n",
      "Surrounded by thriving scenarios amidst identical approaches of life lies beneath spring, relaxes midst dedicated fountain. With every moment spend in our city celebrated person whose expertise knows absolutely – nostalgia I needed thinking foundations, thoughts basically, navigating. Oh what why dramatically soft bang self-relevance caught sure prosperous instal clearer morning confidence dances upon watched discovery increasing attain pebbled rock reserve – discovered time while awaits organ palms compassion all into start at urge tongue grateful guardians bad planting.\n",
      "\n",
      "Does this description include the child_1 birthday? Please answer with 'yes' or 'no' only.\n",
      " Week 28 (July 9th - July 15th)\n",
      "Surrounded by thriving scenarios amidst identical approaches of life lies beneath spring, relaxes midst dedicated fountain. With every moment spend in our city celebrated person whose expertise knows absolutely – nostalgia I needed thinking foundations, thoughts basically, navigating. Oh what why dramatically soft bang self-relevance caught sure prosperous instal clearer morning confidence dances upon watched discovery increasing attain pebbled rock reserve – discovered time while awaits organ palms compassion all into start at urge tongue grateful guardians bad planting.\n",
      "\n",
      "Does this description include the Participating in a week-long photography workshop? Please answer with 'yes' or 'no' only.\n",
      " Week 19 (May 7th - May 13th)\n",
      "Spring is happily unfolding with beginnings everywhere – a formative period that is impossible not to love. Nature imbues spirit, illuminating happiness in everything. Had an excellent week remembering beautiful family moments past and the secure excitement about what the summer will bring.\n",
      "\n",
      "Does this description include the Participate in local fishing contests? Please answer with 'yes' or 'no' only.\n"
     ]
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import re\n",
    "import time\n",
    "import pandas as pd\n",
    "from vllm import LLM, SamplingParams\n",
    "\n",
    "# 读取JSON文件\n",
    "def read_json(file_path):\n",
    "    with open(file_path, 'r') as file:\n",
    "        return json.load(file)\n",
    "\n",
    "# 写入JSON文件\n",
    "def write_json(file_path, data):\n",
    "    with open(file_path, 'w') as file:\n",
    "        json.dump(data, file, indent=4)\n",
    "\n",
    "# 解析output_blocks中特定类型的条目\n",
    "def parse_blocks(output_blocks, type):\n",
    "    type_to_block = {}\n",
    "    pattern = rf\"{type} (\\d+)\"  # 假设类型后的数字仍有用，例如标识ID或序号\n",
    "    for block in output_blocks:\n",
    "        match = re.search(pattern, block)\n",
    "        if match:\n",
    "            identifier = int(match.group(1))  # 获取类型后的数字\n",
    "            type_to_block[identifier] = block\n",
    "    return type_to_block\n",
    "\n",
    "# 生成检查内容的prompt\n",
    "def create_prompts(checks, type_to_block):\n",
    "    prompts = []\n",
    "    identifiers = []\n",
    "    for identifier, event_desc in checks.items():\n",
    "        identifier = int(identifier)  # 确保转换为整数\n",
    "        if identifier in type_to_block:\n",
    "            prompts.append(type_to_block[identifier] + f\" Does this description include the {event_desc}? Please answer with 'yes' or 'no' only.\")\n",
    "            identifiers.append(identifier)\n",
    "    return prompts, identifiers\n",
    "\n",
    "# 定义评估准确性的函数\n",
    "def evaluate_accuracy(prompts, llm, sampling_params):\n",
    "    outputs = llm.generate(prompts, sampling_params)\n",
    "    results = []\n",
    "    for output in outputs:\n",
    "        response = output.outputs[0].text.strip().lower()\n",
    "        result = 'yes' if 'yes' in response else 'no'\n",
    "        results.append(result)\n",
    "    return results\n",
    "\n",
    "# 保存准确率到CSV文件\n",
    "def save_accuracy_to_csv(file_path, model_name, completion_rate, acc_once, acc_range, acc_periodic):\n",
    "    df = pd.DataFrame({\n",
    "        'Model': [model_name],\n",
    "        'Completion Rate': [completion_rate],\n",
    "        'Accuracy Once': [acc_once],\n",
    "        'Accuracy Range': [acc_range],\n",
    "        'Accuracy Periodic': [acc_periodic],\n",
    "        'Average Accuracy': [(acc_once + acc_range + acc_periodic) / 3]\n",
    "    })\n",
    "    \n",
    "    try:\n",
    "        existing_df = pd.read_csv(file_path)\n",
    "        existing_df = existing_df[existing_df['Model'] != model_name]  # 删除相同模型名称的行\n",
    "        df = pd.concat([existing_df, df], ignore_index=True)\n",
    "    except FileNotFoundError:\n",
    "        pass\n",
    "    \n",
    "    df.to_csv(file_path, index=False)\n",
    "\n",
    "# 计算完成度\n",
    "def calculate_completion_rate(type_to_block, total_number):\n",
    "    identifiers = set(type_to_block.keys())\n",
    "    expected_identifiers = set(range(1, total_number + 1))\n",
    "    missing_identifiers = expected_identifiers - identifiers\n",
    "    completion_rate = (len(expected_identifiers) - len(missing_identifiers)) / len(expected_identifiers)\n",
    "    return completion_rate * 100\n",
    "\n",
    "# 主函数\n",
    "json_file_path = \"/home/yuhao/THREADING-THE-NEEDLE/Evalution/results/Meta-Llama-3.1-8B-Instruct_maxlen8000.json\"\n",
    "csv_file_path = \"/home/yuhao/THREADING-THE-NEEDLE/Evalution/results/accuracy_results.csv\"\n",
    "model_name = json_file_path.split('/')[-1].replace('.json', '')\n",
    "\n",
    "datas = read_json(json_file_path)\n",
    "\n",
    "prompts_once = []\n",
    "prompts_range = []\n",
    "prompts_periodic = []\n",
    "identifiers_once = []\n",
    "identifiers_range = []\n",
    "identifiers_periodic = []\n",
    "\n",
    "completion_rate = 0\n",
    "for data in datas:\n",
    "    checks_block = parse_blocks(data['output_blocks'], data['type'])\n",
    "    # 生成once, range, periodic的prompts\n",
    "    p_once, ids_once = create_prompts(data['checks_once'], checks_block)\n",
    "    p_range, ids_range = create_prompts(data['checks_range'], checks_block)\n",
    "    p_periodic, ids_periodic = create_prompts(data['checks_periodic'], checks_block)\n",
    "    \n",
    "    prompts_once.extend(p_once)\n",
    "    identifiers_once.extend(ids_once)\n",
    "    \n",
    "    prompts_range.extend(p_range)\n",
    "    identifiers_range.extend(ids_range)\n",
    "    \n",
    "    prompts_periodic.extend(p_periodic)\n",
    "    identifiers_periodic.extend(ids_periodic)\n",
    "\n",
    "    data['count_once'] = len(ids_once)\n",
    "    data['count_range'] = len(ids_range)\n",
    "    data['count_periodic'] = len(ids_periodic)\n",
    "\n",
    "    \n",
    "    # 计算完成度\n",
    "    completion_rate += calculate_completion_rate(checks_block, data['number'])\n",
    "\n",
    "completion_rate /= len(datas)  # 平均完成度\n",
    "\n",
    "# Define the sampling parameters\n",
    "sampling_params = SamplingParams(temperature=0.95, top_p=0.95, max_tokens=50, seed=42)\n",
    "\n",
    "# Record the start time\n",
    "start_time = time.time()\n",
    "\n",
    "# Initialize the LLM with the specified model and configuration\n",
    "llm = LLM(model=\"meta-llama/Meta-Llama-3.1-8B-Instruct\", tensor_parallel_size=2)\n",
    "\n",
    "# Evaluate the accuracy for each set of prompts\n",
    "results_once = evaluate_accuracy(prompts_once, llm, sampling_params)\n",
    "results_range = evaluate_accuracy(prompts_range, llm, sampling_params)\n",
    "results_periodic = evaluate_accuracy(prompts_periodic, llm, sampling_params)\n",
    "\n",
    "# 计算准确率\n",
    "acc_once = sum(1 for result in results_once if result == 'yes') / len(results_once) if results_once else 0\n",
    "acc_range = sum(1 for result in results_range if result == 'yes') / len(results_range) if results_range else 0\n",
    "acc_periodic = sum(1 for result in results_periodic if result == 'yes') / len(results_periodic) if results_periodic else 0\n",
    "\n",
    "# 将结果添加到JSON文件中\n",
    "start_index_once = 0\n",
    "start_index_range = 0\n",
    "start_index_periodic = 0\n",
    "for data in datas:\n",
    "    data['results_once'] = {str(identifiers_once[i]): results_once[i] for i in range(start_index_once, start_index_once + data['count_once'])}\n",
    "    start_index_once += data['count_once']\n",
    "    \n",
    "    data['results_range'] = {str(identifiers_range[i]): results_range[i] for i in range(start_index_range, start_index_range + data['count_range'])}\n",
    "    start_index_range += data['count_range']\n",
    "    \n",
    "    data['results_periodic'] = {str(identifiers_periodic[i]): results_periodic[i] for i in range(start_index_periodic, start_index_periodic + data['count_periodic'])}\n",
    "    start_index_periodic += data['count_periodic']\n",
    "\n",
    "# 写回JSON文件\n",
    "write_json(json_file_path, datas)\n",
    "\n",
    "# 保存准确率到CSV文件\n",
    "save_accuracy_to_csv(csv_file_path, model_name, completion_rate, acc_once, acc_range, acc_periodic)\n",
    "\n",
    "# Print the elapsed time\n",
    "elapsed_time = time.time() - start_time\n",
    "print(f\"Elapsed time: {elapsed_time:.2f} seconds\")\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "easycontext",
   "language": "python",
   "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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
