本文整理匯總了Python中soundfile.info方法的典型用法代碼示例。如果您正苦於以下問題:Python soundfile.info方法的具體用法?Python soundfile.info怎麽用?Python soundfile.info使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類soundfile
的用法示例。
在下文中一共展示了soundfile.info方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: _does_utt_match_target_format
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def _does_utt_match_target_format(self, utterance):
"""
Return ``True`` if the utterance already matches the target format,
``False`` otherwise.
"""
if utterance.track.path.endswith('mp3'):
return False
try:
info = sf.info(utterance.track.path)
for key, value in self.expected_properties.items():
if info.__getattribute__(key) != value:
return False
except RuntimeError:
return False
return True
示例2: main
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def main(args):
assert args.valid_percent >= 0 and args.valid_percent <= 1.
dir_path = os.path.realpath(args.root)
search_path = os.path.join(dir_path, '**/*.' + args.ext)
rand = random.Random(args.seed)
with open(os.path.join(args.dest, 'train.tsv'), 'w') as train_f, open(
os.path.join(args.dest, 'valid.tsv'), 'w') as valid_f:
print(dir_path, file=train_f)
print(dir_path, file=valid_f)
for fname in glob.iglob(search_path, recursive=True):
file_path = os.path.realpath(fname)
if args.path_must_contain and args.path_must_contain not in file_path:
continue
frames = soundfile.info(fname).frames
dest = train_f if rand.random() > args.valid_percent else valid_f
print('{}\t{}'.format(os.path.relpath(file_path, dir_path), frames), file=dest)
示例3: soundfile_loader
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def soundfile_loader(path, start=0, dur=None):
import soundfile
# get metadata
info = soundfile_info(path)
start = int(start * info['samplerate'])
# check if dur is none
if dur:
# stop in soundfile is calc in samples, not seconds
stop = start + int(dur * info['samplerate'])
else:
# set to None for reading complete file
stop = dur
audio, _ = soundfile.read(
path,
always_2d=True,
start=start,
stop=stop
)
return torch.FloatTensor(audio.T)
示例4: change_format_and_subtype
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def change_format_and_subtype(audio_path):
audio, sr = sf.read(audio_path)
audio_info = sf.info(audio_path)
formats = ['WAV', 'FLAC']
if audio_info.format in formats:
formats.remove(audio_info.format)
_format = random.choice(formats)
subtypes = sf.available_subtypes(_format)
accepted_subtypes = ['PCM_16', 'PCM_32', 'PCM_24', 'FLOAT', 'DOUBLE']
subtypes = [s for s in subtypes.keys() if s in accepted_subtypes]
if audio_info.subtype in subtypes:
subtypes.remove(audio_info.subtype)
_subtype = random.choice(subtypes)
sf.write(audio_path, audio, sr, subtype=_subtype, format=_format)
示例5: info
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def info(filepath: str) -> Tuple[SignalInfo, EncodingInfo]:
r"""See torchaudio.info"""
sfi = soundfile.info(filepath)
precision = _subtype_to_precision[sfi.subtype]
si = SignalInfo(sfi.channels, sfi.samplerate, precision, sfi.frames)
ei = EncodingInfo(bits_per_sample=precision)
return si, ei
示例6: _process_audio
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def _process_audio(self, root, id):
path = os.path.join(root, id + '.flac')
self.paths.append(path)
duration = soundfile.info(path).duration
self.durations.append(duration)
示例7: read_nsamples
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def read_nsamples(audio_path):
if audio_path.suffix == '.wv1':
f = open(audio_path, 'rb')
header = f.read(1024).decode("utf-8") # nist header is a multiple of
# 1024 bytes
nsamples = int(re.search("sample_count -i (.+?)\n", header).group(1))
else:
info = sf.info(str(audio_path), verbose=True)
nsamples = info.frames
return nsamples
示例8: _check_duration
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def _check_duration(fname, expected_duration, tolerance):
dur = sf.info(fname).duration
success = np.abs(dur - expected_duration) < tolerance
if not success:
raise warnings.warn('{} does not have the expected duration: {} !~ {}'
.format(fname, dur, expected_duration))
return success
示例9: soundfile_info
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def soundfile_info(path):
import soundfile
info = {}
sfi = soundfile.info(path)
info['samplerate'] = sfi.samplerate
info['samples'] = int(sfi.duration * sfi.samplerate)
info['duration'] = sfi.duration
return info
示例10: torchaudio_info
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def torchaudio_info(path):
import torchaudio
# get length of file in samples
info = {}
si, _ = torchaudio.info(str(path))
info['samplerate'] = si.rate
info['samples'] = si.length // si.channels
info['duration'] = info['samples'] / si.rate
return info
示例11: torchaudio_loader
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def torchaudio_loader(path, start=0, dur=None):
import torchaudio
info = torchaudio_info(path)
# loads the full track duration
if dur is None:
sig, rate = torchaudio.load(path)
return sig
# otherwise loads a random excerpt
else:
num_frames = int(dur * info['samplerate'])
offset = int(start * info['samplerate'])
sig, rate = torchaudio.load(
path, num_frames=num_frames, offset=offset
)
return sig
示例12: stats
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def stats(self):
if not self._stats:
self._stats = sf.info(self.filename)
return self._stats
示例13: __init__
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def __init__(
self,
path="None",
is_wav=False,
stem_id=None,
subset=None,
chunk_start=0,
chunk_duration=None
):
self.path = path
self.subset = subset
self.stem_id = stem_id
self.is_wav = is_wav
self.chunk_start = chunk_start
self.chunk_duration = chunk_duration
# load and store metadata
if os.path.exists(self.path):
if not self.is_wav:
self.info = stempeg.Info(self.path)
self.samples = int(self.info.samples(self.stem_id))
self.duration = self.info.duration(self.stem_id)
self.rate = self.info.rate(self.stem_id)
else:
self.info = sf.info(self.path)
self.samples = self.info.frames
self.duration = self.info.duration
self.rate = self.info.samplerate
else:
# set to `None` if no path was set (fake file)
self.info = None
self.samples = None
self.duration = None
self.rate = None
self._audio = None
示例14: load_audio
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def load_audio(self, path, stem_id, chunk_start=0, chunk_duration=None):
"""array_like: [shape=(num_samples, num_channels)]
"""
if os.path.exists(self.path):
if not self.is_wav:
# read using stempeg
audio, rate = stempeg.read_stems(
filename=path,
stem_id=stem_id,
start=chunk_start,
duration=chunk_duration,
info=self.info
)
else:
chunk_start = int(chunk_start * self.rate)
# check if dur is none
if chunk_duration:
# stop in soundfile is calc in samples, not seconds
stop = chunk_start + int(chunk_duration * self.rate)
else:
stop = chunk_duration
audio, rate = sf.read(
path,
always_2d=True,
start=chunk_start,
stop=stop
)
self._rate = rate
return audio
else:
self._rate = None
self._audio = None
raise ValueError("Oops! %s cannot be loaded" % path)
示例15: stems
# 需要導入模塊: import soundfile [as 別名]
# 或者: from soundfile import info [as 別名]
def stems(self):
"""array_like: [shape=(stems, num_samples, num_channels)]
"""
# return cached audio it explicitly set bet setter
if self._stems is not None:
return self._stems
# read from disk to save RAM otherwise
else:
if not self.is_wav and os.path.exists(self.path):
S, rate = stempeg.read_stems(
filename=self.path,
start=self.chunk_start,
duration=self.chunk_duration,
info=self.info
)
else:
rate = self.rate
S = []
S.append(self.audio)
# append sources in order of stem_ids
for k, v in sorted(self.sources.items(), key=lambda x: x[1].stem_id):
S.append(v.audio)
S = np.array(S)
self._rate = rate
return S