如何从tf.data管道的tf.py_function中的python子进程模块运行shell命令?

问题描述 投票:0回答:1

我创建了tf.data.Dataset管道变量,我将一个python函数传递给该变量,该函数试图通过python的sox模块运行subprocess命令。该代码在带有Windows操作系统的cpu上运行良好,但无法在具有Linux操作系统的Google Colab的GPU上运行。这是代码-

from scipy.io import wavfile
import tensorflow as tf

    def tf_func(inp_sample):

        def func(inp_sample,<tf.string object>):
            try:
                fdesc, infile = tempfile.mkstemp(suffix=".wav")
                os.close(fdesc)
                fdesc, outfile = tempfile.mkstemp(suffix=".wav")
                os.close(fdesc)
                wavfile.write(infile,<sample rate>,inp_sample.numpy()) //writes audio file to disk
                arguments = ['sox',infile,outfile,'-q','compand',
                            *DRC_PRESET[<tf.string object>.numpy().decode('utf-8')]] 

                subprocess.check_call(arguments)

            finally:
                os.unlink(infile)
                os.unlink(outfile)

            return tf.convert_to_tensor(inp_sample,dtype=tf.float32)

        drc = np.random.choice(<lis of string>)
        [inp_sample,] = tf.py_function(dynamic_compression, 
                        [inp_sample,tf.constant(drc)],[tf.float32])
        inp_sample.set_shape(target_sample_size) //target_size=<some int>

        return inp_sample
...

inp=tf.data.Dataset.from_tensor_slices(inp) // inp shape eg: (4, 500)
inp = inp.map(tf_dynamic_compression)
for i in inp:
    print(i.numpy())

及其引发的错误-

UnknownError: 2 root error(s) found.
  (0) Unknown:   CalledProcessError: Command 'None' died with <Signals.SIGINT: 2>.
Traceback (most recent call last):

  File "/usr/local/lib/python3.6/dist-packages/tensorflow_core/python/ops/script_ops.py", line 233, in __call__
    return func(device, token, args)

  File "/usr/local/lib/python3.6/dist-packages/tensorflow_core/python/ops/script_ops.py", line 122, in __call__
    ret = self._func(*args)

  File "/tmp/tmpn_9q_jxm.py", line 24, in dynamic_compression
    ag__.converted_call(subprocess.check_call, dynamic_compression_scope.callopts, (arguments,), None, dynamic_compression_scope)

  File "/usr/local/lib/python3.6/dist-packages/tensorflow_core/python/autograph/impl/api.py", line 541, in converted_call
    result = converted_f(*effective_args)

  File "/tmp/tmpozf4qyav.py", line 50, in tf__check_call
    ag__.if_stmt(cond_1, if_true_1, if_false_1, get_state_1, set_state_1, (), ())

  File "/usr/local/lib/python3.6/dist-packages/tensorflow_core/python/autograph/operators/control_flow.py", line 895, in if_stmt
    return _py_if_stmt(cond, body, orelse)

  File "/usr/local/lib/python3.6/dist-packages/tensorflow_core/python/autograph/operators/control_flow.py", line 1004, in _py_if_stmt
    return body() if cond else orelse()

  File "/tmp/tmpozf4qyav.py", line 44, in if_true_1
    raise ag__.converted_call(CalledProcessError, check_call_scope.callopts, (retcode, cmd), None, check_call_scope)

如何解决此问题?

python-3.x subprocess tensorflow2.0 tensorflow-datasets sox
1个回答
0
投票

由于sox模块未执行subprocess而出现问题。之前已经回答了。有两种解决方案-

首先更改arguments

arguments = " ".join(['sox',infile,outfile,'-q','compand',*DRC_PRESET[<tf.string object>.numpy().decode('utf-8')]])

然后

  1. os.system(arguments)

    OR

  2. [subprocess.check_call(arguments, shell=True)

    ] >>
  3. 对我来说,第二

有效。
© www.soinside.com 2019 - 2024. All rights reserved.