mediapipe-nightly 0.10.10.post20240216__cp310-cp310-macosx_11_0_universal2.whl → 0.10.10.post20240220__cp310-cp310-macosx_11_0_universal2.whl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (22) hide show
  1. mediapipe/__init__.py +1 -1
  2. mediapipe/python/_framework_bindings.cpython-310-darwin.so +0 -0
  3. mediapipe/tasks/python/__init__.py +1 -0
  4. mediapipe/tasks/python/genai/__init__.py +14 -0
  5. mediapipe/tasks/python/genai/converter/__init__.py +24 -0
  6. mediapipe/tasks/python/genai/converter/converter_base.py +172 -0
  7. mediapipe/tasks/python/genai/converter/converter_factory.py +79 -0
  8. mediapipe/tasks/python/genai/converter/llm_converter.py +213 -0
  9. mediapipe/tasks/python/genai/converter/pytorch_converter.py +315 -0
  10. mediapipe/tasks/python/genai/converter/pytorch_converter_test.py +86 -0
  11. mediapipe/tasks/python/genai/converter/quantization_util.py +516 -0
  12. mediapipe/tasks/python/genai/converter/quantization_util_test.py +259 -0
  13. mediapipe/tasks/python/genai/converter/safetensors_converter.py +521 -0
  14. mediapipe/tasks/python/genai/converter/safetensors_converter_test.py +83 -0
  15. mediapipe/tasks/python/genai/converter/weight_bins_writer.py +111 -0
  16. mediapipe/tasks/python/genai/converter/weight_bins_writer_test.py +62 -0
  17. mediapipe/version.txt +1 -1
  18. {mediapipe_nightly-0.10.10.post20240216.dist-info → mediapipe_nightly-0.10.10.post20240220.dist-info}/METADATA +1 -1
  19. {mediapipe_nightly-0.10.10.post20240216.dist-info → mediapipe_nightly-0.10.10.post20240220.dist-info}/RECORD +21 -8
  20. {mediapipe_nightly-0.10.10.post20240216.dist-info → mediapipe_nightly-0.10.10.post20240220.dist-info}/LICENSE +0 -0
  21. {mediapipe_nightly-0.10.10.post20240216.dist-info → mediapipe_nightly-0.10.10.post20240220.dist-info}/WHEEL +0 -0
  22. {mediapipe_nightly-0.10.10.post20240216.dist-info → mediapipe_nightly-0.10.10.post20240220.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,111 @@
1
+ # Copyright 2024 The MediaPipe Authors.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ """ModelWriter for writing a set of weights as binary files."""
16
+
17
+ import contextlib
18
+ import os
19
+ from typing import Dict, Tuple
20
+
21
+ import numpy as np
22
+
23
+ from mediapipe.tasks.python.genai.converter import converter_base
24
+ from mediapipe.tasks.python.genai.converter import quantization_util
25
+
26
+
27
+ @contextlib.contextmanager
28
+ def filemanager(filename: str, mode: str):
29
+ try:
30
+ with open(filename, mode) as f:
31
+ yield f
32
+ finally:
33
+ pass
34
+
35
+
36
+ def removeprefix(s, prefix):
37
+ """Removes the prefix from a string."""
38
+ if s.startswith(prefix):
39
+ return s[len(prefix) :]
40
+ return s
41
+
42
+
43
+ class WeightBinsWriter(converter_base.ModelWriterBase):
44
+ """A ModelWriter for writing a set of weights as binary files."""
45
+
46
+ def get_weight_info(self, var_name: str, weight: np.ndarray) -> str:
47
+ """Gets the string that describes the weights."""
48
+ dtype_str = str(weight.dtype)
49
+ shape_str = '_'.join(map(str, weight.shape))
50
+ return f'mdl_vars.{var_name}.{dtype_str}.{shape_str}\n'
51
+
52
+ def write_variables(self, variables: Dict[str, Tuple[np.ndarray, bool]]):
53
+ """Writes variable to the binary files. One for each layer.
54
+
55
+ Args:
56
+ variables: A dictionary that maps from the target variable names to the
57
+ quantized tensor values along with a boolean that indicates whether to
58
+ pack the values (only applicable for the 4-bit quantized tensors).
59
+ """
60
+ weights_info = []
61
+ for var_name, value in variables.items():
62
+ output = value[0]
63
+ if value[1]:
64
+ # Squeeze the tensor to make sure it is a 1D array for packing.
65
+ output = np.expand_dims(np.ravel(output), axis=-1)
66
+ # Extra pack needed for 4 bit. We always pack the weights along the
67
+ # first dimension since the tensor has already been squeezed.
68
+ output = quantization_util.pack_4bit(output, 0)
69
+ if 'combined_qkv' in var_name:
70
+ var_name = removeprefix(var_name, 'mld_vars.')
71
+ var_name_q = var_name.replace('combined_qkv', 'q')
72
+ var_name_k = var_name.replace('combined_qkv', 'k')
73
+ var_name_v = var_name.replace('combined_qkv', 'v')
74
+ if output.shape[0] == 3:
75
+ weight_q, weight_k, weight_v = output
76
+ assert weight_q.shape == weight_k.shape == weight_v.shape
77
+ else: # LoRA right weight is shared across q, k, v
78
+ weight_q = weight_k = weight_v = output
79
+ weights_info.append(self.get_weight_info(var_name_q, weight_q))
80
+ path_q = os.path.join(self._output_dir, var_name_q)
81
+ with filemanager(path_q, 'wb') as f:
82
+ f.write(weight_q.tobytes())
83
+ weights_info.append(self.get_weight_info(var_name_k, weight_k))
84
+ path_k = os.path.join(self._output_dir, var_name_k)
85
+ with filemanager(path_k, 'wb') as f:
86
+ f.write(weight_k.tobytes())
87
+ path_v = os.path.join(self._output_dir, var_name_v)
88
+ with filemanager(path_v, 'wb') as f:
89
+ f.write(weight_v.tobytes())
90
+ weights_info.append(self.get_weight_info(var_name_v, weight_v))
91
+ else:
92
+ if 'key' in var_name:
93
+ var_name = var_name.replace('key', 'k')
94
+ if 'query' in var_name:
95
+ var_name = var_name.replace('query', 'q')
96
+ if 'value' in var_name:
97
+ var_name = var_name.replace('value', 'v')
98
+ path = os.path.join(
99
+ self._output_dir, removeprefix(var_name, 'mdl_vars.')
100
+ )
101
+ with filemanager(path, 'wb') as f:
102
+ f.write(output.tobytes())
103
+ weights_info.append(self.get_weight_info(var_name, output))
104
+
105
+ # Sort weights_info
106
+ weights_info.sort()
107
+ with filemanager(
108
+ os.path.join(self._output_dir, 'layer_info.txt'), 'w'
109
+ ) as finfo:
110
+ for line in weights_info:
111
+ finfo.write(line + '\n')
@@ -0,0 +1,62 @@
1
+ # Copyright 2024 The MediaPipe Authors.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ """Unit tests for pax_converter."""
16
+
17
+ import os
18
+
19
+ from absl import flags
20
+ from absl.testing import absltest
21
+ from absl.testing import parameterized
22
+ import numpy as np
23
+
24
+ from mediapipe.tasks.python.genai.converter import weight_bins_writer
25
+
26
+
27
+ class WeightBinsWriterTest(parameterized.TestCase):
28
+
29
+ def test_get_weight_info(self):
30
+ output_dir = os.path.join(flags.FLAGS.test_tmpdir, 'output_dir')
31
+ writer = weight_bins_writer.WeightBinsWriter(
32
+ output_dir=output_dir, backend='cpu'
33
+ )
34
+ var_name = 'params.lm.softmax.logits_ffn.linear.w'
35
+ weight_info = writer.get_weight_info(
36
+ var_name, np.array([[1, 2, 3], [4, 5, 6]], dtype=np.float32)
37
+ )
38
+ self.assertEqual(
39
+ weight_info,
40
+ 'mdl_vars.params.lm.softmax.logits_ffn.linear.w.float32.2_3\n',
41
+ )
42
+
43
+ def test_load_to_actions(self):
44
+ output_dir = os.path.join(flags.FLAGS.test_tmpdir, 'output_dir')
45
+ writer = weight_bins_writer.WeightBinsWriter(
46
+ output_dir=output_dir, backend='cpu'
47
+ )
48
+ variables = {
49
+ 'mdl_vars.params.lm.softmax.logits_ffn.linear.w': (
50
+ np.array([[1, 2, 3], [4, 5, 6]], dtype=np.float32),
51
+ False,
52
+ ),
53
+ }
54
+ writer.write_variables(variables)
55
+ file_size = os.path.getsize(
56
+ os.path.join(output_dir, 'params.lm.softmax.logits_ffn.linear.w')
57
+ )
58
+ self.assertEqual(file_size, 6 * 4)
59
+
60
+
61
+ if __name__ == '__main__':
62
+ absltest.main()
mediapipe/version.txt CHANGED
@@ -1 +1 @@
1
- 0.10.10-20240216
1
+ 0.10.10-20240220
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: mediapipe-nightly
3
- Version: 0.10.10.post20240216
3
+ Version: 0.10.10.post20240220
4
4
  Summary: MediaPipe is the simplest way for researchers and developers to build world-class ML solutions and applications for mobile, edge, cloud and the web.
5
5
  Home-page: https://github.com/google/mediapipe
6
6
  Author: The MediaPipe Authors
@@ -1,11 +1,11 @@
1
- mediapipe_nightly-0.10.10.post20240216.dist-info/RECORD,,
2
- mediapipe_nightly-0.10.10.post20240216.dist-info/LICENSE,sha256=hwfu8FM5h-_FsVXWR2HutuIHk_ULm9Gmja0c9HGdDtg,12331
3
- mediapipe_nightly-0.10.10.post20240216.dist-info/WHEEL,sha256=M8b9ULkaMplgMtp3yPg8hIiqGMbYy3WJOJ_rS5NiMpg,111
4
- mediapipe_nightly-0.10.10.post20240216.dist-info/top_level.txt,sha256=LG-epD1oIiiHFRqLp--7jacjB3dbx2RfMcLYjCIhmxU,175
5
- mediapipe_nightly-0.10.10.post20240216.dist-info/METADATA,sha256=UOivjWZI-gIVxzgH2pfjxL15cS2JmVVJHX3pZkWGe9Y,9672
6
- mediapipe/__init__.py,sha256=qqZ9eB_asECNYDc7jx1XIZ-5heE3E3wuuTnMqgP6Zf8,816
1
+ mediapipe_nightly-0.10.10.post20240220.dist-info/RECORD,,
2
+ mediapipe_nightly-0.10.10.post20240220.dist-info/LICENSE,sha256=hwfu8FM5h-_FsVXWR2HutuIHk_ULm9Gmja0c9HGdDtg,12331
3
+ mediapipe_nightly-0.10.10.post20240220.dist-info/WHEEL,sha256=M8b9ULkaMplgMtp3yPg8hIiqGMbYy3WJOJ_rS5NiMpg,111
4
+ mediapipe_nightly-0.10.10.post20240220.dist-info/top_level.txt,sha256=LG-epD1oIiiHFRqLp--7jacjB3dbx2RfMcLYjCIhmxU,175
5
+ mediapipe_nightly-0.10.10.post20240220.dist-info/METADATA,sha256=EhYSeSZKjHI0a_l13O29t73CzTLaRhFQix-W_s_lVX8,9672
6
+ mediapipe/__init__.py,sha256=rdbukqBkiz5MY5H-FrACK0jAtVcmijeoMWNeVR_bhrU,816
7
7
  mediapipe/tasks/__init__.py,sha256=sVJS2p8J2PNVl8DLRPVY6KLpHenP_z3QVPRU0x_iL5g,571
8
- mediapipe/tasks/python/__init__.py,sha256=i-0yWpv_VgAcZeBFQZiLlgIb0FuFb1fHdT--0EqLCAU,838
8
+ mediapipe/tasks/python/__init__.py,sha256=wIM_WOWboOVI1MeehN8fkN_DjoA0MEBVw5mShAd8AS4,858
9
9
  mediapipe/tasks/python/benchmark/__init__.py,sha256=epEucluzX0HinwBZoS7Tgb19j_qgfTuBf-vBkqemch8,587
10
10
  mediapipe/tasks/python/benchmark/benchmark_utils.py,sha256=5qbqGxxYlJJQLJzbW0cwMCcGl4c8ZfKL3rNmm7xMVAE,2241
11
11
  mediapipe/tasks/python/benchmark/vision/benchmark.py,sha256=gifRumSkesmXVU51GHRct-UYf8S9Dn2isD28Aw7BClQ,3491
@@ -85,6 +85,19 @@ mediapipe/tasks/python/text/text_embedder.py,sha256=JB-jQyVgcbfH8tOuJjV2Qyk2ewyU
85
85
  mediapipe/tasks/python/text/text_classifier.py,sha256=AJbYep6iL8vkf6JKRrGArr9sNd5ugLEliOK1tNr3DsE,7917
86
86
  mediapipe/tasks/python/text/core/base_text_task_api.py,sha256=OHt7j_0n5c3HBdOrCb_BGWCdKWMKvDULp6tKA5mDZAc,1822
87
87
  mediapipe/tasks/python/text/core/__init__.py,sha256=ZKC2XRtShVe6k6u6LxDt1pG7DQIn5nZnjurs6Pcvm6A,593
88
+ mediapipe/tasks/python/genai/__init__.py,sha256=7rri6fT6wNurla8O2c5yKiLs9_3qIY0vKkyVAUDe-18,620
89
+ mediapipe/tasks/python/genai/converter/pytorch_converter_test.py,sha256=hJOjozkWpzjedhkfWoF-vinSMs7TqCPO-W9VpleQo2U,3008
90
+ mediapipe/tasks/python/genai/converter/safetensors_converter_test.py,sha256=bdBHCQOTqAyHpC19di_H0hV3zraBOXXfV_6NbFT0ouw,2796
91
+ mediapipe/tasks/python/genai/converter/quantization_util.py,sha256=B6i13GqRRIwMabEJWO8rFHPMBjIgdOhFpHiwMD4GzRc,17196
92
+ mediapipe/tasks/python/genai/converter/safetensors_converter.py,sha256=IbnvTH_n8hnVd9nChOT8oGx2Ssw4iCFCnlWB1708ujc,18710
93
+ mediapipe/tasks/python/genai/converter/weight_bins_writer_test.py,sha256=6qgNYXODNOsbveZ0ighEW4JBdawil9mPcC16MZ0mdm8,1994
94
+ mediapipe/tasks/python/genai/converter/converter_base.py,sha256=nRIhPYUg2pkUZcmwMIDVM4lskRRUwoOYep9MY78b2xE,6519
95
+ mediapipe/tasks/python/genai/converter/pytorch_converter.py,sha256=RiuCr2aXbZVn3Ssa3OcSx_RQK56rfZRCpvG7qYIji4w,10675
96
+ mediapipe/tasks/python/genai/converter/__init__.py,sha256=jfUkinDJR5BVldnbJMbo5vIr2Xc5Z4TTnaCJTNoAUvg,893
97
+ mediapipe/tasks/python/genai/converter/converter_factory.py,sha256=2K16PZBQym0WhXM2HOdBMHMugykohoD4OTaOIo-UKko,2928
98
+ mediapipe/tasks/python/genai/converter/llm_converter.py,sha256=_S8fj-WAA6OMQFj_QZPChlfkJ4gp_DE2t8i4pwJAHjI,7782
99
+ mediapipe/tasks/python/genai/converter/quantization_util_test.py,sha256=ICujhTFeREGuHGmNk1PlBpf1AUThFvv-Wl5UuZ-xWAk,9060
100
+ mediapipe/tasks/python/genai/converter/weight_bins_writer.py,sha256=Ar8XBs1GhVSFObqN29K754iVZ_WSxe4k0Rty1a4vla0,4308
88
101
  mediapipe/tasks/python/metadata/metadata.py,sha256=EECQnM-Af0angD60jaBBOuNMgt7HExH6SqVtVMFNHGc,33763
89
102
  mediapipe/tasks/python/metadata/metadata_displayer_cli.py,sha256=tLhF0B1mXG0igFTA9nPh8t1efRpRw2hQ00XpTPYdk_o,1202
90
103
  mediapipe/tasks/python/metadata/__init__.py,sha256=YGHXQMz1ZGPcNgSXggu03b0USZKE8d9Xqvn6NDUl898,586
@@ -293,7 +306,7 @@ mediapipe/util/analytics/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZ
293
306
  mediapipe/util/analytics/mediapipe_log_extension_pb2.py,sha256=UX1x8jckc8NQbUz-SXOKkb8co3JNIRX3rfaMs4_Dz8g,4319
294
307
  mediapipe/util/analytics/mediapipe_logging_enums_pb2.py,sha256=9pxs-DNSQnXQe7E_LKokGDbD_G1FpmzzJw1jzex78lU,3781
295
308
  mediapipe/python/solution_base.py,sha256=48PszV6dCssQUkyPBaqhqVehVjPtskawtGUc54k10DM,25624
296
- mediapipe/python/_framework_bindings.cpython-310-darwin.so,sha256=MIG8Ri_ckCo8UQiT460iWyRZU__Ph4g7x7Nu6vM3mtE,78020947
309
+ mediapipe/python/_framework_bindings.cpython-310-darwin.so,sha256=hB-quaKQIVSWYWvzmJ6CAG6TM_rmpeRMiIEsIrys_0A,78069939
297
310
  mediapipe/python/timestamp_test.py,sha256=oWKTZMsV586jH57OBV30rihcymETyGC29VbYURNLJQQ,2528
298
311
  mediapipe/python/image_frame_test.py,sha256=ZSjdE-an2t8i6MiA4_Xri91VMH5_CCx45fjhWUQptMY,8602
299
312
  mediapipe/python/__init__.py,sha256=xTuq4e55ofMUGUpV81ZbVzYHmjMmzt9dBOfS4ugFN1c,1428