Image-Text Semantic Matching with AutoMM

Open In Colab Open In SageMaker Studio Lab

Vision and language are two important aspects of human intelligence to understand the real world. Image-text semantic matching, measuring the visual-semantic similarity between image and text, plays a critical role in bridging the vision and language. Learning a joint space where text and image feature vectors are aligned is a typical solution for image-text matching. It is becoming increasingly significant for various vision-and-language tasks, such as cross-modal retrieval, image captioning, text-to-image synthesis, and multimodal neural machine translation. This tutorial will introduce how to apply AutoMM to the image-text matching task.

import os
import warnings
from IPython.display import Image, display
import numpy as np
warnings.filterwarnings('ignore')
np.random.seed(123)

Dataset

In this tutorial, we will use the Flickr30K dataset to demonstrate the image-text matching. The Flickr30k dataset is a popular benchmark for sentence-based picture portrayal. The dataset is comprised of 31,783 images that capture people engaged in everyday activities and events. Each image has a descriptive caption. We organized the dataset using pandas dataframe. To get started, Let’s download the dataset.

from autogluon.core.utils.loaders import load_pd
import pandas as pd
download_dir = './ag_automm_tutorial_imgtxt'
zip_file = 'https://automl-mm-bench.s3.amazonaws.com/flickr30k.zip'
from autogluon.core.utils.loaders import load_zip
load_zip.unzip(zip_file, unzip_dir=download_dir)
Downloading ./ag_automm_tutorial_imgtxt/file.zip from https://automl-mm-bench.s3.amazonaws.com/flickr30k.zip...
0%|          | 0.00/4.38G [00:00<?, ?iB/s]
0%|          | 6.63M/4.38G [00:00<01:09, 63.3MiB/s]
0%|          | 13.0M/4.38G [00:00<01:51, 39.1MiB/s]
0%|          | 17.4M/4.38G [00:00<02:52, 25.3MiB/s]
1%|          | 23.4M/4.38G [00:00<03:20, 21.7MiB/s]
1%|          | 26.0M/4.38G [00:01<03:20, 21.7MiB/s]
1%|          | 31.8M/4.38G [00:01<02:31, 28.7MiB/s]
1%|          | 35.3M/4.38G [00:01<02:33, 28.3MiB/s]
1%|          | 40.2M/4.38G [00:01<02:32, 28.6MiB/s]
1%|          | 43.3M/4.38G [00:01<02:35, 27.9MiB/s]
1%|          | 50.3M/4.38G [00:01<02:34, 28.0MiB/s]
1%|▏         | 57.3M/4.38G [00:01<01:59, 36.2MiB/s]
1%|▏         | 61.4M/4.38G [00:02<02:10, 33.0MiB/s]
2%|▏         | 67.1M/4.38G [00:02<01:53, 38.1MiB/s]
2%|▏         | 75.5M/4.38G [00:02<01:47, 40.1MiB/s]
2%|▏         | 83.9M/4.38G [00:02<01:52, 38.3MiB/s]
2%|▏         | 90.5M/4.38G [00:02<01:50, 38.8MiB/s]
2%|▏         | 94.6M/4.38G [00:02<02:06, 33.8MiB/s]
2%|▏         | 98.9M/4.38G [00:03<02:47, 25.6MiB/s]
2%|▏         | 102M/4.38G [00:03<03:01, 23.6MiB/s]
3%|▎         | 110M/4.38G [00:03<02:02, 34.8MiB/s]
3%|▎         | 117M/4.38G [00:03<01:55, 36.9MiB/s]
3%|▎         | 126M/4.38G [00:03<01:56, 36.6MiB/s]
3%|▎         | 132M/4.38G [00:04<01:46, 39.9MiB/s]
3%|▎         | 137M/4.38G [00:04<01:59, 35.5MiB/s]
3%|▎         | 143M/4.38G [00:04<01:56, 36.5MiB/s]
3%|▎         | 147M/4.38G [00:04<01:59, 35.3MiB/s]
3%|▎         | 151M/4.38G [00:04<02:04, 33.9MiB/s]
4%|▎         | 158M/4.38G [00:04<01:42, 41.2MiB/s]
4%|▎         | 162M/4.38G [00:04<01:52, 37.6MiB/s]
4%|▍         | 166M/4.38G [00:05<01:56, 36.2MiB/s]
4%|▍         | 170M/4.38G [00:05<02:12, 31.9MiB/s]
4%|▍         | 176M/4.38G [00:05<02:03, 34.2MiB/s]
4%|▍         | 183M/4.38G [00:05<01:48, 38.7MiB/s]
4%|▍         | 187M/4.38G [00:05<01:58, 35.4MiB/s]
4%|▍         | 193M/4.38G [00:05<01:57, 35.8MiB/s]
5%|▍         | 200M/4.38G [00:05<01:49, 38.4MiB/s]
5%|▍         | 203M/4.38G [00:06<02:00, 34.8MiB/s]
5%|▍         | 208M/4.38G [00:06<03:07, 22.2MiB/s]
5%|▍         | 211M/4.38G [00:06<03:06, 22.3MiB/s]
5%|▍         | 216M/4.38G [00:06<02:38, 26.3MiB/s]
5%|▌         | 219M/4.38G [00:06<02:41, 25.8MiB/s]
5%|▌         | 222M/4.38G [00:06<02:42, 25.7MiB/s]
5%|▌         | 226M/4.38G [00:07<02:22, 29.2MiB/s]
5%|▌         | 235M/4.38G [00:07<02:00, 34.5MiB/s]
6%|▌         | 243M/4.38G [00:07<02:02, 33.8MiB/s]
6%|▌         | 250M/4.38G [00:07<01:44, 39.5MiB/s]
6%|▌         | 255M/4.38G [00:07<01:59, 34.5MiB/s]
6%|▌         | 258M/4.38G [00:07<02:14, 30.7MiB/s]
6%|▌         | 262M/4.38G [00:08<02:32, 27.0MiB/s]
6%|▌         | 264M/4.38G [00:08<02:33, 26.8MiB/s]
6%|▌         | 267M/4.38G [00:08<03:30, 19.5MiB/s]
6%|▌         | 269M/4.38G [00:08<03:40, 18.6MiB/s]
6%|▋         | 275M/4.38G [00:08<03:33, 19.3MiB/s]
6%|▋         | 277M/4.38G [00:09<03:32, 19.3MiB/s]
7%|▋         | 285M/4.38G [00:09<02:17, 29.7MiB/s]
7%|▋         | 294M/4.38G [00:09<02:01, 33.6MiB/s]
7%|▋         | 300M/4.38G [00:09<01:46, 38.4MiB/s]
7%|▋         | 304M/4.38G [00:09<02:02, 33.3MiB/s]
7%|▋         | 309M/4.38G [00:10<02:49, 24.0MiB/s]
7%|▋         | 312M/4.38G [00:10<02:53, 23.5MiB/s]
7%|▋         | 317M/4.38G [00:10<02:33, 26.5MiB/s]
7%|▋         | 320M/4.38G [00:10<02:32, 26.7MiB/s]
7%|▋         | 325M/4.38G [00:10<02:05, 32.4MiB/s]
8%|▊         | 329M/4.38G [00:10<02:17, 29.5MiB/s]
8%|▊         | 334M/4.38G [00:10<02:21, 28.5MiB/s]
8%|▊         | 337M/4.38G [00:11<02:41, 25.1MiB/s]
8%|▊         | 342M/4.38G [00:11<02:13, 30.2MiB/s]
8%|▊         | 346M/4.38G [00:11<02:10, 30.9MiB/s]
8%|▊         | 352M/4.38G [00:11<02:20, 28.8MiB/s]
8%|▊         | 359M/4.38G [00:11<01:55, 34.7MiB/s]
8%|▊         | 363M/4.38G [00:11<01:59, 33.7MiB/s]
8%|▊         | 367M/4.38G [00:11<01:52, 35.8MiB/s]
8%|▊         | 371M/4.38G [00:12<01:58, 33.9MiB/s]
9%|▊         | 376M/4.38G [00:12<01:55, 34.6MiB/s]
9%|▊         | 379M/4.38G [00:12<02:20, 28.4MiB/s]
9%|▉         | 384M/4.38G [00:12<02:17, 29.1MiB/s]
9%|▉         | 387M/4.38G [00:12<02:27, 27.2MiB/s]
9%|▉         | 390M/4.38G [00:12<03:07, 21.2MiB/s]
9%|▉         | 394M/4.38G [00:13<03:04, 21.6MiB/s]
9%|▉         | 401M/4.38G [00:13<02:46, 23.9MiB/s]
9%|▉         | 403M/4.38G [00:13<03:10, 20.9MiB/s]
9%|▉         | 409M/4.38G [00:13<02:50, 23.3MiB/s]
9%|▉         | 412M/4.38G [00:13<02:55, 22.7MiB/s]
10%|▉         | 418M/4.38G [00:14<03:14, 20.4MiB/s]
10%|▉         | 420M/4.38G [00:14<03:20, 19.7MiB/s]
10%|▉         | 426M/4.38G [00:14<02:35, 25.5MiB/s]
10%|▉         | 429M/4.38G [00:14<02:50, 23.2MiB/s]
10%|▉         | 432M/4.38G [00:14<02:36, 25.3MiB/s]
10%|▉         | 436M/4.38G [00:14<02:57, 22.2MiB/s]
10%|█         | 443M/4.38G [00:15<02:25, 27.1MiB/s]
10%|█         | 446M/4.38G [00:15<02:43, 24.1MiB/s]
10%|█         | 451M/4.38G [00:15<02:38, 24.8MiB/s]
10%|█         | 455M/4.38G [00:15<02:22, 27.6MiB/s]
11%|█         | 461M/4.38G [00:15<01:56, 33.7MiB/s]
11%|█         | 470M/4.38G [00:15<01:52, 34.6MiB/s]
11%|█         | 478M/4.38G [00:16<01:38, 39.5MiB/s]
11%|█         | 485M/4.38G [00:16<01:26, 45.3MiB/s]
11%|█         | 490M/4.38G [00:16<01:35, 40.9MiB/s]
11%|█▏        | 494M/4.38G [00:16<01:58, 32.7MiB/s]
11%|█▏        | 498M/4.38G [00:16<02:05, 31.0MiB/s]
11%|█▏        | 503M/4.38G [00:16<01:51, 34.8MiB/s]
12%|█▏        | 510M/4.38G [00:16<01:54, 33.9MiB/s]
12%|█▏        | 514M/4.38G [00:17<02:03, 31.3MiB/s]
12%|█▏        | 519M/4.38G [00:17<02:04, 31.0MiB/s]
12%|█▏        | 522M/4.38G [00:17<02:12, 29.0MiB/s]
12%|█▏        | 527M/4.38G [00:17<01:58, 32.5MiB/s]
12%|█▏        | 530M/4.38G [00:17<02:05, 30.8MiB/s]
12%|█▏        | 533M/4.38G [00:18<03:15, 19.7MiB/s]
12%|█▏        | 537M/4.38G [00:18<03:06, 20.6MiB/s]
12%|█▏        | 544M/4.38G [00:18<02:29, 25.6MiB/s]
12%|█▏        | 546M/4.38G [00:18<02:44, 23.4MiB/s]
13%|█▎        | 552M/4.38G [00:18<02:13, 28.8MiB/s]
13%|█▎        | 556M/4.38G [00:18<02:05, 30.6MiB/s]
13%|█▎        | 562M/4.38G [00:18<01:44, 36.5MiB/s]
13%|█▎        | 569M/4.38G [00:18<01:32, 41.4MiB/s]
13%|█▎        | 573M/4.38G [00:19<01:35, 39.9MiB/s]
13%|█▎        | 577M/4.38G [00:19<01:38, 38.6MiB/s]
13%|█▎        | 581M/4.38G [00:19<01:49, 34.8MiB/s]
13%|█▎        | 585M/4.38G [00:19<01:47, 35.4MiB/s]
13%|█▎        | 589M/4.38G [00:19<01:55, 32.8MiB/s]
14%|█▎        | 594M/4.38G [00:19<01:56, 32.4MiB/s]
14%|█▎        | 597M/4.38G [00:19<02:16, 27.7MiB/s]
14%|█▍        | 604M/4.38G [00:20<01:53, 33.3MiB/s]
14%|█▍        | 611M/4.38G [00:20<01:41, 37.1MiB/s]
14%|█▍        | 614M/4.38G [00:20<01:52, 33.4MiB/s]
14%|█▍        | 619M/4.38G [00:20<02:23, 26.2MiB/s]
14%|█▍        | 622M/4.38G [00:20<02:27, 25.5MiB/s]
14%|█▍        | 627M/4.38G [00:20<02:10, 28.8MiB/s]
14%|█▍        | 630M/4.38G [00:21<02:35, 24.1MiB/s]
15%|█▍        | 636M/4.38G [00:21<02:08, 29.0MiB/s]
15%|█▍        | 639M/4.38G [00:21<02:17, 27.3MiB/s]
15%|█▍        | 644M/4.38G [00:21<02:02, 30.5MiB/s]
15%|█▍        | 647M/4.38G [00:21<02:05, 29.8MiB/s]
15%|█▍        | 653M/4.38G [00:21<01:57, 31.8MiB/s]
15%|█▍        | 656M/4.38G [00:21<02:08, 29.0MiB/s]
15%|█▌        | 663M/4.38G [00:22<01:49, 34.0MiB/s]
15%|█▌        | 669M/4.38G [00:22<01:30, 40.9MiB/s]
15%|█▌        | 674M/4.38G [00:22<02:05, 29.6MiB/s]
15%|█▌        | 678M/4.38G [00:22<01:57, 31.6MiB/s]
16%|█▌        | 682M/4.38G [00:22<01:56, 31.6MiB/s]
16%|█▌        | 686M/4.38G [00:22<02:11, 28.1MiB/s]
16%|█▌        | 691M/4.38G [00:22<01:52, 32.8MiB/s]
16%|█▌        | 696M/4.38G [00:23<01:56, 31.6MiB/s]
16%|█▌        | 703M/4.38G [00:23<01:37, 37.8MiB/s]
16%|█▌        | 707M/4.38G [00:23<01:55, 31.8MiB/s]
16%|█▋        | 713M/4.38G [00:23<01:56, 31.5MiB/s]
16%|█▋        | 720M/4.38G [00:23<01:49, 33.5MiB/s]
17%|█▋        | 724M/4.38G [00:23<01:55, 31.6MiB/s]
17%|█▋        | 730M/4.38G [00:24<01:46, 34.3MiB/s]
17%|█▋        | 738M/4.38G [00:24<01:41, 36.1MiB/s]
17%|█▋        | 745M/4.38G [00:24<02:01, 29.9MiB/s]
17%|█▋        | 748M/4.38G [00:24<02:06, 28.8MiB/s]
17%|█▋        | 753M/4.38G [00:25<02:16, 26.5MiB/s]
17%|█▋        | 756M/4.38G [00:25<02:24, 25.0MiB/s]
17%|█▋        | 762M/4.38G [00:25<02:04, 29.0MiB/s]
17%|█▋        | 765M/4.38G [00:25<02:12, 27.2MiB/s]
18%|█▊        | 770M/4.38G [00:25<01:59, 30.2MiB/s]
18%|█▊        | 773M/4.38G [00:25<02:11, 27.4MiB/s]
18%|█▊        | 779M/4.38G [00:25<01:46, 33.8MiB/s]
18%|█▊        | 782M/4.38G [00:25<02:03, 29.2MiB/s]
18%|█▊        | 787M/4.38G [00:26<02:28, 24.3MiB/s]
18%|█▊        | 790M/4.38G [00:26<02:40, 22.4MiB/s]
18%|█▊        | 795M/4.38G [00:26<02:38, 22.6MiB/s]
18%|█▊        | 798M/4.38G [00:26<02:43, 22.0MiB/s]
18%|█▊        | 805M/4.38G [00:26<01:58, 30.2MiB/s]
19%|█▊        | 812M/4.38G [00:27<01:52, 31.6MiB/s]
19%|█▊        | 816M/4.38G [00:27<02:04, 28.7MiB/s]
19%|█▊        | 821M/4.38G [00:27<02:14, 26.5MiB/s]
19%|█▉        | 823M/4.38G [00:27<02:38, 22.5MiB/s]
19%|█▉        | 829M/4.38G [00:27<02:08, 27.6MiB/s]
19%|█▉        | 832M/4.38G [00:27<02:21, 25.1MiB/s]
19%|█▉        | 839M/4.38G [00:28<02:09, 27.4MiB/s]
19%|█▉        | 847M/4.38G [00:28<01:50, 32.1MiB/s]
19%|█▉        | 854M/4.38G [00:28<01:46, 33.2MiB/s]
20%|█▉        | 857M/4.38G [00:28<01:56, 30.2MiB/s]
20%|█▉        | 864M/4.38G [00:28<02:03, 28.4MiB/s]
20%|█▉        | 871M/4.38G [00:29<01:41, 34.7MiB/s]
20%|█▉        | 875M/4.38G [00:29<02:23, 24.5MiB/s]
20%|██        | 881M/4.38G [00:29<02:10, 26.8MiB/s]
20%|██        | 887M/4.38G [00:30<02:40, 21.8MiB/s]
20%|██        | 890M/4.38G [00:30<02:48, 20.8MiB/s]
20%|██        | 896M/4.38G [00:30<02:23, 24.2MiB/s]
21%|██        | 899M/4.38G [00:30<02:35, 22.4MiB/s]
21%|██        | 905M/4.38G [00:30<01:57, 29.7MiB/s]
21%|██        | 909M/4.38G [00:30<02:05, 27.7MiB/s]
21%|██        | 913M/4.38G [00:30<02:12, 26.3MiB/s]
21%|██        | 916M/4.38G [00:31<02:44, 21.0MiB/s]
21%|██        | 921M/4.38G [00:31<02:17, 25.2MiB/s]
21%|██        | 924M/4.38G [00:31<02:22, 24.3MiB/s]
21%|██▏       | 931M/4.38G [00:31<01:52, 30.8MiB/s]
21%|██▏       | 938M/4.38G [00:31<02:00, 28.7MiB/s]
21%|██▏       | 941M/4.38G [00:31<02:05, 27.5MiB/s]
22%|██▏       | 948M/4.38G [00:32<01:43, 33.2MiB/s]
22%|██▏       | 955M/4.38G [00:32<01:23, 40.9MiB/s]
22%|██▏       | 959M/4.38G [00:32<01:30, 37.9MiB/s]
22%|██▏       | 965M/4.38G [00:32<01:52, 30.4MiB/s]
22%|██▏       | 972M/4.38G [00:32<02:08, 26.5MiB/s]
22%|██▏       | 975M/4.38G [00:33<02:11, 25.9MiB/s]
22%|██▏       | 980M/4.38G [00:33<02:39, 21.4MiB/s]
22%|██▏       | 982M/4.38G [00:33<02:47, 20.3MiB/s]
23%|██▎       | 990M/4.38G [00:33<02:21, 23.9MiB/s]
23%|██▎       | 996M/4.38G [00:34<02:11, 25.7MiB/s]
23%|██▎       | 999M/4.38G [00:34<02:08, 26.4MiB/s]
23%|██▎       | 1.00G/4.38G [00:34<02:04, 27.2MiB/s]
23%|██▎       | 1.01G/4.38G [00:34<02:06, 26.6MiB/s]
23%|██▎       | 1.01G/4.38G [00:34<01:59, 28.3MiB/s]
23%|██▎       | 1.02G/4.38G [00:34<02:07, 26.3MiB/s]
23%|██▎       | 1.02G/4.38G [00:34<01:45, 31.9MiB/s]
23%|██▎       | 1.02G/4.38G [00:34<01:46, 31.7MiB/s]
24%|██▎       | 1.03G/4.38G [00:35<01:46, 31.3MiB/s]
24%|██▎       | 1.03G/4.38G [00:35<02:03, 27.1MiB/s]
24%|██▎       | 1.04G/4.38G [00:35<02:28, 22.5MiB/s]
24%|██▎       | 1.04G/4.38G [00:35<02:45, 20.1MiB/s]
24%|██▍       | 1.05G/4.38G [00:36<02:49, 19.6MiB/s]
24%|██▍       | 1.05G/4.38G [00:36<02:50, 19.5MiB/s]
24%|██▍       | 1.06G/4.38G [00:36<02:25, 22.9MiB/s]
24%|██▍       | 1.06G/4.38G [00:36<02:17, 24.2MiB/s]
24%|██▍       | 1.07G/4.38G [00:36<01:58, 28.1MiB/s]
24%|██▍       | 1.07G/4.38G [00:36<01:54, 28.8MiB/s]
25%|██▍       | 1.08G/4.38G [00:37<01:55, 28.7MiB/s]
25%|██▍       | 1.08G/4.38G [00:37<01:52, 29.4MiB/s]
25%|██▍       | 1.09G/4.38G [00:37<02:01, 27.0MiB/s]
25%|██▍       | 1.09G/4.38G [00:37<02:07, 25.8MiB/s]
25%|██▌       | 1.10G/4.38G [00:38<02:26, 22.4MiB/s]
25%|██▌       | 1.10G/4.38G [00:38<02:20, 23.4MiB/s]
25%|██▌       | 1.11G/4.38G [00:38<01:56, 28.2MiB/s]
25%|██▌       | 1.11G/4.38G [00:38<01:56, 28.2MiB/s]
25%|██▌       | 1.12G/4.38G [00:38<01:43, 31.7MiB/s]
26%|██▌       | 1.12G/4.38G [00:38<01:24, 38.6MiB/s]
26%|██▌       | 1.13G/4.38G [00:38<01:31, 35.7MiB/s]
26%|██▌       | 1.13G/4.38G [00:38<01:39, 32.8MiB/s]
26%|██▌       | 1.14G/4.38G [00:39<01:14, 43.2MiB/s]
26%|██▌       | 1.15G/4.38G [00:39<01:21, 39.6MiB/s]
26%|██▌       | 1.15G/4.38G [00:39<01:51, 29.1MiB/s]
26%|██▋       | 1.16G/4.38G [00:39<01:41, 31.6MiB/s]
26%|██▋       | 1.16G/4.38G [00:39<01:45, 30.6MiB/s]
27%|██▋       | 1.17G/4.38G [00:39<01:28, 36.3MiB/s]
27%|██▋       | 1.17G/4.38G [00:40<01:27, 36.8MiB/s]
27%|██▋       | 1.18G/4.38G [00:40<01:19, 40.1MiB/s]
27%|██▋       | 1.19G/4.38G [00:40<01:18, 40.8MiB/s]
27%|██▋       | 1.19G/4.38G [00:40<01:33, 34.3MiB/s]
27%|██▋       | 1.20G/4.38G [00:40<01:42, 31.1MiB/s]
27%|██▋       | 1.20G/4.38G [00:40<01:49, 28.9MiB/s]
28%|██▊       | 1.21G/4.38G [00:41<01:35, 33.2MiB/s]
28%|██▊       | 1.22G/4.38G [00:41<01:15, 41.8MiB/s]
28%|██▊       | 1.22G/4.38G [00:41<01:43, 30.6MiB/s]
28%|██▊       | 1.22G/4.38G [00:41<01:49, 28.8MiB/s]
28%|██▊       | 1.23G/4.38G [00:41<01:46, 29.6MiB/s]
28%|██▊       | 1.24G/4.38G [00:42<01:36, 32.7MiB/s]
28%|██▊       | 1.24G/4.38G [00:42<01:57, 26.6MiB/s]
28%|██▊       | 1.25G/4.38G [00:42<02:03, 25.4MiB/s]
29%|██▊       | 1.25G/4.38G [00:42<02:25, 21.5MiB/s]
29%|██▊       | 1.26G/4.38G [00:43<02:33, 20.3MiB/s]
29%|██▊       | 1.26G/4.38G [00:43<02:42, 19.2MiB/s]
29%|██▉       | 1.27G/4.38G [00:43<01:48, 28.7MiB/s]
29%|██▉       | 1.27G/4.38G [00:43<01:34, 32.8MiB/s]
29%|██▉       | 1.28G/4.38G [00:43<01:36, 32.1MiB/s]
29%|██▉       | 1.28G/4.38G [00:43<01:29, 34.6MiB/s]
29%|██▉       | 1.29G/4.38G [00:43<01:42, 30.1MiB/s]
29%|██▉       | 1.29G/4.38G [00:44<01:25, 36.1MiB/s]
30%|██▉       | 1.30G/4.38G [00:44<01:13, 42.0MiB/s]
30%|██▉       | 1.31G/4.38G [00:44<01:13, 41.7MiB/s]
30%|██▉       | 1.31G/4.38G [00:44<01:26, 35.6MiB/s]
30%|███       | 1.32G/4.38G [00:44<01:23, 36.9MiB/s]
30%|███       | 1.32G/4.38G [00:44<01:35, 32.1MiB/s]
30%|███       | 1.33G/4.38G [00:45<01:17, 39.3MiB/s]
30%|███       | 1.34G/4.38G [00:45<01:35, 32.0MiB/s]
31%|███       | 1.34G/4.38G [00:45<01:48, 28.0MiB/s]
31%|███       | 1.34G/4.38G [00:45<03:02, 16.7MiB/s]
31%|███       | 1.35G/4.38G [00:46<02:23, 21.1MiB/s]
31%|███       | 1.35G/4.38G [00:46<02:19, 21.6MiB/s]
31%|███       | 1.36G/4.38G [00:46<01:54, 26.5MiB/s]
31%|███       | 1.36G/4.38G [00:46<02:00, 25.0MiB/s]
31%|███       | 1.37G/4.38G [00:46<01:43, 29.1MiB/s]
31%|███▏      | 1.38G/4.38G [00:46<01:24, 35.6MiB/s]
32%|███▏      | 1.38G/4.38G [00:46<01:06, 44.9MiB/s]
32%|███▏      | 1.39G/4.38G [00:47<01:14, 40.1MiB/s]
32%|███▏      | 1.39G/4.38G [00:47<01:24, 35.5MiB/s]
32%|███▏      | 1.40G/4.38G [00:47<01:16, 38.9MiB/s]
32%|███▏      | 1.40G/4.38G [00:47<01:17, 38.5MiB/s]
32%|███▏      | 1.41G/4.38G [00:47<01:29, 33.3MiB/s]
32%|███▏      | 1.41G/4.38G [00:47<01:34, 31.4MiB/s]
32%|███▏      | 1.42G/4.38G [00:47<01:24, 35.1MiB/s]
32%|███▏      | 1.42G/4.38G [00:48<01:28, 33.4MiB/s]
33%|███▎      | 1.42G/4.38G [00:48<01:35, 30.9MiB/s]
33%|███▎      | 1.43G/4.38G [00:48<01:46, 27.6MiB/s]
33%|███▎      | 1.43G/4.38G [00:48<01:36, 30.6MiB/s]
33%|███▎      | 1.44G/4.38G [00:48<01:34, 31.2MiB/s]
33%|███▎      | 1.44G/4.38G [00:48<01:41, 29.0MiB/s]
33%|███▎      | 1.45G/4.38G [00:49<01:29, 32.7MiB/s]
33%|███▎      | 1.45G/4.38G [00:49<01:34, 30.9MiB/s]
33%|███▎      | 1.46G/4.38G [00:49<02:22, 20.5MiB/s]
33%|███▎      | 1.46G/4.38G [00:49<02:28, 19.7MiB/s]
33%|███▎      | 1.47G/4.38G [00:49<02:09, 22.4MiB/s]
34%|███▎      | 1.47G/4.38G [00:50<01:48, 26.9MiB/s]
34%|███▎      | 1.48G/4.38G [00:50<01:39, 29.1MiB/s]
34%|███▍      | 1.48G/4.38G [00:50<01:16, 38.0MiB/s]
34%|███▍      | 1.49G/4.38G [00:50<01:15, 38.6MiB/s]
34%|███▍      | 1.49G/4.38G [00:50<01:41, 28.4MiB/s]
34%|███▍      | 1.50G/4.38G [00:50<01:42, 28.1MiB/s]
34%|███▍      | 1.50G/4.38G [00:50<01:35, 30.1MiB/s]
34%|███▍      | 1.50G/4.38G [00:51<01:46, 27.1MiB/s]
34%|███▍      | 1.51G/4.38G [00:51<01:15, 38.0MiB/s]
35%|███▍      | 1.52G/4.38G [00:51<01:15, 38.1MiB/s]
35%|███▍      | 1.53G/4.38G [00:51<01:00, 47.5MiB/s]
35%|███▌      | 1.54G/4.38G [00:51<01:11, 39.5MiB/s]
35%|███▌      | 1.54G/4.38G [00:51<01:05, 43.1MiB/s]
35%|███▌      | 1.55G/4.38G [00:51<01:05, 43.1MiB/s]
35%|███▌      | 1.55G/4.38G [00:52<01:16, 37.2MiB/s]
36%|███▌      | 1.56G/4.38G [00:52<01:18, 36.0MiB/s]
36%|███▌      | 1.56G/4.38G [00:52<01:31, 30.7MiB/s]
36%|███▌      | 1.57G/4.38G [00:52<01:30, 31.0MiB/s]
36%|███▌      | 1.57G/4.38G [00:52<01:45, 26.7MiB/s]
36%|███▌      | 1.58G/4.38G [00:53<02:16, 20.5MiB/s]
36%|███▌      | 1.58G/4.38G [00:53<02:21, 19.9MiB/s]
36%|███▌      | 1.58G/4.38G [00:53<02:02, 22.8MiB/s]
36%|███▌      | 1.59G/4.38G [00:53<02:01, 22.9MiB/s]
36%|███▋      | 1.59G/4.38G [00:53<01:24, 32.9MiB/s]
37%|███▋      | 1.60G/4.38G [00:54<01:27, 31.8MiB/s]
37%|███▋      | 1.60G/4.38G [00:54<01:36, 28.9MiB/s]
37%|███▋      | 1.61G/4.38G [00:54<01:27, 31.7MiB/s]
37%|███▋      | 1.62G/4.38G [00:54<01:20, 34.1MiB/s]
37%|███▋      | 1.62G/4.38G [00:55<02:08, 21.5MiB/s]
37%|███▋      | 1.63G/4.38G [00:55<02:04, 22.1MiB/s]
37%|███▋      | 1.63G/4.38G [00:55<02:08, 21.5MiB/s]
37%|███▋      | 1.64G/4.38G [00:55<01:49, 25.0MiB/s]
38%|███▊      | 1.64G/4.38G [00:55<01:42, 26.8MiB/s]
38%|███▊      | 1.65G/4.38G [00:55<01:29, 30.4MiB/s]
38%|███▊      | 1.65G/4.38G [00:56<01:31, 29.8MiB/s]
38%|███▊      | 1.66G/4.38G [00:56<01:18, 34.9MiB/s]
38%|███▊      | 1.67G/4.38G [00:56<01:08, 39.4MiB/s]
38%|███▊      | 1.67G/4.38G [00:56<01:13, 36.7MiB/s]
38%|███▊      | 1.68G/4.38G [00:56<01:14, 36.2MiB/s]
38%|███▊      | 1.68G/4.38G [00:56<01:16, 35.3MiB/s]
39%|███▊      | 1.69G/4.38G [00:56<01:16, 35.0MiB/s]
39%|███▊      | 1.69G/4.38G [00:57<01:09, 38.7MiB/s]
39%|███▊      | 1.70G/4.38G [00:57<01:16, 35.3MiB/s]
39%|███▉      | 1.70G/4.38G [00:57<01:25, 31.2MiB/s]
39%|███▉      | 1.71G/4.38G [00:57<01:38, 27.0MiB/s]
39%|███▉      | 1.71G/4.38G [00:57<01:39, 26.8MiB/s]
39%|███▉      | 1.72G/4.38G [00:57<01:30, 29.6MiB/s]
39%|███▉      | 1.72G/4.38G [00:58<01:39, 26.8MiB/s]
39%|███▉      | 1.73G/4.38G [00:58<01:23, 32.0MiB/s]
40%|███▉      | 1.74G/4.38G [00:58<01:15, 35.1MiB/s]
40%|███▉      | 1.74G/4.38G [00:58<01:09, 38.2MiB/s]
40%|███▉      | 1.75G/4.38G [00:58<01:25, 30.8MiB/s]
40%|████      | 1.75G/4.38G [00:59<01:19, 33.0MiB/s]
40%|████      | 1.76G/4.38G [00:59<01:01, 42.8MiB/s]
40%|████      | 1.77G/4.38G [00:59<01:07, 38.9MiB/s]
40%|████      | 1.77G/4.38G [00:59<01:26, 30.2MiB/s]
41%|████      | 1.78G/4.38G [00:59<01:15, 34.4MiB/s]
41%|████      | 1.78G/4.38G [00:59<01:20, 32.5MiB/s]
41%|████      | 1.79G/4.38G [00:59<01:13, 35.2MiB/s]
41%|████      | 1.79G/4.38G [01:00<01:03, 40.5MiB/s]
41%|████      | 1.80G/4.38G [01:00<01:08, 37.7MiB/s]
41%|████      | 1.80G/4.38G [01:00<01:10, 36.6MiB/s]
41%|████      | 1.81G/4.38G [01:00<01:19, 32.4MiB/s]
41%|████▏     | 1.81G/4.38G [01:00<01:20, 31.8MiB/s]
41%|████▏     | 1.81G/4.38G [01:00<01:27, 29.4MiB/s]
42%|████▏     | 1.82G/4.38G [01:00<01:21, 31.5MiB/s]
42%|████▏     | 1.82G/4.38G [01:01<01:22, 31.0MiB/s]
42%|████▏     | 1.83G/4.38G [01:01<01:14, 34.1MiB/s]
42%|████▏     | 1.84G/4.38G [01:01<00:59, 42.5MiB/s]
42%|████▏     | 1.84G/4.38G [01:01<01:02, 40.4MiB/s]
42%|████▏     | 1.85G/4.38G [01:01<01:07, 37.8MiB/s]
42%|████▏     | 1.85G/4.38G [01:01<01:00, 41.7MiB/s]
42%|████▏     | 1.86G/4.38G [01:01<01:09, 36.3MiB/s]
42%|████▏     | 1.86G/4.38G [01:02<01:15, 33.4MiB/s]
43%|████▎     | 1.86G/4.38G [01:02<01:18, 32.2MiB/s]
43%|████▎     | 1.87G/4.38G [01:02<01:16, 32.7MiB/s]
43%|████▎     | 1.87G/4.38G [01:02<01:18, 32.0MiB/s]
43%|████▎     | 1.88G/4.38G [01:02<01:24, 29.7MiB/s]
43%|████▎     | 1.88G/4.38G [01:02<01:34, 26.4MiB/s]
43%|████▎     | 1.89G/4.38G [01:02<01:21, 30.7MiB/s]
43%|████▎     | 1.89G/4.38G [01:03<01:10, 35.3MiB/s]
43%|████▎     | 1.90G/4.38G [01:03<01:13, 33.8MiB/s]
43%|████▎     | 1.90G/4.38G [01:03<01:06, 37.0MiB/s]
44%|████▎     | 1.91G/4.38G [01:03<00:59, 41.6MiB/s]
44%|████▎     | 1.92G/4.38G [01:03<01:08, 35.8MiB/s]
44%|████▍     | 1.92G/4.38G [01:03<01:10, 35.2MiB/s]
44%|████▍     | 1.92G/4.38G [01:03<01:16, 32.3MiB/s]
44%|████▍     | 1.93G/4.38G [01:04<01:17, 31.6MiB/s]
44%|████▍     | 1.94G/4.38G [01:04<01:05, 37.4MiB/s]
44%|████▍     | 1.94G/4.38G [01:04<01:05, 37.5MiB/s]
44%|████▍     | 1.95G/4.38G [01:04<01:06, 36.3MiB/s]
45%|████▍     | 1.95G/4.38G [01:04<01:08, 35.5MiB/s]
45%|████▍     | 1.96G/4.38G [01:04<01:17, 31.2MiB/s]
45%|████▍     | 1.96G/4.38G [01:05<01:34, 25.5MiB/s]
45%|████▍     | 1.96G/4.38G [01:05<01:41, 23.8MiB/s]
45%|████▍     | 1.97G/4.38G [01:05<01:29, 27.0MiB/s]
45%|████▌     | 1.98G/4.38G [01:05<01:13, 32.9MiB/s]
45%|████▌     | 1.98G/4.38G [01:05<01:20, 29.9MiB/s]
45%|████▌     | 1.99G/4.38G [01:06<01:28, 27.0MiB/s]
45%|████▌     | 1.99G/4.38G [01:06<01:40, 23.8MiB/s]
46%|████▌     | 2.00G/4.38G [01:06<01:26, 27.7MiB/s]
46%|████▌     | 2.00G/4.38G [01:06<01:27, 27.2MiB/s]
46%|████▌     | 2.00G/4.38G [01:06<01:23, 28.6MiB/s]
46%|████▌     | 2.01G/4.38G [01:06<01:13, 32.3MiB/s]
46%|████▌     | 2.01G/4.38G [01:06<01:17, 30.4MiB/s]
46%|████▌     | 2.02G/4.38G [01:07<01:06, 35.5MiB/s]
46%|████▋     | 2.03G/4.38G [01:07<01:04, 36.3MiB/s]
46%|████▋     | 2.03G/4.38G [01:07<01:04, 36.3MiB/s]
46%|████▋     | 2.04G/4.38G [01:07<01:08, 34.4MiB/s]
47%|████▋     | 2.04G/4.38G [01:07<01:21, 28.8MiB/s]
47%|████▋     | 2.05G/4.38G [01:07<01:19, 29.4MiB/s]
47%|████▋     | 2.05G/4.38G [01:08<01:28, 26.5MiB/s]
47%|████▋     | 2.05G/4.38G [01:08<01:23, 27.8MiB/s]
47%|████▋     | 2.06G/4.38G [01:08<01:30, 25.7MiB/s]
47%|████▋     | 2.06G/4.38G [01:08<01:33, 24.7MiB/s]
47%|████▋     | 2.06G/4.38G [01:08<01:34, 24.5MiB/s]
47%|████▋     | 2.07G/4.38G [01:08<01:09, 33.3MiB/s]
47%|████▋     | 2.07G/4.38G [01:08<01:16, 30.0MiB/s]
47%|████▋     | 2.08G/4.38G [01:09<01:16, 30.2MiB/s]
48%|████▊     | 2.09G/4.38G [01:09<01:23, 27.4MiB/s]
48%|████▊     | 2.09G/4.38G [01:09<01:31, 24.9MiB/s]
48%|████▊     | 2.09G/4.38G [01:09<01:19, 28.7MiB/s]
48%|████▊     | 2.10G/4.38G [01:09<01:34, 24.2MiB/s]
48%|████▊     | 2.10G/4.38G [01:10<01:38, 23.2MiB/s]
48%|████▊     | 2.11G/4.38G [01:10<01:36, 23.5MiB/s]
48%|████▊     | 2.11G/4.38G [01:10<01:20, 28.1MiB/s]
48%|████▊     | 2.12G/4.38G [01:10<01:16, 29.6MiB/s]
48%|████▊     | 2.12G/4.38G [01:10<01:19, 28.5MiB/s]
49%|████▊     | 2.13G/4.38G [01:10<01:10, 31.8MiB/s]
49%|████▊     | 2.13G/4.38G [01:11<01:25, 26.4MiB/s]
49%|████▉     | 2.14G/4.38G [01:11<01:18, 28.7MiB/s]
49%|████▉     | 2.15G/4.38G [01:11<01:06, 33.8MiB/s]
49%|████▉     | 2.15G/4.38G [01:11<01:07, 33.2MiB/s]
49%|████▉     | 2.16G/4.38G [01:11<00:52, 42.1MiB/s]
49%|████▉     | 2.16G/4.38G [01:11<00:58, 37.6MiB/s]
50%|████▉     | 2.17G/4.38G [01:12<00:50, 43.5MiB/s]
50%|████▉     | 2.18G/4.38G [01:12<00:54, 40.6MiB/s]
50%|████▉     | 2.18G/4.38G [01:12<01:02, 35.3MiB/s]
50%|████▉     | 2.19G/4.38G [01:12<01:52, 19.6MiB/s]
50%|████▉     | 2.19G/4.38G [01:13<01:54, 19.2MiB/s]
50%|█████     | 2.20G/4.38G [01:13<01:39, 22.0MiB/s]
50%|█████     | 2.20G/4.38G [01:13<01:36, 22.6MiB/s]
50%|█████     | 2.20G/4.38G [01:13<01:38, 22.2MiB/s]
50%|█████     | 2.20G/4.38G [01:13<01:36, 22.5MiB/s]
50%|█████     | 2.21G/4.38G [01:13<02:22, 15.3MiB/s]
51%|█████     | 2.21G/4.38G [01:14<01:25, 25.2MiB/s]
51%|█████     | 2.22G/4.38G [01:14<01:10, 30.7MiB/s]
51%|█████     | 2.22G/4.38G [01:14<01:16, 28.2MiB/s]
51%|█████     | 2.23G/4.38G [01:14<01:15, 28.6MiB/s]
51%|█████     | 2.23G/4.38G [01:14<01:07, 31.8MiB/s]
51%|█████     | 2.24G/4.38G [01:14<01:07, 31.8MiB/s]
51%|█████▏    | 2.25G/4.38G [01:15<01:02, 33.9MiB/s]
51%|█████▏    | 2.25G/4.38G [01:15<01:16, 27.7MiB/s]
52%|█████▏    | 2.26G/4.38G [01:15<01:18, 27.1MiB/s]
52%|█████▏    | 2.26G/4.38G [01:15<01:15, 27.9MiB/s]
52%|█████▏    | 2.27G/4.38G [01:15<01:20, 26.3MiB/s]
52%|█████▏    | 2.27G/4.38G [01:15<01:07, 31.0MiB/s]
52%|█████▏    | 2.28G/4.38G [01:16<01:20, 26.1MiB/s]
52%|█████▏    | 2.28G/4.38G [01:16<01:03, 32.9MiB/s]
52%|█████▏    | 2.29G/4.38G [01:16<00:52, 39.6MiB/s]
52%|█████▏    | 2.29G/4.38G [01:16<01:03, 32.9MiB/s]
52%|█████▏    | 2.30G/4.38G [01:16<01:08, 30.6MiB/s]
53%|█████▎    | 2.31G/4.38G [01:17<01:13, 28.1MiB/s]
53%|█████▎    | 2.31G/4.38G [01:17<01:16, 27.0MiB/s]
53%|█████▎    | 2.31G/4.38G [01:17<01:04, 32.2MiB/s]
53%|█████▎    | 2.32G/4.38G [01:17<01:04, 32.0MiB/s]
53%|█████▎    | 2.32G/4.38G [01:17<01:07, 30.5MiB/s]
53%|█████▎    | 2.33G/4.38G [01:17<01:05, 31.2MiB/s]
53%|█████▎    | 2.33G/4.38G [01:18<01:12, 28.3MiB/s]
53%|█████▎    | 2.34G/4.38G [01:18<01:06, 30.6MiB/s]
53%|█████▎    | 2.34G/4.38G [01:18<01:04, 31.4MiB/s]
54%|█████▎    | 2.35G/4.38G [01:18<00:58, 34.5MiB/s]
54%|█████▍    | 2.36G/4.38G [01:18<00:51, 39.4MiB/s]
54%|█████▍    | 2.37G/4.38G [01:18<00:52, 38.5MiB/s]
54%|█████▍    | 2.37G/4.38G [01:18<00:50, 39.9MiB/s]
54%|█████▍    | 2.38G/4.38G [01:19<00:57, 35.1MiB/s]
54%|█████▍    | 2.38G/4.38G [01:19<00:56, 35.6MiB/s]
54%|█████▍    | 2.38G/4.38G [01:19<00:58, 34.2MiB/s]
55%|█████▍    | 2.39G/4.38G [01:19<00:55, 35.9MiB/s]
55%|█████▍    | 2.39G/4.38G [01:19<01:05, 30.2MiB/s]
55%|█████▍    | 2.40G/4.38G [01:19<01:15, 26.4MiB/s]
55%|█████▍    | 2.40G/4.38G [01:20<01:14, 26.5MiB/s]
55%|█████▍    | 2.41G/4.38G [01:20<01:03, 30.9MiB/s]
55%|█████▍    | 2.41G/4.38G [01:20<01:16, 25.7MiB/s]
55%|█████▌    | 2.41G/4.38G [01:20<01:12, 27.3MiB/s]
55%|█████▌    | 2.42G/4.38G [01:20<01:05, 30.0MiB/s]
55%|█████▌    | 2.42G/4.38G [01:20<01:06, 29.4MiB/s]
55%|█████▌    | 2.42G/4.38G [01:20<01:17, 25.3MiB/s]
55%|█████▌    | 2.43G/4.38G [01:21<00:58, 33.3MiB/s]
56%|█████▌    | 2.43G/4.38G [01:21<01:07, 28.9MiB/s]
56%|█████▌    | 2.44G/4.38G [01:21<01:06, 29.4MiB/s]
56%|█████▌    | 2.44G/4.38G [01:21<01:10, 27.5MiB/s]
56%|█████▌    | 2.45G/4.38G [01:21<00:57, 33.8MiB/s]
56%|█████▌    | 2.46G/4.38G [01:21<00:49, 39.2MiB/s]
56%|█████▌    | 2.46G/4.38G [01:21<00:54, 35.1MiB/s]
56%|█████▋    | 2.46G/4.38G [01:22<00:55, 34.3MiB/s]
56%|█████▋    | 2.47G/4.38G [01:22<00:56, 34.1MiB/s]
56%|█████▋    | 2.47G/4.38G [01:22<00:48, 39.1MiB/s]
57%|█████▋    | 2.48G/4.38G [01:22<00:44, 42.4MiB/s]
57%|█████▋    | 2.49G/4.38G [01:22<00:51, 37.0MiB/s]
57%|█████▋    | 2.49G/4.38G [01:22<00:55, 34.3MiB/s]
57%|█████▋    | 2.50G/4.38G [01:23<01:03, 29.6MiB/s]
57%|█████▋    | 2.50G/4.38G [01:23<01:05, 28.8MiB/s]
57%|█████▋    | 2.51G/4.38G [01:23<00:59, 31.6MiB/s]
57%|█████▋    | 2.52G/4.38G [01:23<01:27, 21.3MiB/s]
57%|█████▋    | 2.52G/4.38G [01:23<01:20, 23.0MiB/s]
58%|█████▊    | 2.52G/4.38G [01:24<01:11, 26.2MiB/s]
58%|█████▊    | 2.53G/4.38G [01:24<01:14, 24.8MiB/s]
58%|█████▊    | 2.53G/4.38G [01:24<01:03, 28.9MiB/s]
58%|█████▊    | 2.53G/4.38G [01:24<01:03, 29.0MiB/s]
58%|█████▊    | 2.54G/4.38G [01:24<01:05, 28.0MiB/s]
58%|█████▊    | 2.54G/4.38G [01:24<01:06, 27.5MiB/s]
58%|█████▊    | 2.55G/4.38G [01:24<00:58, 31.6MiB/s]
58%|█████▊    | 2.55G/4.38G [01:25<01:06, 27.7MiB/s]
58%|█████▊    | 2.55G/4.38G [01:25<01:35, 19.2MiB/s]
58%|█████▊    | 2.56G/4.38G [01:25<01:35, 19.1MiB/s]
59%|█████▊    | 2.57G/4.38G [01:25<01:14, 24.4MiB/s]
59%|█████▊    | 2.57G/4.38G [01:25<01:19, 22.9MiB/s]
59%|█████▊    | 2.57G/4.38G [01:26<01:06, 27.0MiB/s]
59%|█████▉    | 2.58G/4.38G [01:26<01:11, 25.3MiB/s]
59%|█████▉    | 2.58G/4.38G [01:26<00:56, 31.7MiB/s]
59%|█████▉    | 2.59G/4.38G [01:26<00:56, 31.8MiB/s]
59%|█████▉    | 2.59G/4.38G [01:26<01:03, 28.2MiB/s]
59%|█████▉    | 2.59G/4.38G [01:26<01:11, 25.2MiB/s]
59%|█████▉    | 2.60G/4.38G [01:27<01:18, 22.8MiB/s]
59%|█████▉    | 2.60G/4.38G [01:27<01:17, 23.1MiB/s]
60%|█████▉    | 2.61G/4.38G [01:27<00:55, 31.8MiB/s]
60%|█████▉    | 2.62G/4.38G [01:27<00:52, 33.8MiB/s]
60%|█████▉    | 2.62G/4.38G [01:27<01:00, 29.1MiB/s]
60%|█████▉    | 2.62G/4.38G [01:27<00:56, 31.3MiB/s]
60%|█████▉    | 2.63G/4.38G [01:27<00:58, 30.1MiB/s]
60%|██████    | 2.63G/4.38G [01:28<01:01, 28.3MiB/s]
60%|██████    | 2.64G/4.38G [01:28<01:03, 27.6MiB/s]
60%|██████    | 2.64G/4.38G [01:28<01:02, 27.8MiB/s]
60%|██████    | 2.64G/4.38G [01:28<01:09, 24.9MiB/s]
60%|██████    | 2.65G/4.38G [01:28<00:51, 33.4MiB/s]
61%|██████    | 2.65G/4.38G [01:28<01:01, 28.2MiB/s]
61%|██████    | 2.66G/4.38G [01:29<01:04, 26.8MiB/s]
61%|██████    | 2.67G/4.38G [01:29<00:50, 34.0MiB/s]
61%|██████    | 2.67G/4.38G [01:29<00:50, 34.2MiB/s]
61%|██████    | 2.67G/4.38G [01:29<00:55, 30.9MiB/s]
61%|██████    | 2.68G/4.38G [01:29<01:03, 26.8MiB/s]
61%|██████▏   | 2.68G/4.38G [01:29<00:55, 30.8MiB/s]
61%|██████▏   | 2.69G/4.38G [01:30<01:00, 28.1MiB/s]
61%|██████▏   | 2.69G/4.38G [01:30<01:07, 24.8MiB/s]
62%|██████▏   | 2.70G/4.38G [01:30<01:17, 21.8MiB/s]
62%|██████▏   | 2.70G/4.38G [01:30<01:10, 23.9MiB/s]
62%|██████▏   | 2.71G/4.38G [01:30<00:52, 31.7MiB/s]
62%|██████▏   | 2.72G/4.38G [01:30<00:44, 37.1MiB/s]
62%|██████▏   | 2.72G/4.38G [01:31<00:47, 34.8MiB/s]
62%|██████▏   | 2.73G/4.38G [01:31<00:50, 33.0MiB/s]
62%|██████▏   | 2.73G/4.38G [01:31<00:50, 32.7MiB/s]
63%|██████▎   | 2.74G/4.38G [01:31<00:42, 38.2MiB/s]
63%|██████▎   | 2.75G/4.38G [01:31<00:44, 36.5MiB/s]
63%|██████▎   | 2.75G/4.38G [01:31<00:43, 37.5MiB/s]
63%|██████▎   | 2.75G/4.38G [01:32<00:46, 35.0MiB/s]
63%|██████▎   | 2.76G/4.38G [01:32<00:49, 32.7MiB/s]
63%|██████▎   | 2.76G/4.38G [01:32<00:56, 28.6MiB/s]
63%|██████▎   | 2.77G/4.38G [01:32<00:52, 30.8MiB/s]
63%|██████▎   | 2.78G/4.38G [01:32<00:42, 38.0MiB/s]
63%|██████▎   | 2.78G/4.38G [01:32<00:47, 33.7MiB/s]
64%|██████▎   | 2.78G/4.38G [01:32<00:47, 33.9MiB/s]
64%|██████▎   | 2.79G/4.38G [01:33<00:47, 33.9MiB/s]
64%|██████▎   | 2.79G/4.38G [01:33<00:46, 34.6MiB/s]
64%|██████▍   | 2.80G/4.38G [01:33<00:56, 28.2MiB/s]
64%|██████▍   | 2.80G/4.38G [01:33<00:49, 31.7MiB/s]
64%|██████▍   | 2.81G/4.38G [01:33<00:40, 39.1MiB/s]
64%|██████▍   | 2.82G/4.38G [01:33<00:43, 35.9MiB/s]
64%|██████▍   | 2.82G/4.38G [01:34<00:49, 31.3MiB/s]
65%|██████▍   | 2.83G/4.38G [01:34<00:43, 35.9MiB/s]
65%|██████▍   | 2.83G/4.38G [01:34<00:48, 32.0MiB/s]
65%|██████▍   | 2.84G/4.38G [01:34<00:51, 30.0MiB/s]
65%|██████▍   | 2.84G/4.38G [01:34<00:43, 35.2MiB/s]
65%|██████▍   | 2.85G/4.38G [01:34<00:48, 31.9MiB/s]
65%|██████▌   | 2.85G/4.38G [01:35<00:54, 27.8MiB/s]
65%|██████▌   | 2.85G/4.38G [01:35<00:58, 25.9MiB/s]
65%|██████▌   | 2.86G/4.38G [01:35<00:58, 25.9MiB/s]
65%|██████▌   | 2.86G/4.38G [01:35<00:58, 25.9MiB/s]
65%|██████▌   | 2.86G/4.38G [01:35<01:02, 24.3MiB/s]
65%|██████▌   | 2.87G/4.38G [01:35<00:41, 36.3MiB/s]
66%|██████▌   | 2.87G/4.38G [01:35<00:45, 33.4MiB/s]
66%|██████▌   | 2.88G/4.38G [01:35<00:49, 30.3MiB/s]
66%|██████▌   | 2.88G/4.38G [01:36<00:40, 37.4MiB/s]
66%|██████▌   | 2.89G/4.38G [01:36<00:46, 32.2MiB/s]
66%|██████▌   | 2.89G/4.38G [01:36<00:42, 34.7MiB/s]
66%|██████▌   | 2.90G/4.38G [01:36<00:43, 34.2MiB/s]
66%|██████▌   | 2.90G/4.38G [01:36<00:45, 32.8MiB/s]
66%|██████▋   | 2.91G/4.38G [01:36<00:46, 31.4MiB/s]
66%|██████▋   | 2.91G/4.38G [01:37<00:50, 29.3MiB/s]
67%|██████▋   | 2.92G/4.38G [01:37<00:53, 27.6MiB/s]
67%|██████▋   | 2.92G/4.38G [01:37<00:58, 24.9MiB/s]
67%|██████▋   | 2.93G/4.38G [01:37<00:52, 27.6MiB/s]
67%|██████▋   | 2.93G/4.38G [01:37<01:00, 24.1MiB/s]
67%|██████▋   | 2.93G/4.38G [01:37<01:12, 20.1MiB/s]
67%|██████▋   | 2.93G/4.38G [01:38<01:21, 17.7MiB/s]
67%|██████▋   | 2.94G/4.38G [01:38<01:22, 17.5MiB/s]
67%|██████▋   | 2.94G/4.38G [01:38<00:54, 26.3MiB/s]
67%|██████▋   | 2.95G/4.38G [01:38<01:09, 20.5MiB/s]
67%|██████▋   | 2.95G/4.38G [01:38<01:02, 22.8MiB/s]
68%|██████▊   | 2.96G/4.38G [01:39<00:43, 32.9MiB/s]
68%|██████▊   | 2.96G/4.38G [01:39<00:49, 28.8MiB/s]
68%|██████▊   | 2.97G/4.38G [01:39<00:53, 26.5MiB/s]
68%|██████▊   | 2.98G/4.38G [01:39<00:52, 26.7MiB/s]
68%|██████▊   | 2.98G/4.38G [01:39<00:53, 26.1MiB/s]
68%|██████▊   | 2.99G/4.38G [01:39<00:45, 30.4MiB/s]
68%|██████▊   | 2.99G/4.38G [01:40<00:45, 30.2MiB/s]
68%|██████▊   | 3.00G/4.38G [01:40<00:47, 28.9MiB/s]
69%|██████▊   | 3.00G/4.38G [01:40<00:44, 31.2MiB/s]
69%|██████▊   | 3.01G/4.38G [01:40<00:38, 35.5MiB/s]
69%|██████▉   | 3.01G/4.38G [01:40<00:44, 30.5MiB/s]
69%|██████▉   | 3.02G/4.38G [01:40<00:39, 34.3MiB/s]
69%|██████▉   | 3.02G/4.38G [01:41<00:43, 31.0MiB/s]
69%|██████▉   | 3.03G/4.38G [01:41<00:39, 34.4MiB/s]
69%|██████▉   | 3.04G/4.38G [01:41<00:35, 37.4MiB/s]
69%|██████▉   | 3.04G/4.38G [01:41<00:35, 38.1MiB/s]
70%|██████▉   | 3.05G/4.38G [01:41<00:38, 35.0MiB/s]
70%|██████▉   | 3.05G/4.38G [01:41<00:38, 34.5MiB/s]
70%|██████▉   | 3.06G/4.38G [01:42<00:42, 30.9MiB/s]
70%|██████▉   | 3.06G/4.38G [01:42<00:42, 31.1MiB/s]
70%|███████   | 3.07G/4.38G [01:42<00:33, 39.1MiB/s]
70%|███████   | 3.07G/4.38G [01:42<00:43, 30.4MiB/s]
70%|███████   | 3.08G/4.38G [01:42<00:46, 28.3MiB/s]
70%|███████   | 3.08G/4.38G [01:42<00:46, 28.3MiB/s]
70%|███████   | 3.08G/4.38G [01:43<00:51, 25.2MiB/s]
70%|███████   | 3.09G/4.38G [01:43<00:48, 26.7MiB/s]
71%|███████   | 3.09G/4.38G [01:43<00:53, 24.2MiB/s]
71%|███████   | 3.10G/4.38G [01:43<00:47, 27.1MiB/s]
71%|███████   | 3.10G/4.38G [01:43<00:35, 36.3MiB/s]
71%|███████   | 3.11G/4.38G [01:43<00:34, 36.7MiB/s]
71%|███████   | 3.11G/4.38G [01:43<00:38, 33.2MiB/s]
71%|███████   | 3.12G/4.38G [01:44<00:34, 36.4MiB/s]
71%|███████▏  | 3.12G/4.38G [01:44<00:41, 30.7MiB/s]
71%|███████▏  | 3.13G/4.38G [01:44<00:56, 22.3MiB/s]
71%|███████▏  | 3.13G/4.38G [01:44<00:56, 22.0MiB/s]
72%|███████▏  | 3.14G/4.38G [01:44<00:43, 28.3MiB/s]
72%|███████▏  | 3.15G/4.38G [01:44<00:33, 37.0MiB/s]
72%|███████▏  | 3.15G/4.38G [01:45<00:31, 39.4MiB/s]
72%|███████▏  | 3.16G/4.38G [01:45<00:29, 41.4MiB/s]
72%|███████▏  | 3.17G/4.38G [01:45<00:28, 42.4MiB/s]
72%|███████▏  | 3.17G/4.38G [01:45<00:39, 30.5MiB/s]
73%|███████▎  | 3.18G/4.38G [01:45<00:36, 32.8MiB/s]
73%|███████▎  | 3.18G/4.38G [01:46<00:37, 32.2MiB/s]
73%|███████▎  | 3.19G/4.38G [01:46<00:37, 32.0MiB/s]
73%|███████▎  | 3.19G/4.38G [01:46<00:30, 38.5MiB/s]
73%|███████▎  | 3.20G/4.38G [01:46<00:37, 31.5MiB/s]
73%|███████▎  | 3.20G/4.38G [01:46<00:37, 31.7MiB/s]
73%|███████▎  | 3.21G/4.38G [01:46<00:31, 36.8MiB/s]
73%|███████▎  | 3.22G/4.38G [01:47<00:31, 37.0MiB/s]
74%|███████▎  | 3.22G/4.38G [01:47<00:34, 33.8MiB/s]
74%|███████▎  | 3.23G/4.38G [01:47<00:32, 35.1MiB/s]
74%|███████▍  | 3.24G/4.38G [01:47<00:28, 39.9MiB/s]
74%|███████▍  | 3.24G/4.38G [01:47<00:31, 36.8MiB/s]
74%|███████▍  | 3.24G/4.38G [01:47<00:30, 37.8MiB/s]
74%|███████▍  | 3.25G/4.38G [01:47<00:32, 34.9MiB/s]
74%|███████▍  | 3.25G/4.38G [01:48<00:33, 33.4MiB/s]
74%|███████▍  | 3.26G/4.38G [01:48<00:42, 26.7MiB/s]
74%|███████▍  | 3.26G/4.38G [01:48<00:33, 33.2MiB/s]
75%|███████▍  | 3.27G/4.38G [01:48<00:33, 32.8MiB/s]
75%|███████▍  | 3.27G/4.38G [01:48<00:35, 31.1MiB/s]
75%|███████▍  | 3.28G/4.38G [01:48<00:44, 25.0MiB/s]
75%|███████▍  | 3.28G/4.38G [01:49<00:45, 24.0MiB/s]
75%|███████▌  | 3.29G/4.38G [01:49<00:34, 31.6MiB/s]
75%|███████▌  | 3.29G/4.38G [01:49<00:38, 28.1MiB/s]
75%|███████▌  | 3.30G/4.38G [01:49<00:35, 30.7MiB/s]
75%|███████▌  | 3.31G/4.38G [01:49<00:29, 37.1MiB/s]
76%|███████▌  | 3.31G/4.38G [01:49<00:30, 35.4MiB/s]
76%|███████▌  | 3.32G/4.38G [01:50<00:32, 32.3MiB/s]
76%|███████▌  | 3.32G/4.38G [01:50<00:32, 32.9MiB/s]
76%|███████▌  | 3.33G/4.38G [01:50<00:29, 36.1MiB/s]
76%|███████▌  | 3.33G/4.38G [01:50<00:32, 31.9MiB/s]
76%|███████▌  | 3.34G/4.38G [01:50<00:31, 33.3MiB/s]
76%|███████▋  | 3.35G/4.38G [01:50<00:31, 32.5MiB/s]
76%|███████▋  | 3.35G/4.38G [01:51<00:33, 30.9MiB/s]
77%|███████▋  | 3.36G/4.38G [01:51<00:24, 42.1MiB/s]
77%|███████▋  | 3.36G/4.38G [01:51<00:26, 38.7MiB/s]
77%|███████▋  | 3.37G/4.38G [01:51<00:32, 31.1MiB/s]
77%|███████▋  | 3.37G/4.38G [01:51<00:31, 31.7MiB/s]
77%|███████▋  | 3.38G/4.38G [01:51<00:27, 36.8MiB/s]
77%|███████▋  | 3.38G/4.38G [01:52<00:29, 34.1MiB/s]
77%|███████▋  | 3.39G/4.38G [01:52<00:27, 35.8MiB/s]
77%|███████▋  | 3.39G/4.38G [01:52<00:28, 34.7MiB/s]
78%|███████▊  | 3.40G/4.38G [01:52<00:34, 28.4MiB/s]
78%|███████▊  | 3.40G/4.38G [01:52<00:38, 25.6MiB/s]
78%|███████▊  | 3.40G/4.38G [01:52<00:34, 28.6MiB/s]
78%|███████▊  | 3.41G/4.38G [01:52<00:37, 26.0MiB/s]
78%|███████▊  | 3.41G/4.38G [01:53<00:41, 23.2MiB/s]
78%|███████▊  | 3.41G/4.38G [01:53<00:44, 21.6MiB/s]
78%|███████▊  | 3.42G/4.38G [01:53<00:50, 19.2MiB/s]
78%|███████▊  | 3.42G/4.38G [01:53<00:49, 19.2MiB/s]
78%|███████▊  | 3.43G/4.38G [01:53<00:32, 29.5MiB/s]
78%|███████▊  | 3.43G/4.38G [01:54<00:34, 27.5MiB/s]
78%|███████▊  | 3.44G/4.38G [01:54<00:39, 24.2MiB/s]
79%|███████▊  | 3.44G/4.38G [01:54<00:42, 22.3MiB/s]
79%|███████▊  | 3.45G/4.38G [01:54<00:30, 30.1MiB/s]
79%|███████▉  | 3.45G/4.38G [01:54<00:27, 34.1MiB/s]
79%|███████▉  | 3.46G/4.38G [01:54<00:30, 30.6MiB/s]
79%|███████▉  | 3.46G/4.38G [01:55<00:25, 35.6MiB/s]
79%|███████▉  | 3.47G/4.38G [01:55<00:28, 31.6MiB/s]
79%|███████▉  | 3.47G/4.38G [01:55<00:32, 28.0MiB/s]
79%|███████▉  | 3.48G/4.38G [01:55<00:27, 32.4MiB/s]
80%|███████▉  | 3.49G/4.38G [01:55<00:21, 42.2MiB/s]
80%|███████▉  | 3.49G/4.38G [01:55<00:24, 35.9MiB/s]
80%|███████▉  | 3.50G/4.38G [01:56<00:29, 30.3MiB/s]
80%|███████▉  | 3.50G/4.38G [01:56<00:26, 33.2MiB/s]
80%|████████  | 3.51G/4.38G [01:56<00:30, 29.1MiB/s]
80%|████████  | 3.51G/4.38G [01:56<00:26, 32.2MiB/s]
80%|████████  | 3.52G/4.38G [01:56<00:21, 40.3MiB/s]
80%|████████  | 3.53G/4.38G [01:56<00:21, 39.6MiB/s]
81%|████████  | 3.53G/4.38G [01:57<00:24, 34.4MiB/s]
81%|████████  | 3.54G/4.38G [01:57<00:25, 33.1MiB/s]
81%|████████  | 3.54G/4.38G [01:57<00:27, 30.1MiB/s]
81%|████████  | 3.55G/4.38G [01:57<00:25, 33.2MiB/s]
81%|████████  | 3.55G/4.38G [01:57<00:26, 31.9MiB/s]
81%|████████  | 3.56G/4.38G [01:57<00:25, 32.7MiB/s]
81%|████████▏ | 3.56G/4.38G [01:58<00:36, 22.8MiB/s]
81%|████████▏ | 3.56G/4.38G [01:58<00:39, 20.8MiB/s]
81%|████████▏ | 3.57G/4.38G [01:58<00:39, 20.9MiB/s]
82%|████████▏ | 3.57G/4.38G [01:58<00:27, 29.0MiB/s]
82%|████████▏ | 3.58G/4.38G [01:58<00:22, 35.4MiB/s]
82%|████████▏ | 3.58G/4.38G [01:58<00:24, 32.8MiB/s]
82%|████████▏ | 3.59G/4.38G [01:59<00:23, 33.9MiB/s]
82%|████████▏ | 3.60G/4.38G [01:59<00:25, 31.2MiB/s]
82%|████████▏ | 3.60G/4.38G [01:59<00:26, 29.6MiB/s]
82%|████████▏ | 3.61G/4.38G [01:59<00:26, 29.4MiB/s]
82%|████████▏ | 3.61G/4.38G [01:59<00:28, 27.6MiB/s]
82%|████████▏ | 3.61G/4.38G [01:59<00:23, 32.4MiB/s]
83%|████████▎ | 3.62G/4.38G [01:59<00:24, 30.6MiB/s]
83%|████████▎ | 3.62G/4.38G [02:00<00:23, 32.7MiB/s]
83%|████████▎ | 3.63G/4.38G [02:00<00:28, 26.4MiB/s]
83%|████████▎ | 3.63G/4.38G [02:00<00:31, 23.4MiB/s]
83%|████████▎ | 3.64G/4.38G [02:00<00:26, 27.9MiB/s]
83%|████████▎ | 3.65G/4.38G [02:01<00:20, 35.1MiB/s]
83%|████████▎ | 3.66G/4.38G [02:01<00:19, 37.3MiB/s]
84%|████████▎ | 3.67G/4.38G [02:01<00:16, 42.2MiB/s]
84%|████████▍ | 3.67G/4.38G [02:01<00:22, 31.8MiB/s]
84%|████████▍ | 3.68G/4.38G [02:01<00:22, 31.0MiB/s]
84%|████████▍ | 3.68G/4.38G [02:02<00:22, 31.1MiB/s]
84%|████████▍ | 3.69G/4.38G [02:02<00:17, 38.4MiB/s]
84%|████████▍ | 3.69G/4.38G [02:02<00:19, 35.6MiB/s]
84%|████████▍ | 3.70G/4.38G [02:02<00:20, 34.0MiB/s]
85%|████████▍ | 3.71G/4.38G [02:02<00:22, 30.7MiB/s]
85%|████████▍ | 3.71G/4.38G [02:02<00:22, 29.9MiB/s]
85%|████████▍ | 3.72G/4.38G [02:02<00:18, 35.7MiB/s]
85%|████████▍ | 3.72G/4.38G [02:03<00:20, 32.6MiB/s]
85%|████████▌ | 3.72G/4.38G [02:03<00:19, 33.4MiB/s]
85%|████████▌ | 3.73G/4.38G [02:03<00:15, 42.4MiB/s]
85%|████████▌ | 3.74G/4.38G [02:03<00:15, 41.2MiB/s]
85%|████████▌ | 3.74G/4.38G [02:03<00:15, 42.3MiB/s]
86%|████████▌ | 3.75G/4.38G [02:03<00:14, 43.0MiB/s]
86%|████████▌ | 3.76G/4.38G [02:03<00:14, 41.7MiB/s]
86%|████████▌ | 3.76G/4.38G [02:04<00:16, 38.4MiB/s]
86%|████████▌ | 3.77G/4.38G [02:04<00:15, 39.6MiB/s]
86%|████████▌ | 3.77G/4.38G [02:04<00:13, 44.3MiB/s]
86%|████████▌ | 3.78G/4.38G [02:04<00:16, 37.5MiB/s]
86%|████████▋ | 3.78G/4.38G [02:04<00:13, 43.4MiB/s]
87%|████████▋ | 3.79G/4.38G [02:04<00:13, 43.9MiB/s]
87%|████████▋ | 3.79G/4.38G [02:04<00:16, 35.8MiB/s]
87%|████████▋ | 3.80G/4.38G [02:05<00:15, 37.6MiB/s]
87%|████████▋ | 3.80G/4.38G [02:05<00:18, 31.9MiB/s]
87%|████████▋ | 3.81G/4.38G [02:05<00:19, 29.0MiB/s]
87%|████████▋ | 3.82G/4.38G [02:05<00:20, 28.2MiB/s]
87%|████████▋ | 3.82G/4.38G [02:05<00:21, 26.3MiB/s]
87%|████████▋ | 3.83G/4.38G [02:06<00:18, 29.6MiB/s]
87%|████████▋ | 3.83G/4.38G [02:06<00:15, 35.9MiB/s]
88%|████████▊ | 3.84G/4.38G [02:06<00:16, 32.8MiB/s]
88%|████████▊ | 3.84G/4.38G [02:06<00:16, 32.2MiB/s]
88%|████████▊ | 3.85G/4.38G [02:06<00:14, 36.2MiB/s]
88%|████████▊ | 3.86G/4.38G [02:06<00:13, 38.5MiB/s]
88%|████████▊ | 3.86G/4.38G [02:07<00:15, 34.0MiB/s]
88%|████████▊ | 3.87G/4.38G [02:07<00:14, 36.4MiB/s]
88%|████████▊ | 3.87G/4.38G [02:07<00:16, 31.5MiB/s]
88%|████████▊ | 3.87G/4.38G [02:07<00:26, 19.5MiB/s]
88%|████████▊ | 3.88G/4.38G [02:07<00:27, 18.7MiB/s]
89%|████████▊ | 3.88G/4.38G [02:08<00:21, 23.5MiB/s]
89%|████████▊ | 3.89G/4.38G [02:08<00:19, 25.7MiB/s]
89%|████████▉ | 3.89G/4.38G [02:08<00:14, 33.1MiB/s]
89%|████████▉ | 3.90G/4.38G [02:08<00:12, 39.5MiB/s]
89%|████████▉ | 3.90G/4.38G [02:08<00:13, 34.5MiB/s]
89%|████████▉ | 3.91G/4.38G [02:08<00:14, 32.9MiB/s]
89%|████████▉ | 3.92G/4.38G [02:08<00:11, 39.7MiB/s]
89%|████████▉ | 3.92G/4.38G [02:08<00:12, 35.7MiB/s]
90%|████████▉ | 3.93G/4.38G [02:09<00:13, 34.8MiB/s]
90%|████████▉ | 3.93G/4.38G [02:09<00:11, 40.4MiB/s]
90%|████████▉ | 3.94G/4.38G [02:09<00:10, 41.5MiB/s]
90%|█████████ | 3.95G/4.38G [02:09<00:09, 45.6MiB/s]
90%|█████████ | 3.95G/4.38G [02:09<00:09, 45.3MiB/s]
90%|█████████ | 3.96G/4.38G [02:09<00:09, 46.7MiB/s]
91%|█████████ | 3.97G/4.38G [02:09<00:08, 51.2MiB/s]
91%|█████████ | 3.97G/4.38G [02:10<00:08, 46.0MiB/s]
91%|█████████ | 3.98G/4.38G [02:10<00:13, 29.5MiB/s]
91%|█████████ | 3.98G/4.38G [02:10<00:12, 31.1MiB/s]
91%|█████████ | 3.99G/4.38G [02:10<00:12, 30.7MiB/s]
91%|█████████ | 3.99G/4.38G [02:10<00:11, 33.7MiB/s]
91%|█████████▏| 4.00G/4.38G [02:10<00:09, 41.5MiB/s]
91%|█████████▏| 4.00G/4.38G [02:11<00:09, 38.2MiB/s]
92%|█████████▏| 4.01G/4.38G [02:11<00:09, 37.7MiB/s]
92%|█████████▏| 4.01G/4.38G [02:11<00:11, 32.9MiB/s]
92%|█████████▏| 4.02G/4.38G [02:11<00:10, 36.0MiB/s]
92%|█████████▏| 4.03G/4.38G [02:11<00:08, 41.9MiB/s]
92%|█████████▏| 4.03G/4.38G [02:11<00:07, 46.1MiB/s]
92%|█████████▏| 4.04G/4.38G [02:11<00:07, 44.4MiB/s]
92%|█████████▏| 4.04G/4.38G [02:12<00:09, 37.1MiB/s]
92%|█████████▏| 4.05G/4.38G [02:12<00:07, 42.3MiB/s]
93%|█████████▎| 4.05G/4.38G [02:12<00:07, 42.3MiB/s]
93%|█████████▎| 4.06G/4.38G [02:12<00:09, 35.0MiB/s]
93%|█████████▎| 4.07G/4.38G [02:12<00:09, 31.6MiB/s]
93%|█████████▎| 4.07G/4.38G [02:12<00:10, 29.7MiB/s]
93%|█████████▎| 4.08G/4.38G [02:13<00:09, 31.8MiB/s]
93%|█████████▎| 4.08G/4.38G [02:13<00:09, 30.9MiB/s]
93%|█████████▎| 4.08G/4.38G [02:13<00:10, 29.4MiB/s]
93%|█████████▎| 4.09G/4.38G [02:13<00:10, 28.9MiB/s]
93%|█████████▎| 4.09G/4.38G [02:13<00:08, 33.5MiB/s]
93%|█████████▎| 4.10G/4.38G [02:13<00:10, 27.9MiB/s]
94%|█████████▎| 4.10G/4.38G [02:14<00:14, 19.8MiB/s]
94%|█████████▎| 4.10G/4.38G [02:14<00:14, 19.6MiB/s]
94%|█████████▍| 4.11G/4.38G [02:14<00:10, 26.7MiB/s]
94%|█████████▍| 4.11G/4.38G [02:14<00:10, 25.7MiB/s]
94%|█████████▍| 4.12G/4.38G [02:14<00:09, 28.4MiB/s]
94%|█████████▍| 4.12G/4.38G [02:14<00:10, 26.1MiB/s]
94%|█████████▍| 4.13G/4.38G [02:14<00:07, 32.3MiB/s]
94%|█████████▍| 4.13G/4.38G [02:15<00:08, 28.3MiB/s]
94%|█████████▍| 4.14G/4.38G [02:15<00:08, 30.4MiB/s]
95%|█████████▍| 4.14G/4.38G [02:15<00:06, 38.2MiB/s]
95%|█████████▍| 4.15G/4.38G [02:15<00:08, 27.0MiB/s]
95%|█████████▍| 4.15G/4.38G [02:15<00:08, 28.2MiB/s]
95%|█████████▍| 4.16G/4.38G [02:16<00:06, 33.7MiB/s]
95%|█████████▌| 4.16G/4.38G [02:16<00:06, 32.8MiB/s]
95%|█████████▌| 4.17G/4.38G [02:16<00:06, 33.0MiB/s]
95%|█████████▌| 4.18G/4.38G [02:16<00:07, 26.5MiB/s]
95%|█████████▌| 4.18G/4.38G [02:16<00:08, 24.9MiB/s]
96%|█████████▌| 4.18G/4.38G [02:16<00:06, 28.6MiB/s]
96%|█████████▌| 4.19G/4.38G [02:17<00:06, 28.8MiB/s]
96%|█████████▌| 4.19G/4.38G [02:17<00:06, 28.3MiB/s]
96%|█████████▌| 4.20G/4.38G [02:17<00:05, 33.9MiB/s]
96%|█████████▌| 4.21G/4.38G [02:17<00:05, 30.9MiB/s]
96%|█████████▌| 4.21G/4.38G [02:17<00:06, 27.4MiB/s]
96%|█████████▋| 4.22G/4.38G [02:18<00:05, 31.1MiB/s]
96%|█████████▋| 4.23G/4.38G [02:18<00:05, 30.2MiB/s]
97%|█████████▋| 4.23G/4.38G [02:18<00:05, 27.2MiB/s]
97%|█████████▋| 4.23G/4.38G [02:18<00:06, 22.0MiB/s]
97%|█████████▋| 4.24G/4.38G [02:18<00:06, 22.1MiB/s]
97%|█████████▋| 4.24G/4.38G [02:19<00:05, 26.6MiB/s]
97%|█████████▋| 4.25G/4.38G [02:19<00:05, 25.7MiB/s]
97%|█████████▋| 4.25G/4.38G [02:19<00:03, 33.5MiB/s]
97%|█████████▋| 4.26G/4.38G [02:19<00:03, 32.1MiB/s]
97%|█████████▋| 4.26G/4.38G [02:19<00:03, 33.5MiB/s]
97%|█████████▋| 4.26G/4.38G [02:19<00:05, 22.0MiB/s]
97%|█████████▋| 4.27G/4.38G [02:20<00:04, 25.0MiB/s]
98%|█████████▊| 4.27G/4.38G [02:20<00:04, 23.1MiB/s]
98%|█████████▊| 4.28G/4.38G [02:20<00:04, 26.0MiB/s]
98%|█████████▊| 4.28G/4.38G [02:20<00:03, 26.2MiB/s]
98%|█████████▊| 4.28G/4.38G [02:20<00:03, 28.6MiB/s]
98%|█████████▊| 4.29G/4.38G [02:20<00:03, 30.4MiB/s]
98%|█████████▊| 4.29G/4.38G [02:20<00:03, 29.7MiB/s]
98%|█████████▊| 4.29G/4.38G [02:20<00:03, 28.1MiB/s]
98%|█████████▊| 4.30G/4.38G [02:21<00:03, 25.7MiB/s]
98%|█████████▊| 4.30G/4.38G [02:21<00:02, 29.6MiB/s]
98%|█████████▊| 4.31G/4.38G [02:21<00:01, 36.6MiB/s]
99%|█████████▊| 4.32G/4.38G [02:21<00:01, 43.0MiB/s]
99%|█████████▊| 4.32G/4.38G [02:21<00:01, 35.8MiB/s]
99%|█████████▉| 4.33G/4.38G [02:21<00:01, 33.7MiB/s]
99%|█████████▉| 4.34G/4.38G [02:22<00:01, 36.2MiB/s]
99%|█████████▉| 4.34G/4.38G [02:22<00:01, 30.3MiB/s]
99%|█████████▉| 4.35G/4.38G [02:22<00:01, 34.5MiB/s]
99%|█████████▉| 4.35G/4.38G [02:22<00:00, 36.5MiB/s]
100%|█████████▉| 4.36G/4.38G [02:22<00:00, 41.0MiB/s]
100%|█████████▉| 4.36G/4.38G [02:22<00:00, 35.7MiB/s]
100%|█████████▉| 4.37G/4.38G [02:23<00:00, 36.1MiB/s]
100%|█████████▉| 4.37G/4.38G [02:23<00:00, 24.4MiB/s]
100%|█████████▉| 4.38G/4.38G [02:23<00:00, 29.0MiB/s]
100%|██████████| 4.38G/4.38G [02:23<00:00, 30.5MiB/s]

Then we will load the csv files.

dataset_path = os.path.join(download_dir, 'flickr30k_processed')
train_data = pd.read_csv(f'{dataset_path}/train.csv', index_col=0)
val_data = pd.read_csv(f'{dataset_path}/val.csv', index_col=0)
test_data = pd.read_csv(f'{dataset_path}/test.csv', index_col=0)
image_col = "image"
text_col = "caption"

We also need to expand the relative image paths to use their absolute local paths.

def path_expander(path, base_folder):
    path_l = path.split(';')
    return ';'.join([os.path.abspath(os.path.join(base_folder, path)) for path in path_l])

train_data[image_col] = train_data[image_col].apply(lambda ele: path_expander(ele, base_folder=dataset_path))
val_data[image_col] = val_data[image_col].apply(lambda ele: path_expander(ele, base_folder=dataset_path))
test_data[image_col] = test_data[image_col].apply(lambda ele: path_expander(ele, base_folder=dataset_path))

Take train_data for example, let’s see how the data look like in the dataframe.

train_data.head()
caption image
0 Two young guys with shaggy hair look at their ... /home/ci/autogluon/docs/tutorials/multimodal/s...
1 Two young White males are outside near many bu... /home/ci/autogluon/docs/tutorials/multimodal/s...
2 Two men in green shirts are standing in a yard /home/ci/autogluon/docs/tutorials/multimodal/s...
3 A man in a blue shirt standing in a garden /home/ci/autogluon/docs/tutorials/multimodal/s...
4 Two friends enjoy time spent together /home/ci/autogluon/docs/tutorials/multimodal/s...

Each row is one image and text pair, implying that they match each other. Since one image corresponds to five captions in the dataset, we copy each image path five times to build the correspondences. We can visualize one image-text pair.

train_data[text_col][0]
'Two young guys with shaggy hair look at their hands while hanging out in the yard'
pil_img = Image(filename=train_data[image_col][0])
display(pil_img)
../../../_images/b012c7e966f6550874ccb85ef9602d483aa89b8623dff9ffcdb0faab8f2ca9ab.jpg

To perform evaluation or semantic search, we need to extract the unique image and text items from text_data and add one label column in the test_data.

test_image_data = pd.DataFrame({image_col: test_data[image_col].unique().tolist()})
test_text_data = pd.DataFrame({text_col: test_data[text_col].unique().tolist()})
test_data_with_label = test_data.copy()
test_label_col = "relevance"
test_data_with_label[test_label_col] = [1] * len(test_data)

Initialize Predictor

To initialize a predictor for image-text matching, we need to set problem_type as image_text_similarity. query and response refer to the two dataframe columns in which two items in one row should match each other. You can set query=text_col and response=image_col, or query=image_col and response=text_col. In image-text matching, query and response are equivalent.

from autogluon.multimodal import MultiModalPredictor
predictor = MultiModalPredictor(
            query=text_col,
            response=image_col,
            problem_type="image_text_similarity",
            eval_metric="recall",
        )
/home/ci/opt/venv/lib/python3.11/site-packages/mmengine/optim/optimizer/zero_optimizer.py:11: DeprecationWarning: `TorchScript` support for functional optimizers is deprecated and will be removed in a future PyTorch release. Consider using the `torch.compile` optimizer instead.
  from torch.distributed.optim import \

By initializing the predictor for image_text_similarity, you have loaded the pretrained CLIP backbone openai/clip-vit-base-patch32.

Directly Evaluate on Test Dataset (Zero-shot)

You may be interested in getting the pretrained model’s performance on your data. Let’s compute the text-to-image and image-to-text retrieval scores.

txt_to_img_scores = predictor.evaluate(
            data=test_data_with_label,
            query_data=test_text_data,
            response_data=test_image_data,
            label=test_label_col,
            cutoffs=[1, 5, 10],
        )
img_to_txt_scores = predictor.evaluate(
            data=test_data_with_label,
            query_data=test_image_data,
            response_data=test_text_data,
            label=test_label_col,
            cutoffs=[1, 5, 10],
        )
print(f"txt_to_img_scores: {txt_to_img_scores}")
print(f"img_to_txt_scores: {img_to_txt_scores}")
txt_to_img_scores: {'recall@1': 0.58964, 'recall@5': 0.83513, 'recall@10': 0.90156}
img_to_txt_scores: {'recall@1': 0.15505, 'recall@5': 0.5708, 'recall@10': 0.7172}

Here we report the recall, which is the eval_metric in initializing the predictor above. One cutoff value means using the top k retrieved items to calculate the score. You may find that the text-to-image recalls are much higher than the image-to-text recalls. This is because each image is paired with five texts. In image-to-text retrieval, the upper bound of recall@1 is 20%, which means that the top-1 text is correct, but there are totally five texts to retrieve.

Finetune Predictor

After measuring the pretrained performance, we can finetune the model on our dataset to see whether we can get improvements. For a quick demo, here we set the time limit to 180 seconds.

predictor.fit(
            train_data=train_data,
            tuning_data=val_data,
            time_limit=180,
        )
No path specified. Models will be saved in: "AutogluonModels/ag-20250206_094435"
=================== System Info ===================
AutoGluon Version:  1.2.1b20250206
Python Version:     3.11.9
Operating System:   Linux
Platform Machine:   x86_64
Platform Version:   #1 SMP Tue Sep 24 10:00:37 UTC 2024
CPU Count:          8
Pytorch Version:    2.5.1+cu124
CUDA Version:       12.4
Memory Avail:       26.92 GB / 30.95 GB (87.0%)
Disk Space Avail:   171.58 GB / 255.99 GB (67.0%)
===================================================
AutoMM starts to create your model. ✨✨✨

To track the learning progress, you can open a terminal and launch Tensorboard:
    ```shell
    # Assume you have installed tensorboard
    tensorboard --logdir /home/ci/autogluon/docs/tutorials/multimodal/semantic_matching/AutogluonModels/ag-20250206_094435
    ```
INFO: Seed set to 0
GPU Count: 1
GPU Count to be Used: 1
GPU 0 Name: Tesla T4
GPU 0 Memory: 0.56GB/15.0GB (Used/Total)
INFO: Using 16bit Automatic Mixed Precision (AMP)
INFO: GPU available: True (cuda), used: True
INFO: TPU available: False, using: 0 TPU cores
INFO: HPU available: False, using: 0 HPUs
INFO: LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0]
INFO: 
  | Name              | Type                      | Params | Mode 
------------------------------------------------------------------------
0 | query_model       | CLIPForImageText          | 151 M  | train
1 | response_model    | CLIPForImageText          | 151 M  | train
2 | validation_metric | CustomHitRate             | 0      | train
3 | loss_func         | MultiNegativesSoftmaxLoss | 0      | train
------------------------------------------------------------------------
151 M     Trainable params
0         Non-trainable params
151 M     Total params
605.109   Total estimated model params size (MB)
5         Modules in train mode
306       Modules in eval mode
INFO: Time limit reached. Elapsed time is 0:03:00. Signaling Trainer to stop.
INFO: Epoch 0, global step 395: 'val_recall' reached 0.56177 (best 0.56177), saving model to '/home/ci/autogluon/docs/tutorials/multimodal/semantic_matching/AutogluonModels/ag-20250206_094435/epoch=0-step=395.ckpt' as top 3
Start to fuse 1 checkpoints via the greedy soup algorithm.
AutoMM has created your model. 🎉🎉🎉

To load the model, use the code below:
    ```python
    from autogluon.multimodal import MultiModalPredictor
    predictor = MultiModalPredictor.load("/home/ci/autogluon/docs/tutorials/multimodal/semantic_matching/AutogluonModels/ag-20250206_094435")
    ```

If you are not satisfied with the model, try to increase the training time, 
adjust the hyperparameters (https://auto.gluon.ai/stable/tutorials/multimodal/advanced_topics/customization.html),
or post issues on GitHub (https://github.com/autogluon/autogluon/issues).
<autogluon.multimodal.predictor.MultiModalPredictor at 0x7ff93874c7d0>

Evaluate the Finetuned Model on the Test Dataset

Now Let’s evaluate the finetuned model. Similarly, we also compute the recalls of text-to-image and image-to-text retrievals.

txt_to_img_scores = predictor.evaluate(
            data=test_data_with_label,
            query_data=test_text_data,
            response_data=test_image_data,
            label=test_label_col,
            cutoffs=[1, 5, 10],
        )
img_to_txt_scores = predictor.evaluate(
            data=test_data_with_label,
            query_data=test_image_data,
            response_data=test_text_data,
            label=test_label_col,
            cutoffs=[1, 5, 10],
        )
print(f"txt_to_img_scores: {txt_to_img_scores}")
print(f"img_to_txt_scores: {img_to_txt_scores}")
txt_to_img_scores: {'recall@1': 0.70048, 'recall@5': 0.90836, 'recall@10': 0.95398}
img_to_txt_scores: {'recall@1': 0.16905, 'recall@5': 0.6706, 'recall@10': 0.82}

We can observe large improvements over the zero-shot predictor. This means that finetuning CLIP on our customized data may help achieve better performance.

Predict Whether Image and Text Match

Whether finetuned or not, the predictor can predict whether image and text pairs match.

pred = predictor.predict(test_data.head(5))
print(pred)
0    1
1    1
2    1
3    1
4    1
dtype: int64

Predict Matching Probabilities

The predictor can also return to you the matching probabilities.

proba = predictor.predict_proba(test_data.head(5))
print(proba)
0         1
0  0.342339  0.657661
1  0.326096  0.673904
2  0.347501  0.652499
3  0.343473  0.656527
4  0.329360  0.670640

The second column is the probability of being a match.

Extract Embeddings

Another common user case is to extract image and text embeddings.

image_embeddings = predictor.extract_embedding({image_col: test_image_data[image_col][:5].tolist()})
print(image_embeddings.shape) 
(5, 512)
text_embeddings = predictor.extract_embedding({text_col: test_text_data[text_col][:5].tolist()})
print(text_embeddings.shape)
(5, 512)

Other Examples

You may go to AutoMM Examples to explore other examples about AutoMM.

Customization

To learn how to customize AutoMM, please refer to Customize AutoMM.