Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Regarding the issue of building torchaudio from source on Nvidia Jetson AGX Orin 64G #3882

Open
formioq opened this issue Feb 18, 2025 · 0 comments

Comments

@formioq
Copy link

formioq commented Feb 18, 2025

I attempted to install PyTorch and torchaudio on the Nvidia Jetson AGX Orin 64G. The installation of PyTorch was relatively successful, with version torch-2.0.0a0 installed. However, when I followed your installation documentation at https://pytorch.org/audio/2.0.1/build.jetson.html to install torchaudio using the command
USE_CUDA=1 USE_FFMPEG=1 pip install -v -e . --no-use-pep517
I encountered the error
subprocess.CalledProcessError: Command '['cmake', '--build', '.', '--target', 'install']' returned non-zero exit status 1
The full compilation process is as follows:

Using pip 25.0.1 from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/pip (python 3.8)
WARNING: Ignoring invalid distribution -orch (/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages)
Obtaining file:///home/liuzhiyan/biyesheji/audio
  Running command python setup.py egg_info
  -- Git branch: None
  -- Git SHA: None
  -- Git tag: None
  -- PyTorch dependency: torch
  -- Building version 2.6.0a0
  running egg_info
  creating /tmp/pip-pip-egg-info-0jn8jpm2/torchaudio.egg-info
  writing /tmp/pip-pip-egg-info-0jn8jpm2/torchaudio.egg-info/PKG-INFO
  writing dependency_links to /tmp/pip-pip-egg-info-0jn8jpm2/torchaudio.egg-info/dependency_links.txt
  writing requirements to /tmp/pip-pip-egg-info-0jn8jpm2/torchaudio.egg-info/requires.txt
  writing top-level names to /tmp/pip-pip-egg-info-0jn8jpm2/torchaudio.egg-info/top_level.txt
  writing manifest file '/tmp/pip-pip-egg-info-0jn8jpm2/torchaudio.egg-info/SOURCES.txt'
  reading manifest file '/tmp/pip-pip-egg-info-0jn8jpm2/torchaudio.egg-info/SOURCES.txt'
  adding license file 'LICENSE'
  writing manifest file '/tmp/pip-pip-egg-info-0jn8jpm2/torchaudio.egg-info/SOURCES.txt'
  Preparing metadata (setup.py) ... done
  WARNING: Ignoring invalid distribution -orch (/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages)
Requirement already satisfied: torch in /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages (from torchaudio==2.6.0a0) (2.0.0a0+8aa34602.nv23.3)
Requirement already satisfied: filelock in /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages (from torch->torchaudio==2.6.0a0) (3.13.1)
Requirement already satisfied: networkx in /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages (from torch->torchaudio==2.6.0a0) (3.0)
Requirement already satisfied: sympy in /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages (from torch->torchaudio==2.6.0a0) (1.13.1)
Requirement already satisfied: typing-extensions in /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages (from torch->torchaudio==2.6.0a0) (4.12.2)
Requirement already satisfied: mpmath<1.4,>=1.1.0 in /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages (from sympy->torch->torchaudio==2.6.0a0) (1.3.0)
WARNING: Ignoring invalid distribution -orch (/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages)
Installing collected packages: torchaudio
  DEPRECATION: Legacy editable install of torchaudio==2.6.0a0 from file:///home/liuzhiyan/biyesheji/audio (setup.py develop) is deprecated. pip 25.1 will enforce this behaviour change. A possible replacement is to add a pyproject.toml or enable --use-pep517, and use setuptools >= 64. If the resulting installation is not behaving as expected, try using --config-settings editable_mode=compat. Please consult the setuptools documentation for more information. Discussion can be found at https://github.com/pypa/pip/issues/11457
  Running setup.py develop for torchaudio
    Running command python setup.py develop
    -- Git branch: None
    -- Git SHA: None
    -- Git tag: None
    -- PyTorch dependency: torch
    -- Building version 2.6.0a0
    running develop
    running egg_info
    writing src/torchaudio.egg-info/PKG-INFO
    writing dependency_links to src/torchaudio.egg-info/dependency_links.txt
    writing requirements to src/torchaudio.egg-info/requires.txt
    writing top-level names to src/torchaudio.egg-info/top_level.txt
    reading manifest file 'src/torchaudio.egg-info/SOURCES.txt'
    adding license file 'LICENSE'
    writing manifest file 'src/torchaudio.egg-info/SOURCES.txt'
    running build_ext
    -- Caffe2: CUDA detected: 11.4
    -- Caffe2: CUDA nvcc is: /usr/local/cuda/bin/nvcc
    -- Caffe2: CUDA toolkit directory: /usr/local/cuda
    -- Caffe2: Header version is: 11.4
    -- /usr/local/cuda/lib64/libnvrtc.so shorthash is 7c7201d5
    -- USE_CUDNN is set to 0. Compiling without cuDNN support
    -- Autodetected CUDA architecture(s):  8.7
    -- Added CUDA NVCC flags for: -gencode;arch=compute_87,code=sm_87
    -- Could not find ccache. Consider installing ccache to speed up compilation.
    CMake Warning (dev) at /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/cmake/data/share/cmake-3.31/Modules/FetchContent.cmake:1953 (message):
      Calling FetchContent_Populate(sox_src) is deprecated, call
      FetchContent_MakeAvailable(sox_src) instead.  Policy CMP0169 can be set to
      OLD to allow FetchContent_Populate(sox_src) to be called directly for now,
      but the ability to call it with declared details will be removed completely
      in a future version.
    Call Stack (most recent call first):
      third_party/sox/CMakeLists.txt:14 (FetchContent_Populate)
    This warning is for project developers.  Use -Wno-dev to suppress it.

    CMake Warning (dev) at /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/cmake/data/share/cmake-3.31/Modules/FetchContent.cmake:1564 (cmake_parse_arguments):
      The BUILD_COMMAND keyword was followed by an empty string or no value at
      all.  Policy CMP0174 is not set, so cmake_parse_arguments() will unset the
      ARG_BUILD_COMMAND variable rather than setting it to an empty string.
    Call Stack (most recent call first):
      /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/cmake/data/share/cmake-3.31/Modules/FetchContent.cmake:2145:EVAL:2 (__FetchContent_doPopulation)
      /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/cmake/data/share/cmake-3.31/Modules/FetchContent.cmake:2145 (cmake_language)
      /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/cmake/data/share/cmake-3.31/Modules/FetchContent.cmake:1978:EVAL:1 (__FetchContent_Populate)
      /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/cmake/data/share/cmake-3.31/Modules/FetchContent.cmake:1978 (cmake_language)
      third_party/sox/CMakeLists.txt:14 (FetchContent_Populate)
    This warning is for project developers.  Use -Wno-dev to suppress it.

    CMake Warning (dev) at /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/cmake/data/share/cmake-3.31/Modules/FetchContent.cmake:1564 (cmake_parse_arguments):
      The CONFIGURE_COMMAND keyword was followed by an empty string or no value
      at all.  Policy CMP0174 is not set, so cmake_parse_arguments() will unset
      the ARG_CONFIGURE_COMMAND variable rather than setting it to an empty
      string.

      426 |   IValue(at::TensorBase t) : tag(Tag::Tensor) {
          |          ~~~~~~~~~~~~~~~^
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue.h:228:3: note: candidate: ‘c10::IValue::IValue(c10::IValue&&)’
      228 |   IValue(IValue&& rhs) noexcept : tag(rhs.tag) {
          |   ^~~~~~
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue.h:228:19: note:   no known conversion for argument 1 from ‘const std::optional<at::Tensor>’ to ‘c10::IValue&&’
      228 |   IValue(IValue&& rhs) noexcept : tag(rhs.tag) {
          |          ~~~~~~~~~^~~
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue.h:221:3: note: candidate: ‘c10::IValue::IValue(const c10::IValue&)’
      221 |   IValue(const IValue& rhs)
          |   ^~~~~~
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue.h:221:24: note:   no known conversion for argument 1 from ‘const std::optional<at::Tensor>’ to ‘const c10::IValue&’
      221 |   IValue(const IValue& rhs)
          |          ~~~~~~~~~~~~~~^~~
    In file included from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue.h:1467,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/List_inl.h:4,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/List.h:494,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/IListRef_inl.h:3,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/IListRef.h:632,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/DeviceGuard.h:3,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/ATen.h:9,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include/torch/types.h:3,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/script.h:3,
                     from /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rnnt/compute.h:3,
                     from /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rnnt/compute.cpp:1:
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue_inl.h: In instantiation of ‘T c10::generic_to(c10::IValue, c10::_fake_type<T>) [with T = std::optional<at::Tensor>]’:
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue_inl.h:1917:20:   required from ‘T c10::IValue::to() && [with T = std::optional<at::Tensor>]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/impl/boxing.h:168:27:   required from ‘static c10::impl::PopResult<std::tuple<_Tps ...> >::Result c10::impl::PopResult<std::tuple<_Tps ...> >::pop_to_tuple_impl(c10::Stack&, std::index_sequence<Is ...>) [with long unsigned int ...indices = {0, 1}; Types = {at::Tensor, std::optional<at::Tensor>}; c10::impl::PopResult<std::tuple<_Tps ...> >::Result = std::tuple<at::Tensor, std::optional<at::Tensor> >; c10::Stack = std::vector<c10::IValue>; std::index_sequence<Is ...> = std::integer_sequence<long unsigned int, 0, 1>]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/impl/boxing.h:161:29:   required from ‘static c10::impl::PopResult<std::tuple<_Tps ...> >::Result c10::impl::PopResult<std::tuple<_Tps ...> >::call(c10::Stack&) [with Types = {at::Tensor, std::optional<at::Tensor>}; c10::impl::PopResult<std::tuple<_Tps ...> >::Result = std::tuple<at::Tensor, std::optional<at::Tensor> >; c10::Stack = std::vector<c10::IValue>]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/impl/boxing.h:232:51:   required from ‘c10::impl::BoxedKernelWrapper<Result(Args ...), typename std::enable_if<((std::conjunction<c10::impl::can_box<Args>...>::value && std::conjunction<std::disjunction<c10::impl::has_ivalue_to<T, void>, std::is_same<void, T> >, std::negation<std::is_lvalue_reference<_Tp> > >::value) && (! c10::impl::is_tuple_of_mutable_tensor_refs<Result>::value)), void>::type>::call(const c10::BoxedKernel&, const c10::OperatorHandle&, c10::DispatchKeySet, Args ...) [with Result = std::tuple<at::Tensor, std::optional<at::Tensor> >; Args = {at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool}]::<lambda(auto:10)> [with auto:10 = c10::guts::detail::_identity]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/c10/util/C++17.h:232:41:   required by substitution of ‘template<class Func> struct c10::guts::detail::function_takes_identity_argument<Func, c10::guts::void_t<decltype (declval<Func>()(c10::guts::detail::_identity()))> > [with Func = c10::impl::BoxedKernelWrapper<Result(Args ...), typename std::enable_if<((std::conjunction<c10::impl::can_box<Args>...>::value && std::conjunction<std::disjunction<c10::impl::has_ivalue_to<T, void>, std::is_same<void, T> >, std::negation<std::is_lvalue_reference<_Tp> > >::value) && (! c10::impl::is_tuple_of_mutable_tensor_refs<Result>::value)), void>::type>::call(const c10::BoxedKernel&, const c10::OperatorHandle&, c10::DispatchKeySet, Args ...) [with Result = std::tuple<at::Tensor, std::optional<at::Tensor> >; Args = {at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool}]::<lambda(auto:10)>]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/c10/util/C++17.h:361:5:   required from ‘decltype(auto) c10::guts::if_constexpr(ThenCallback&&, ElseCallback&&) [with bool Condition = true; ThenCallback = c10::impl::BoxedKernelWrapper<Result(Args ...), typename std::enable_if<((std::conjunction<c10::impl::can_box<Args>...>::value && std::conjunction<std::disjunction<c10::impl::has_ivalue_to<T, void>, std::is_same<void, T> >, std::negation<std::is_lvalue_reference<_Tp> > >::value) && (! c10::impl::is_tuple_of_mutable_tensor_refs<Result>::value)), void>::type>::call(const c10::BoxedKernel&, const c10::OperatorHandle&, c10::DispatchKeySet, Args ...) [with Result = std::tuple<at::Tensor, std::optional<at::Tensor> >; Args = {at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool}]::<lambda(auto:10)>; ElseCallback = c10::impl::BoxedKernelWrapper<Result(Args ...), typename std::enable_if<((std::conjunction<c10::impl::can_box<Args>...>::value && std::conjunction<std::disjunction<c10::impl::has_ivalue_to<T, void>, std::is_same<void, T> >, std::negation<std::is_lvalue_reference<_Tp> > >::value) && (! c10::impl::is_tuple_of_mutable_tensor_refs<Result>::value)), void>::type>::call(const c10::BoxedKernel&, const c10::OperatorHandle&, c10::DispatchKeySet, Args ...) [with Result = std::tuple<at::Tensor, std::optional<at::Tensor> >; Args = {at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool}]::<lambda()>]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/impl/boxing.h:229:66:   required from ‘static Result c10::impl::BoxedKernelWrapper<Result(Args ...), typename std::enable_if<((std::conjunction<c10::impl::can_box<Args>...>::value && std::conjunction<std::disjunction<c10::impl::has_ivalue_to<T, void>, std::is_same<void, T> >, std::negation<std::is_lvalue_reference<_Tp> > >::value) && (! c10::impl::is_tuple_of_mutable_tensor_refs<Result>::value)), void>::type>::call(const c10::BoxedKernel&, const c10::OperatorHandle&, c10::DispatchKeySet, Args ...) [with Result = std::tuple<at::Tensor, std::optional<at::Tensor> >; Args = {at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool}]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/KernelFunction_impl.h:107:59:   required from ‘Return c10::KernelFunction::call(const c10::OperatorHandle&, c10::DispatchKeySet, Args ...) const [with Return = std::tuple<at::Tensor, std::optional<at::Tensor> >; Args = {at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool}]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/dispatch/Dispatcher.h:639:95:   required from ‘Return c10::Dispatcher::call(const c10::TypedOperatorHandle<Return(Args ...)>&, Args ...) const [with Return = std::tuple<at::Tensor, std::optional<at::Tensor> >; Args = {at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool}]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/dispatch/Dispatcher.h:487:97:   required from ‘Return c10::TypedOperatorHandle<Return(Args ...)>::call(Args ...) const [with Return = std::tuple<at::Tensor, std::optional<at::Tensor> >; Args = {at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool}]’
    /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rnnt/compute.cpp:22:24:   required from here
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue_inl.h:1785:9: error: no type named ‘element_type’ in ‘std::__remove_pointer_helper<std::optional<at::Tensor>, std::optional<at::Tensor> >::type’ {aka ‘class std::optional<at::Tensor>’}
     1785 |   using ElemType = typename std::remove_pointer<T>::type::element_type;
          |         ^~~~~~~~
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue_inl.h:1786:52: error: no matching function for call to ‘c10::IValue::<expression error>()’
     1786 |   return std::move(ivalue).toCustomClass<ElemType>();
          |                                                    ^
    In file included from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/List_inl.h:4,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/List.h:494,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/IListRef_inl.h:3,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/IListRef.h:632,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/DeviceGuard.h:3,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/ATen.h:9,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include/torch/types.h:3,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/script.h:3,
                     from /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rnnt/compute.h:3,
                     from /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rnnt/compute.cpp:1:
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue.h:500:25: note: candidate: ‘template<class T> c10::intrusive_ptr<T> c10::IValue::toCustomClass() &&’
      500 |   c10::intrusive_ptr<T> toCustomClass() &&;
          |                         ^~~~~~~~~~~~~
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue.h:500:25: note:   template argument deduction/substitution failed:
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue.h:502:25: note: candidate: ‘template<class T> c10::intrusive_ptr<T> c10::IValue::toCustomClass() const &’
      502 |   c10::intrusive_ptr<T> toCustomClass() const&;
          |                         ^~~~~~~~~~~~~
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue.h:502:25: note:   template argument deduction/substitution failed:
    [4/84] /usr/bin/c++ -DINCLUDE_ALIGN -DINCLUDE_RIR -DUSE_CUDA -Dlibtorchaudio_EXPORTS -I/home/liuzhiyan/biyesheji/audio/src -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include -isystem /usr/local/cuda/include -Wall -D_GLIBCXX_USE_CXX11_ABI=1 -O3 -DNDEBUG -std=gnu++17 -fPIC -D_GLIBCXX_USE_CXX11_ABI=1 -fopenmp -MD -MT src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rnnt/cpu/compute.cpp.o -MF src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rnnt/cpu/compute.cpp.o.d -o src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rnnt/cpu/compute.cpp.o -c /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rnnt/cpu/compute.cpp
    FAILED: src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rnnt/cpu/compute.cpp.o
    /usr/bin/c++ -DINCLUDE_ALIGN -DINCLUDE_RIR -DUSE_CUDA -Dlibtorchaudio_EXPORTS -I/home/liuzhiyan/biyesheji/audio/src -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include -isystem /usr/local/cuda/include -Wall -D_GLIBCXX_USE_CXX11_ABI=1 -O3 -DNDEBUG -std=gnu++17 -fPIC -D_GLIBCXX_USE_CXX11_ABI=1 -fopenmp -MD -MT src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rnnt/cpu/compute.cpp.o -MF src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rnnt/cpu/compute.cpp.o.d -o src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rnnt/cpu/compute.cpp.o -c /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rnnt/cpu/compute.cpp
    In file included from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue.h:1467,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/List_inl.h:4,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/List.h:494,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/IListRef_inl.h:3,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/IListRef.h:632,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/DeviceGuard.h:3,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/ATen.h:9,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include/torch/types.h:3,
                     from /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/script.h:3,
                     from /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rnnt/cpu/compute.cpp:2:
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue_inl.h: In instantiation of ‘c10::IValue c10::ivalue::detail::from_(T&&, std::false_type) [with T = std::optional<at::Tensor>; std::false_type = std::integral_constant<bool, false>]’:
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue_inl.h:2406:23:   required from ‘c10::IValue c10::ivalue::from(T&&) [with T = std::optional<at::Tensor>]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/impl/make_boxed_from_unboxed_functor.h:418:31:   required from ‘static c10::IValue c10::impl::return_to_ivalue<T, AllowDeprecatedTypes, typename std::enable_if<(! std::is_same<at::Tensor&, T>::value), void>::type>::call(T&&) [with T = std::optional<at::Tensor>; bool AllowDeprecatedTypes = false]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/impl/make_boxed_from_unboxed_functor.h:543:89:   required from ‘static void c10::impl::push_outputs<std::tuple<_Tps ...>, AllowDeprecatedTypes>::call_(std::tuple<_Tps ...>&&, c10::Stack*, std::index_sequence<Is ...>) [with long unsigned int ...indices = {0, 1}; OutputTypes = {at::Tensor, std::optional<at::Tensor>}; bool AllowDeprecatedTypes = false; c10::Stack = std::vector<c10::IValue>; std::index_sequence<Is ...> = std::integer_sequence<long unsigned int, 0, 1>]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/impl/make_boxed_from_unboxed_functor.h:534:12:   required from ‘static void c10::impl::push_outputs<std::tuple<_Tps ...>, AllowDeprecatedTypes>::call(std::tuple<_Tps ...>&&, c10::Stack*) [with OutputTypes = {at::Tensor, std::optional<at::Tensor>}; bool AllowDeprecatedTypes = false; c10::Stack = std::vector<c10::IValue>]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/impl/make_boxed_from_unboxed_functor.h:591:62:   required from ‘static void c10::impl::make_boxed_from_unboxed_functor<KernelFunctor, AllowDeprecatedTypes>::call(c10::OperatorKernel*, const c10::OperatorHandle&, c10::DispatchKeySet, c10::Stack*) [with KernelFunctor = c10::impl::detail::WrapFunctionIntoRuntimeFunctor_<std::tuple<at::Tensor, std::optional<at::Tensor> > (*)(at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool), std::tuple<at::Tensor, std::optional<at::Tensor> >, c10::guts::typelist::typelist<at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool> >; bool AllowDeprecatedTypes = false; c10::Stack = std::vector<c10::IValue>]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/KernelFunction_impl.h:159:9:   required from ‘static c10::KernelFunction c10::KernelFunction::makeFromUnboxedFunctor(std::unique_ptr<c10::OperatorKernel>) [with bool AllowLegacyTypes = false; KernelFunctor = c10::impl::detail::WrapFunctionIntoRuntimeFunctor_<std::tuple<at::Tensor, std::optional<at::Tensor> > (*)(at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool), std::tuple<at::Tensor, std::optional<at::Tensor> >, c10::guts::typelist::typelist<at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool> >]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/boxing/KernelFunction_impl.h:196:114:   required from ‘static c10::KernelFunction c10::KernelFunction::makeFromUnboxedRuntimeFunction(FuncType*) [with bool AllowLegacyTypes = false; FuncType = std::tuple<at::Tensor, std::optional<at::Tensor> >(at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool)]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/library.h:117:66:   required from ‘torch::CppFunction::CppFunction(Func*, std::enable_if_t<c10::guts::is_function_type<FuncType_>::value, std::nullptr_t>) [with Func = std::tuple<at::Tensor, std::optional<at::Tensor> >(at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool); std::enable_if_t<c10::guts::is_function_type<FuncType_>::value, std::nullptr_t> = std::nullptr_t]’
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/library.h:659:17:   required from ‘torch::Library& torch::Library::impl(Name, Func&&, torch::_RegisterOrVerify) & [with Name = const char*; Func = std::tuple<at::Tensor, std::optional<at::Tensor> > (*)(at::Tensor&, const at::Tensor&, const at::Tensor&, const at::Tensor&, long int, double, bool)]’
    /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rnnt/cpu/compute.cpp:145:31:   required from here
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/ATen/core/ivalue_inl.h:2398:25: error: static assertion failed: You are calling from with a type that it doesn't support, and isn't a potential custom class (ie: is an intrusive_ptr)
     2398 |       guts::false_t<T>::value,
          |                         ^~~~~
    [5/84] /usr/bin/c++ -DINCLUDE_ALIGN -DINCLUDE_RIR -DUSE_CUDA -Dlibtorchaudio_EXPORTS -I/home/liuzhiyan/biyesheji/audio/src -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include -isystem /usr/local/cuda/include -Wall -D_GLIBCXX_USE_CXX11_ABI=1 -O3 -DNDEBUG -std=gnu++17 -fPIC -D_GLIBCXX_USE_CXX11_ABI=1 -fopenmp -MD -MT src/libtorchaudio/CMakeFiles/libtorchaudio.dir/forced_align/compute.cpp.o -MF src/libtorchaudio/CMakeFiles/libtorchaudio.dir/forced_align/compute.cpp.o.d -o src/libtorchaudio/CMakeFiles/libtorchaudio.dir/forced_align/compute.cpp.o -c /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/forced_align/compute.cpp
    [6/84] /usr/bin/c++ -DINCLUDE_ALIGN -DINCLUDE_RIR -DUSE_CUDA -Dlibtorchaudio_EXPORTS -I/home/liuzhiyan/biyesheji/audio/src -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include -isystem /usr/local/cuda/include -Wall -D_GLIBCXX_USE_CXX11_ABI=1 -O3 -DNDEBUG -std=gnu++17 -fPIC -D_GLIBCXX_USE_CXX11_ABI=1 -fopenmp -MD -MT src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rir/rir.cpp.o -MF src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rir/rir.cpp.o.d -o src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rir/rir.cpp.o -c /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rir/rir.cpp
    [7/84] /usr/bin/c++ -DINCLUDE_ALIGN -DINCLUDE_RIR -DUSE_CUDA -Dlibtorchaudio_EXPORTS -I/home/liuzhiyan/biyesheji/audio/src -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include -isystem /usr/local/cuda/include -Wall -D_GLIBCXX_USE_CXX11_ABI=1 -O3 -DNDEBUG -std=gnu++17 -fPIC -D_GLIBCXX_USE_CXX11_ABI=1 -fopenmp -MD -MT src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rir/ray_tracing.cpp.o -MF src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rir/ray_tracing.cpp.o.d -o src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rir/ray_tracing.cpp.o -c /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rir/ray_tracing.cpp
    [8/84] /usr/bin/c++ -DINCLUDE_ALIGN -DINCLUDE_RIR -DUSE_CUDA -Dlibtorchaudio_EXPORTS -I/home/liuzhiyan/biyesheji/audio/src -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include -isystem /usr/local/cuda/include -Wall -D_GLIBCXX_USE_CXX11_ABI=1 -O3 -DNDEBUG -std=gnu++17 -fPIC -D_GLIBCXX_USE_CXX11_ABI=1 -fopenmp -MD -MT src/libtorchaudio/CMakeFiles/libtorchaudio.dir/forced_align/cpu/compute.cpp.o -MF src/libtorchaudio/CMakeFiles/libtorchaudio.dir/forced_align/cpu/compute.cpp.o.d -o src/libtorchaudio/CMakeFiles/libtorchaudio.dir/forced_align/cpu/compute.cpp.o -c /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/forced_align/cpu/compute.cpp
    [9/84] /usr/local/cuda/bin/nvcc -forward-unknown-to-host-compiler -DINCLUDE_ALIGN -DINCLUDE_RIR -DUSE_CUDA -Dlibtorchaudio_EXPORTS -I/home/liuzhiyan/biyesheji/audio/src -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include -isystem /usr/local/cuda/include -DCUDA_HAS_FP16=1     -D__CUDA_NO_HALF_OPERATORS__     -D__CUDA_NO_HALF_CONVERSIONS__     -D__CUDA_NO_HALF2_OPERATORS__ -DONNX_NAMESPACE=onnx_c2 -gencode arch=compute_87,code=sm_87 -Xcudafe --diag_suppress=cc_clobber_ignored,--diag_suppress=integer_sign_change,--diag_suppress=useless_using_declaration,--diag_suppress=set_but_not_used,--diag_suppress=field_without_dll_interface,--diag_suppress=base_class_has_different_dll_interface,--diag_suppress=dll_interface_conflict_none_assumed,--diag_suppress=dll_interface_conflict_dllexport_assumed,--diag_suppress=implicit_return_from_non_void_function,--diag_suppress=unsigned_compare_with_zero,--diag_suppress=declared_but_not_referenced,--diag_suppress=bad_friend_decl --expt-relaxed-constexpr --expt-extended-lambda -O3 -DNDEBUG -std=c++17 -Xcompiler=-fPIC -D_GLIBCXX_USE_CXX11_ABI=1 -MD -MT src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rnnt/gpu/compute_betas.cu.o -MF src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rnnt/gpu/compute_betas.cu.o.d -x cu -c /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/rnnt/gpu/compute_betas.cu -o src/libtorchaudio/CMakeFiles/libtorchaudio.dir/rnnt/gpu/compute_betas.cu.o
    [10/84] /usr/local/cuda/bin/nvcc -forward-unknown-to-host-compiler -DINCLUDE_ALIGN -DINCLUDE_RIR -DUSE_CUDA -Dlibtorchaudio_EXPORTS -I/home/liuzhiyan/biyesheji/audio/src -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include -isystem /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/torch/include/torch/csrc/api/include -isystem /usr/local/cuda/include -DCUDA_HAS_FP16=1     -D__CUDA_NO_HALF_OPERATORS__     -D__CUDA_NO_HALF_CONVERSIONS__     -D__CUDA_NO_HALF2_OPERATORS__ -DONNX_NAMESPACE=onnx_c2 -gencode arch=compute_87,code=sm_87 -Xcudafe --diag_suppress=cc_clobber_ignored,--diag_suppress=integer_sign_change,--diag_suppress=useless_using_declaration,--diag_suppress=set_but_not_used,--diag_suppress=field_without_dll_interface,--diag_suppress=base_class_has_different_dll_interface,--diag_suppress=dll_interface_conflict_none_assumed,--diag_suppress=dll_interface_conflict_dllexport_assumed,--diag_suppress=implicit_return_from_non_void_function,--diag_suppress=unsigned_compare_with_zero,--diag_suppress=declared_but_not_referenced,--diag_suppress=bad_friend_decl --expt-relaxed-constexpr --expt-extended-lambda -O3 -DNDEBUG -std=c++17 -Xcompiler=-fPIC -D_GLIBCXX_USE_CXX11_ABI=1 -MD -MT src/libtorchaudio/CMakeFiles/libtorchaudio.dir/forced_align/gpu/compute.cu.o -MF src/libtorchaudio/CMakeFiles/libtorchaudio.dir/forced_align/gpu/compute.cu.o.d -x cu -c /home/liuzhiyan/biyesheji/audio/src/libtorchaudio/forced_align/gpu/compute.cu -o src/libtorchaudio/CMakeFiles/libtorchaudio.dir/forced_align/gpu/compute.cu.o
    ninja: build stopped: subcommand failed.

    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/command/develop.py:41: EasyInstallDeprecationWarning: easy_install command is deprecated.
    !!

            ********************************************************************************
            Please avoid running ``setup.py`` and ``easy_install``.
            Instead, use pypa/build, pypa/installer or other
            standards-based tools.

            See https://github.com/pypa/setuptools/issues/917 for details.
            ********************************************************************************

    !!
      easy_install.initialize_options(self)
    /home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/_distutils/cmd.py:66: SetuptoolsDeprecationWarning: setup.py install is deprecated.
    !!

            ********************************************************************************
            Please avoid running ``setup.py`` directly.
            Instead, use pypa/build, pypa/installer or other
            standards-based tools.

            See https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.html for details.
            ********************************************************************************

    !!
      self.initialize_options()
    Traceback (most recent call last):
      File "<string>", line 2, in <module>
      File "<pip-setuptools-caller>", line 34, in <module>
      File "/home/liuzhiyan/biyesheji/audio/setup.py", line 144, in <module>
        _main()
      File "/home/liuzhiyan/biyesheji/audio/setup.py", line 99, in _main
        setup(
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/__init__.py", line 117, in setup
        return distutils.core.setup(**attrs)
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/_distutils/core.py", line 183, in setup
        return run_commands(dist)
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/_distutils/core.py", line 199, in run_commands
        dist.run_commands()
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/_distutils/dist.py", line 954, in run_commands
        self.run_command(cmd)
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/dist.py", line 999, in run_command
        super().run_command(command)
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/_distutils/dist.py", line 973, in run_command
        cmd_obj.run()
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/command/develop.py", line 35, in run
        self.install_for_development()
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/command/develop.py", line 112, in install_for_development
        self.run_command('build_ext')
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/_distutils/cmd.py", line 316, in run_command
        self.distribution.run_command(command)
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/dist.py", line 999, in run_command
        super().run_command(command)
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/_distutils/dist.py", line 973, in run_command
        cmd_obj.run()
      File "/home/liuzhiyan/biyesheji/audio/tools/setup_helpers/extension.py", line 99, in run
        super().run()
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/command/build_ext.py", line 98, in run
        _build_ext.run(self)
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/_distutils/command/build_ext.py", line 359, in run
        self.build_extensions()
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/_distutils/command/build_ext.py", line 476, in build_extensions
        self._build_extensions_serial()
      File "/home/liuzhiyan/.virtualenvs/biyesheji/lib/python3.8/site-packages/setuptools/_distutils/command/build_ext.py", line 502, in _build_extensions_serial
        self.build_extension(ext)
      File "/home/liuzhiyan/biyesheji/audio/tools/setup_helpers/extension.py", line 183, in build_extension
        subprocess.check_call(["cmake", "--build", "."] + build_args, cwd=self.build_temp)
      File "/usr/lib/python3.8/subprocess.py", line 364, in check_call
        raise CalledProcessError(retcode, cmd)
    subprocess.CalledProcessError: Command '['cmake', '--build', '.', '--target', 'install']' returned non-zero exit status 1.
    error: subprocess-exited-with-error
    
    × python setup.py develop did not run successfully.
    │ exit code: 1
    ╰─> See above for output.
    
    note: This error originates from a subprocess, and is likely not a problem with pip.
    full command: /home/liuzhiyan/.virtualenvs/biyesheji/bin/python3 -c '
    exec(compile('"'"''"'"''"'"'
    # This is <pip-setuptools-caller> -- a caller that pip uses to run setup.py
    #
    # - It imports setuptools before invoking setup.py, to enable projects that directly
    #   import from `distutils.core` to work with newer packaging standards.
    # - It provides a clear error message when setuptools is not installed.
    # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so
    #   setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning:
    #     manifest_maker: standard file '"'"'-c'"'"' not found".
    # - It generates a shim setup.py, for handling setup.cfg-only projects.
    import os, sys, tokenize
    
    try:
        import setuptools
    except ImportError as error:
        print(
            "ERROR: Can not execute `setup.py` since setuptools is not available in "
            "the build environment.",
            file=sys.stderr,
        )
        sys.exit(1)
    
    __file__ = %r
    sys.argv[0] = __file__
    
    if os.path.exists(__file__):
        filename = __file__
        with tokenize.open(__file__) as f:
            setup_py_code = f.read()
    else:
        filename = "<auto-generated setuptools caller>"
        setup_py_code = "from setuptools import setup; setup()"
    
    exec(compile(setup_py_code, filename, "exec"))
    '"'"''"'"''"'"' % ('"'"'/home/liuzhiyan/biyesheji/audio/setup.py'"'"',), "<pip-setuptools-caller>", "exec"))' develop --no-deps
    cwd: /home/liuzhiyan/biyesheji/audio/
error: subprocess-exited-with-error

× python setup.py develop did not run successfully.
│ exit code: 1
╰─> See above for output.

note: This error originates from a subprocess, and is likely not a problem with pip.

The full compilation process is too long to include here, but the complete log is provided in the attached text file.
Could you please advise on how to resolve this issue?

issue.txt

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant