| | |
| | | return load_bytes(bytes) |
| | | |
| | | DATA_TYPES = { |
| | | "sound": lambda x: torchaudio.load(x)[0][0].numpy(), |
| | | "sound": lambda x: torchaudio.load(x)[0].numpy(), |
| | | "pcm": load_pcm, |
| | | "kaldi_ark": load_kaldi, |
| | | "bytes": load_bytes, |
| | |
| | | ] = None, |
| | | float_dtype: str = "float32", |
| | | fs: dict = None, |
| | | mc: bool = False, |
| | | int_dtype: str = "long", |
| | | key_file: str = None, |
| | | ): |
| | |
| | | self.int_dtype = int_dtype |
| | | self.key_file = key_file |
| | | self.fs = fs |
| | | self.mc = mc |
| | | |
| | | self.debug_info = {} |
| | | non_iterable_list = [] |
| | |
| | | array = torchaudio.transforms.Resample(orig_freq=audio_fs, |
| | | new_freq=model_fs)(array) |
| | | array = array.squeeze(0).numpy() |
| | | |
| | | data[name] = array |
| | | |
| | | if self.preprocess is not None: |
| | |
| | | model_fs = self.fs["model_fs"] |
| | | if audio_fs is not None and model_fs is not None: |
| | | array = torch.from_numpy(array) |
| | | array = array.unsqueeze(0) |
| | | array = torchaudio.transforms.Resample(orig_freq=audio_fs, |
| | | new_freq=model_fs)(array) |
| | | array = array.squeeze(0).numpy() |
| | | data[name] = array |
| | | array = array.numpy() |
| | | |
| | | if _type == "sound": |
| | | if self.mc: |
| | | data[name] = array.transpose((1, 0)) |
| | | else: |
| | | data[name] = array[0] |
| | | else: |
| | | data[name] = array |
| | | |
| | | if self.preprocess is not None: |
| | | data = self.preprocess(uid, data) |
| | |
| | | model_fs = self.fs["model_fs"] |
| | | if audio_fs is not None and model_fs is not None: |
| | | array = torch.from_numpy(array) |
| | | array = array.unsqueeze(0) |
| | | array = torchaudio.transforms.Resample(orig_freq=audio_fs, |
| | | new_freq=model_fs)(array) |
| | | array = array.squeeze(0).numpy() |
| | | data[name] = array |
| | | array = array.numpy() |
| | | if _type == "sound": |
| | | if self.mc: |
| | | data[name] = array.transpose((1, 0)) |
| | | else: |
| | | data[name] = array[0] |
| | | else: |
| | | data[name] = array |
| | | if self.non_iterable_dataset is not None: |
| | | # 2.b. Load data from non-iterable dataset |
| | | _, from_non_iterable = self.non_iterable_dataset[uid] |