Apache MXNet-MXNet 설치

MXNet을 시작하려면 가장 먼저해야 할 일은 컴퓨터에 설치하는 것입니다. Apache MXNet은 Windows, Mac 및 Linux를 포함하여 사용 가능한 거의 모든 플랫폼에서 작동합니다.

Linux OS

다음과 같은 방법으로 Linux OS에 MXNet을 설치할 수 있습니다.

그래픽 처리 장치 (GPU)

여기서는 처리를 위해 GPU를 사용할 때 MXNet을 설치하기 위해 Pip, Docker 및 Source라는 다양한 방법을 사용합니다.

Pip 방식을 사용하여

다음 명령을 사용하여 Linus OS에 MXNet을 설치할 수 있습니다.

pip install mxnet

Apache MXNet은 또한 인텔 하드웨어에서 실행할 때 훨씬 빠른 MKL pip 패키지를 제공합니다. 예를 들어 여기mxnet-cu101mkl 의미-

  • 이 패키지는 CUDA / cuDNN으로 구축되었습니다.

  • 패키지는 MKL-DNN을 지원합니다.

  • CUDA 버전은 10.1입니다.

다른 옵션에 대해서는 다음을 참조 할 수도 있습니다. https://pypi.org/project/mxnet/.

Docker를 사용하여

MXNet을 사용하는 Docker 이미지는 DockerHub에서 찾을 수 있습니다. https://hub.docker.com/u/mxnet GPU와 함께 Docker를 사용하여 MXNet을 설치하려면 아래 단계를 확인하십시오.

Step 1− 먼저 다음 위치에서 제공되는 도커 설치 지침을 따릅니다. https://docs.docker.com/engine/install/ubuntu/. 컴퓨터에 Docker를 설치해야합니다.

Step 2− 도커 컨테이너에서 GPU 사용을 활성화하려면 다음으로 nvidia-docker-plugin을 설치해야합니다. 다음에서 제공되는 설치 지침을 따를 수 있습니다.https://github.com/NVIDIA/nvidia-docker/wiki.

Step 3− 다음 명령을 사용하여 MXNet 도커 이미지를 가져올 수 있습니다. −

$ sudo docker pull mxnet/python:gpu

이제 mxnet / python 도커 이미지 풀이 성공했는지 확인하기 위해 다음과 같이 도커 이미지를 나열 할 수 있습니다.

$ sudo docker images

MXNet에서 가장 빠른 추론 속도를 위해 Intel MKL-DNN과 함께 최신 MXNet을 사용하는 것이 좋습니다. 아래 명령을 확인하십시오-

$ sudo docker pull mxnet/python:1.3.0_cpu_mkl
$ sudo docker images

소스에서

GPU를 사용하여 소스에서 MXNet 공유 라이브러리를 구축하려면 먼저 CUDA 및 cuDNN에 대한 환경을 다음과 같이 설정해야합니다.

  • CUDA 툴킷을 다운로드하여 설치하십시오. 여기서 CUDA 9.2를 권장합니다.

  • 다음 다운로드 cuDNN 7.1.4.

  • 이제 파일의 압축을 풀어야합니다. 또한 cuDNN 루트 디렉토리로 변경해야합니다. 또한 다음과 같이 헤더와 라이브러리를 로컬 CUDA Toolkit 폴더로 이동하십시오.

tar xvzf cudnn-9.2-linux-x64-v7.1
sudo cp -P cuda/include/cudnn.h /usr/local/cuda/include
sudo cp -P cuda/lib64/libcudnn* /usr/local/cuda/lib64
sudo chmod a+r /usr/local/cuda/include/cudnn.h /usr/local/cuda/lib64/libcudnn*
sudo ldconfig

CUDA 및 cuDNN에 대한 환경을 설정 한 후 아래 단계에 따라 소스에서 MXNet 공유 라이브러리를 빌드하십시오.

Step 1− 먼저 필수 패키지를 설치해야합니다. 이러한 종속성은 Ubuntu 버전 16.04 이상에서 필요합니다.

sudo apt-get update
sudo apt-get install -y build-essential git ninja-build ccache libopenblas-dev 
libopencv-dev cmake

Step 2−이 단계에서는 MXNet 소스를 다운로드하고 구성합니다. 먼저 다음 명령을 사용하여 저장소를 복제하겠습니다.

git clone –recursive https://github.com/apache/incubator-mxnet.git mxnet
cd mxnet
cp config/linux_gpu.cmake #for build with CUDA

Step 3− 다음 명령어를 사용하여 MXNet core 공유 라이브러리를 구축 할 수 있습니다.

rm -rf build
mkdir -p build && cd build
cmake -GNinja ..
cmake --build .

Two important points regarding the above step is as follows−

디버그 버전을 빌드하려면 다음과 같이 지정하십시오.

cmake -DCMAKE_BUILD_TYPE=Debug -GNinja ..

병렬 컴파일 작업의 수를 설정하려면 다음을 지정하십시오.

cmake --build . --parallel N

MXNet 코어 공유 라이브러리를 성공적으로 빌드하면 build 귀하의 폴더 MXNet project root, 당신은 발견 할 것이다 libmxnet.so 언어 바인딩을 설치하는 데 필요합니다 (선택 사항).

중앙 처리 장치 (CPU)

여기서는 처리를 위해 CPU를 사용할 때 MXNet을 설치하기 위해 Pip, Docker 및 Source라는 다양한 방법을 사용합니다.

Pip 방식을 사용하여

다음 명령을 사용하여 Linus OS에 MXNet을 설치할 수 있습니다.

pip install mxnet

Apache MXNet은 또한 인텔 하드웨어에서 실행할 때 훨씬 빠른 MKL-DNN 지원 pip 패키지를 제공합니다.

pip install mxnet-mkl

Docker를 사용하여

MXNet을 사용하는 Docker 이미지는 DockerHub에서 찾을 수 있습니다. https://hub.docker.com/u/mxnet. CPU와 함께 Docker를 사용하여 MXNet을 설치하려면 아래 단계를 확인하십시오.

Step 1− 먼저 다음 위치에서 제공되는 도커 설치 지침을 따릅니다. https://docs.docker.com/engine/install/ubuntu/. 컴퓨터에 Docker를 설치해야합니다.

Step 2− 다음 명령을 사용하여 MXNet 도커 이미지를 가져올 수 있습니다.

$ sudo docker pull mxnet/python

이제 mxnet / python 도커 이미지 풀이 성공했는지 확인하기 위해 다음과 같이 도커 이미지를 나열 할 수 있습니다.

$ sudo docker images

MXNet에서 가장 빠른 추론 속도를 위해 Intel MKL-DNN과 함께 최신 MXNet을 사용하는 것이 좋습니다.

아래 명령을 확인하십시오-

$ sudo docker pull mxnet/python:1.3.0_cpu_mkl
$ sudo docker images

소스에서

CPU가있는 소스에서 MXNet 공유 라이브러리를 빌드하려면 아래 단계를 따르십시오.

Step 1− 먼저 필수 패키지를 설치해야합니다. 이러한 종속성은 Ubuntu 버전 16.04 이상에서 필요합니다.

sudo apt-get update

sudo apt-get install -y build-essential git ninja-build ccache libopenblas-dev libopencv-dev cmake

Step 2−이 단계에서는 MXNet 소스를 다운로드하고 구성합니다. 먼저 다음 명령을 사용하여 저장소를 복제 해 보겠습니다.

git clone –recursive https://github.com/apache/incubator-mxnet.git mxnet

cd mxnet
cp config/linux.cmake config.cmake

Step 3− 다음 명령을 사용하여 MXNet 코어 공유 라이브러리를 구축 할 수 있습니다.

rm -rf build
mkdir -p build && cd build
cmake -GNinja ..
cmake --build .

Two important points regarding the above step is as follows−

디버그 버전을 빌드하려면 다음과 같이 지정하십시오.

cmake -DCMAKE_BUILD_TYPE=Debug -GNinja ..

병렬 컴파일 작업 수를 설정하려면 다음을 지정하십시오.

cmake --build . --parallel N

MXNet 코어 공유 라이브러리를 성공적으로 빌드하면 build MXNet 프로젝트 루트의 폴더에서 libmxnet.so를 찾을 수 있으며, 이는 언어 바인딩을 설치하는 데 필요합니다 (선택 사항).

맥 OS

다음과 같은 방법으로 MacOS에 MXNet을 설치할 수 있습니다.

그래픽 처리 장치 (GPU)

GPU를 사용하는 MacOS에서 MXNet을 빌드하려는 경우 사용 가능한 Pip 및 Docker 방법이 없습니다. 이 경우 유일한 방법은 소스에서 빌드하는 것입니다.

소스에서

GPU를 사용하여 소스에서 MXNet 공유 라이브러리를 빌드하려면 먼저 CUDA 및 cuDNN에 대한 환경을 설정해야합니다. 당신은 따라야NVIDIA CUDA Installation Guide 사용할 수있는 https://docs.nvidia.com 과 cuDNN Installation Guide, 사용할 수있는 https://docs.nvidia.com/deeplearning Mac OS 용.

2019 년에 CUDA는 macOS 지원을 중단했습니다. 사실 향후 CUDA 버전도 macOS를 지원하지 않을 수 있습니다.

CUDA 및 cuDNN에 대한 환경을 설정했으면 아래 단계에 따라 OS X (Mac)의 소스에서 MXNet을 설치합니다.

Step 1− OS x에 대한 종속성이 필요하기 때문에 먼저 필수 패키지를 설치해야합니다.

xcode-select –-install #Install OS X Developer Tools

/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" #Install Homebrew

brew install cmake ninja ccache opencv # Install dependencies

opencv는 선택적 종속성이므로 OpenCV없이 MXNet을 빌드 할 수도 있습니다.

Step 2−이 단계에서는 MXNet 소스를 다운로드하고 구성합니다. 먼저 다음 명령을 사용하여 저장소를 복제하겠습니다.

git clone –-recursive https://github.com/apache/incubator-mxnet.git mxnet

cd mxnet
cp config/linux.cmake config.cmake

GPU 지원의 경우 GPU가없는 머신에서 GPU 지원 빌드를 빌드하려고하면 MXNet 빌드가 GPU 아키텍처를 자동 감지 할 수 없기 때문에 먼저 CUDA 종속성을 설치해야합니다. 이러한 경우 MXNet은 사용 가능한 모든 GPU 아키텍처를 대상으로합니다.

Step 3− 다음 명령어를 사용하여 MXNet core 공유 라이브러리를 구축 할 수 있습니다.

rm -rf build
mkdir -p build && cd build
cmake -GNinja ..
cmake --build .

위 단계에서 두 가지 중요한 점은 다음과 같습니다.

디버그 버전을 빌드하려면 다음과 같이 지정하십시오.

cmake -DCMAKE_BUILD_TYPE=Debug -GNinja ..

병렬 컴파일 작업 수를 설정하려면 다음을 지정하십시오.

cmake --build . --parallel N

MXNet 코어 공유 라이브러리를 성공적으로 빌드하면 build 귀하의 폴더 MXNet project root, 당신은 발견 할 것이다 libmxnet.dylib, 언어 바인딩을 설치하는 데 필요합니다 (선택 사항).

중앙 처리 장치 (CPU)

여기서는 처리를 위해 CPU를 사용할 때 MXNet을 설치하기 위해 Pip, Docker, Source 등 다양한 방법을 사용할 것입니다.

Pip 방식을 사용하여

다음 명령을 사용하여 Linus OS에 MXNet을 설치할 수 있습니다.

pip install mxnet

Docker를 사용하여

MXNet을 사용하는 Docker 이미지는 DockerHub에서 찾을 수 있습니다. https://hub.docker.com/u/mxnet. CPU와 함께 Docker를 사용하여 MXNet을 설치하려면 아래 단계를 확인하십시오.

Step 1− 먼저 docker installation instructions 사용할 수있는 https://docs.docker.com/docker-for-mac 컴퓨터에 Docker를 설치해야합니다.

Step 2− 다음 명령을 사용하여 MXNet 도커 이미지를 가져올 수 있습니다.

$ docker pull mxnet/python

이제 mxnet / python 도커 이미지 풀이 성공했는지 확인하기 위해 다음과 같이 도커 이미지를 나열 할 수 있습니다.

$ docker images

MXNet에서 가장 빠른 추론 속도를 위해 Intel MKL-DNN과 함께 최신 MXNet을 사용하는 것이 좋습니다. 아래 명령을 확인하십시오.

$ docker pull mxnet/python:1.3.0_cpu_mkl
$ docker images

소스에서

OS X (Mac)의 소스에서 MXNet을 설치하려면 아래 단계를 따르십시오.

Step 1− OS x에 대한 종속성이 필요하므로 먼저 필수 패키지를 설치해야합니다.

xcode-select –-install #Install OS X Developer Tools
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" #Install Homebrew
brew install cmake ninja ccache opencv # Install dependencies

opencv는 선택적 종속성이므로 OpenCV없이 MXNet을 빌드 할 수도 있습니다.

Step 2−이 단계에서는 MXNet 소스를 다운로드하고 구성합니다. 먼저 다음 명령을 사용하여 저장소를 복제 해 보겠습니다.

git clone –-recursive https://github.com/apache/incubator-mxnet.git mxnet

cd mxnet

cp config/linux.cmake config.cmake

Step 3− 다음 명령을 사용하여 MXNet 코어 공유 라이브러리를 구축 할 수 있습니다.

rm -rf build
mkdir -p build && cd build
cmake -GNinja ..
cmake --build .

Two important points regarding the above step is as follows−

디버그 버전을 빌드하려면 다음과 같이 지정하십시오.

cmake -DCMAKE_BUILD_TYPE=Debug -GNinja ..

병렬 컴파일 작업 수를 설정하려면 다음을 지정하십시오.

cmake --build . --parallel N

MXNet 코어 공유 라이브러리를 성공적으로 빌드하면 build 귀하의 폴더 MXNet project root, 당신은 발견 할 것이다 libmxnet.dylib, 언어 바인딩을 설치하는 데 필요합니다 (선택 사항).

Windows OS

Windows에 MXNet을 설치하기위한 전제 조건은 다음과 같습니다.

최소 시스템 요구 사항

  • Windows 7, 10, Server 2012 R2 또는 Server 2016

  • Visual Studio 2015 또는 2017 (모든 유형)

  • Python 2.7 또는 3.6

  • pip

권장 시스템 요구 사항

  • Windows 10, Server 2012 R2 또는 Server 2016

  • 비주얼 스튜디오 2017

  • 하나 이상의 NVIDIA CUDA 지원 GPU

  • MKL 지원 CPU : Intel® Xeon® 프로세서, Intel® Core ™ 프로세서 제품군, Intel Atom® 프로세서 또는 Intel® Xeon Phi ™ 프로세서

  • Python 2.7 또는 3.6

  • pip

그래픽 처리 장치 (GPU)

Pip 방식을 사용하여-

NVIDIA GPU를 사용하여 Windows에서 MXNet을 구축하려는 경우 Python 패키지를 사용하여 CUDA를 지원하는 MXNet을 설치하는 두 가지 옵션이 있습니다.

CUDA 지원으로 설치

다음은 CUDA로 MXNet을 설정할 수있는 단계입니다.

Step 1− 먼저 Microsoft Visual Studio 2017 또는 Microsoft Visual Studio 2015를 설치합니다.

Step 2− 다음으로 NVIDIA CUDA를 다운로드하여 설치합니다. CUDA 9.1의 일부 문제가 과거에 확인되었으므로 CUDA 버전 9.2 또는 9.0을 사용하는 것이 좋습니다.

Step 3− 이제 NVIDIA_CUDA_DNN을 다운로드하여 설치합니다.

Step 4− 마지막으로 다음 pip 명령을 사용하여 CUDA로 MXNet을 설치합니다.

pip install mxnet-cu92

CUDA 및 MKL 지원으로 설치

다음은 CUDA 및 MKL로 MXNet을 설정할 수있는 단계입니다.

Step 1− 먼저 Microsoft Visual Studio 2017 또는 Microsoft Visual Studio 2015를 설치합니다.

Step 2− 다음으로 인텔 MKL을 다운로드하여 설치합니다.

Step 3− 이제 NVIDIA CUDA를 다운로드하여 설치하십시오.

Step 4− 이제 NVIDIA_CUDA_DNN을 다운로드하여 설치합니다.

Step 5− 마지막으로 다음 pip 명령을 사용하여 MKL로 MXNet을 설치합니다.

pip install mxnet-cu92mkl

소스에서

GPU를 사용하여 소스에서 MXNet 코어 라이브러리를 빌드하려면 다음 두 가지 옵션이 있습니다.

Option 1− Build with Microsoft Visual Studio 2017

Microsoft Visual Studio 2017을 사용하여 MXNet을 직접 빌드하고 설치하려면 다음 종속성이 필요합니다.

Install/update Microsoft Visual Studio.

  • Microsoft Visual Studio가 컴퓨터에 아직 설치되지 않은 경우 먼저 다운로드하여 설치하십시오.

  • Git 설치에 대한 메시지가 표시됩니다. 또한 설치하십시오.

  • Microsoft Visual Studio가 이미 컴퓨터에 설치되어 있지만 업데이트하려는 경우 다음 단계로 진행하여 설치를 수정합니다. 여기에서 Microsoft Visual Studio도 업데이트 할 수 있습니다.

Visual Studio 설치 관리자를 열기위한 지침을 따르십시오. https://docs.microsoft.com/en-us 개별 구성 요소를 수정합니다.

Visual Studio 설치 관리자 애플리케이션에서 필요에 따라 업데이트합니다. 그 후 찾아서 확인하십시오.VC++ 2017 version 15.4 v14.11 toolset 클릭 Modify.

이제 다음 명령을 사용하여 Microsoft VS2017의 버전을 v14.11로 변경하십시오.

"C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvars64.bat" -vcvars_ver=14.11

다음으로 다운로드하여 설치해야합니다. CMake 사용 가능 https://cmake.org/download/ 사용하는 것이 좋습니다 CMake v3.12.2 사용할 수있는 https://cmake.org/download/ MXNet으로 테스트 되었기 때문입니다.

이제 다운로드하여 OpenCV 패키지 이용 가능 https://sourceforge.net/projects/opencvlibrary/여러 파일의 압축을 풉니 다. 다른 디렉토리에 배치할지 여부는 귀하에게 달려 있습니다. 여기에서는 경로를 사용합니다.C:\utils(mkdir C:\utils) 기본 경로로.

다음으로, 방금 압축을 푼 OpenCV 빌드 디렉토리를 가리 키도록 환경 변수 OpenCV_DIR을 설정해야합니다. 이 열린 명령 프롬프트에 대해set OpenCV_DIR=C:\utils\opencv\build.

한 가지 중요한 점은 인텔 MKL (Math Kernel Library)이 설치되어 있지 않으면 설치할 수 있다는 것입니다.

사용할 수있는 또 다른 오픈 소스 패키지는 OpenBLAS. 여기에 귀하가 사용하고 있다고 가정하는 추가 지침은OpenBLAS.

그래서, 다운로드 OpenBlas 사용할 수있는 패키지 https://sourceforge.net 파일의 압축을 풀고 이름을 OpenBLAS 아래에 두세요 C:\utils.

다음으로 환경 변수를 설정해야합니다. OpenBLAS_HOME 포함하는 OpenBLAS 디렉토리를 가리 킵니다. includelib디렉토리. 이 열린 명령 프롬프트에 대해set OpenBLAS_HOME=C:\utils\OpenBLAS.

이제 CUDA를 다운로드하여 설치하십시오. https://developer.nvidia.com. CUDA가 이미있는 경우 Microsoft VS2017을 설치 한 경우 지금 CUDA를 다시 설치해야 Microsoft VS2017 통합 용 CUDA 툴킷 구성 요소를 얻을 수 있습니다.

다음으로 cuDNN을 다운로드하여 설치해야합니다.

다음으로 git을 다운로드하여 설치해야합니다. https://gitforwindows.org/ 또한.

필요한 모든 종속성을 설치했으면 아래 단계에 따라 MXNet 소스 코드를 빌드하십시오.

Step 1− 창에서 명령 프롬프트를 엽니 다.

Step 2− 이제 다음 명령을 사용하여 GitHub에서 MXNet 소스 코드를 다운로드합니다.

cd C:\

git clone https://github.com/apache/incubator-mxnet.git --recursive

Step 3− 다음으로 다음을 확인합니다.

DCUDNN_INCLUDE and DCUDNN_LIBRARY 환경 변수는 include 폴더 및 cudnn.lib CUDA 설치 위치의 파일

C:\incubator-mxnet 이전 단계에서 방금 복제 한 소스 코드의 위치입니다.

Step 4− 다음 명령을 사용하여 빌드를 만듭니다. directory 예를 들어 디렉토리로 이동하십시오.

mkdir C:\incubator-mxnet\build
cd C:\incubator-mxnet\build

Step 5− 이제 cmake를 사용하여 다음과 같이 MXNet 소스 코드를 컴파일합니다.

cmake -G "Visual Studio 15 2017 Win64" -T cuda=9.2,host=x64 -DUSE_CUDA=1 -DUSE_CUDNN=1 -DUSE_NVRTC=1 -DUSE_OPENCV=1 -DUSE_OPENMP=1 -DUSE_BLAS=open -DUSE_LAPACK=1 -DUSE_DIST_KVSTORE=0 -DCUDA_ARCH_LIST=Common -DCUDA_TOOLSET=9.2 -DCUDNN_INCLUDE=C:\cuda\include -DCUDNN_LIBRARY=C:\cuda\lib\x64\cudnn.lib "C:\incubator-mxnet"

Step 6− CMake가 성공적으로 완료되면 다음 명령을 사용하여 MXNet 소스 코드를 컴파일합니다.

msbuild mxnet.sln /p:Configuration=Release;Platform=x64 /maxcpucount

Option 2: Build with Microsoft Visual Studio 2015

Microsoft Visual Studio 2015를 사용하여 MXNet을 직접 빌드하고 설치하려면 다음 종속성이 필요합니다.

Microsoft Visual Studio 2015를 설치 / 업데이트합니다. 소스에서 MXnet을 빌드하기위한 최소 요구 사항은 Microsoft Visual Studio 2015의 업데이트 3입니다. 다음을 사용할 수 있습니다. Tools -> Extensions and Updates... | Product Updates 메뉴를 업그레이드합니다.

다음으로 다운로드하여 설치해야합니다. CMake 사용할 수있는 https://cmake.org/download/. 사용하는 것이 좋습니다CMake v3.12.2 에있는 https://cmake.org/download/, MXNet으로 테스트 되었기 때문입니다.

이제 다음에서 사용 가능한 OpenCV 패키지를 다운로드하고 실행하십시오. https://excellmedia.dl.sourceforge.net여러 파일의 압축을 풉니 다. 다른 디렉토리에 배치할지 여부는 귀하에게 달려 있습니다.

다음으로 환경 변수를 설정해야합니다. OpenCV_DIR 가리키다 OpenCV방금 압축을 푼 빌드 디렉토리. 이를 위해 명령 프롬프트를 열고 set을 입력하십시오.OpenCV_DIR=C:\opencv\build\x64\vc14\bin.

한 가지 중요한 점은 인텔 MKL (Math Kernel Library)이 설치되어 있지 않으면 설치할 수 있다는 것입니다.

사용할 수있는 또 다른 오픈 소스 패키지는 OpenBLAS. 여기에 귀하가 사용하고 있다고 가정하는 추가 지침은OpenBLAS.

그래서, 다운로드 OpenBLAS 패키지 이용 가능 https://excellmedia.dl.sourceforge.net 파일의 압축을 풀고 OpenBLAS로 이름을 바꾸고 C : \ utils에 넣습니다.

다음으로 include 및 lib 디렉토리를 포함하는 OpenBLAS 디렉토리를 가리 키도록 환경 변수 OpenBLAS_HOME을 설정해야합니다. 디렉토리를 찾을 수 있습니다.C:\Program files (x86)\OpenBLAS\

CUDA가 이미 설치되어 있고 Microsoft VS2015를 설치 한 경우 지금 CUDA를 다시 설치해야 Microsoft VS2017 통합을위한 CUDA 도구 키트 구성 요소를 얻을 수 있습니다.

다음으로 cuDNN을 다운로드하여 설치해야합니다.

이제 환경 변수 CUDACXX를 설정하여 CUDA Compiler(C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v9.1\bin\nvcc.exe 예).

마찬가지로 환경 변수도 설정해야합니다. CUDNN_ROOT 가리키다 cuDNN 포함하는 디렉토리 include, libbin 디렉토리 (C:\Downloads\cudnn-9.1-windows7-x64-v7\cuda 예).

필요한 모든 종속성을 설치했으면 아래 단계에 따라 MXNet 소스 코드를 빌드하십시오.

Step 1− 먼저 GitHub에서 MXNet 소스 코드를 다운로드합니다.

cd C:\
git clone https://github.com/apache/incubator-mxnet.git --recursive

Step 2− 다음으로 CMake를 사용하여 ./build에 Visual Studio를 만듭니다.

Step 3− 이제 Visual Studio에서 솔루션 파일을 열어야합니다..sln, 컴파일하십시오. 이 명령은 다음과 같은 라이브러리를 생성합니다.mxnet.dll./build/Release/ or ./build/Debug 폴더

Step 4− CMake가 성공적으로 완료되면 다음 명령을 사용하여 MXNet 소스 코드를 컴파일하십시오.

msbuild mxnet.sln /p:Configuration=Release;Platform=x64 /maxcpucount

중앙 처리 장치 (CPU)

여기서는 처리를 위해 CPU를 사용할 때 MXNet을 설치하기 위해 Pip, Docker, Source 등 다양한 방법을 사용할 것입니다.

Pip 방식을 사용하여

CPU가있는 Windows에서 MXNet을 빌드하려는 경우 Python 패키지를 사용하여 MXNet을 설치하는 두 가지 옵션이 있습니다.

Install with CPUs

Python으로 CPU와 함께 MXNet을 설치하려면 다음 명령을 사용하십시오.

pip install mxnet

Install with Intel CPUs

위에서 설명한 바와 같이 MXNet은 Intel MKL 및 MKL-DNN에 대한 실험적 지원을 제공합니다. 다음 명령을 사용하여 Python과 함께 Intel CPU와 함께 MXNet을 설치합니다.

pip install mxnet-mkl

Docker를 사용하여

MXNet에서 도커 이미지를 찾을 수 있습니다. DockerHub, 사용 가능 https://hub.docker.com/u/mxnet CPU와 함께 Docker를 사용하여 MXNet을 설치하려면 아래 단계를 확인하십시오.

Step 1− 먼저, 다음에서 읽을 수있는 도커 설치 지침을 따릅니다. https://docs.docker.com/docker-for-mac/install. 컴퓨터에 Docker를 설치해야합니다.

Step 2− 다음 명령을 사용하여 MXNet 도커 이미지를 가져올 수 있습니다.

$ docker pull mxnet/python

이제 mxnet / python 도커 이미지 풀이 성공했는지 확인하기 위해 다음과 같이 도커 이미지를 나열 할 수 있습니다.

$ docker images

MXNet에서 가장 빠른 추론 속도를 위해 Intel MKL-DNN과 함께 최신 MXNet을 사용하는 것이 좋습니다.

아래 명령을 확인하십시오.

$ docker pull mxnet/python:1.3.0_cpu_mkl
$ docker images

클라우드 및 장치에 MXNet 설치

이 섹션에서는 클라우드 및 장치에 Apache MXNet을 설치하는 방법을 중점적으로 설명합니다. 클라우드에 MXNet을 설치하는 방법부터 시작하겠습니다.

MXNet On Cloud 설치

다음을 사용하여 여러 클라우드 공급자에서 Apache MXNet을 얻을 수도 있습니다. Graphical Processing Unit (GPU)지원하다. 다른 두 가지 지원은 다음과 같습니다.

  • 확장 가능한 추론과 같은 사용 사례에 대한 GPU / CPU 하이브리드 지원.
  • AWS Elastic Inference를 통한 팩토리얼 GPU 지원.

다음은 Apache MXNet을위한 다양한 가상 머신으로 GPU 지원을 제공하는 클라우드 제공 업체입니다.

Alibaba 콘솔

당신은 만들 수 있습니다 NVIDIA GPU Cloud Virtual Machine (VM) 사용 가능 https://docs.nvidia.com/ngc Alibaba Console과 Apache MXNet을 사용하십시오.

아마존 웹 서비스

또한 GPU 지원을 제공하고 Apache MXNet에 대해 다음 서비스를 제공합니다.

Amazon SageMaker

Apache MXNet 모델의 교육 및 배포를 관리합니다.

AWS Deep Learning AMI

Apache MXNet, CUDA, cuDNN, MKL-DNN 및 AWS Elastic Inference와 함께 Python 2 및 Python 3 모두에 대해 사전 설치된 Conda 환경을 제공합니다.

AWS에서의 동적 교육

실험적인 수동 EC2 설정 및 반자동 CloudFormation 설정에 대한 교육을 제공합니다.

당신이 사용할 수있는 NVIDIA VM 사용 가능 https://aws.amazon.com 아마존 웹 서비스와 함께.

구글 클라우드 플랫폼

Google은 또한 NVIDIA GPU cloud image 사용할 수있는 https://console.cloud.google.com Apache MXNet과 함께 작동합니다.

마이크로 소프트 애저

Microsoft Azure Marketplace도 제공합니다. NVIDIA GPU cloud image 사용 가능 https://azuremarketplace.microsoft.com Apache MXNet과 함께 작동합니다.

오라클 클라우드

오라클은 또한 NVIDIA GPU cloud image 사용 가능 https://docs.cloud.oracle.com Apache MXNet과 함께 작동합니다.

중앙 처리 장치 (CPU)

Apache MXNet은 모든 클라우드 제공 업체의 CPU 전용 인스턴스에서 작동합니다. 다음과 같은 다양한 설치 방법이 있습니다.

  • Python pip 설치 지침.

  • Docker 지침.

  • AWS Deep Learning AMI를 제공하는 Amazon Web Services와 같은 사전 설치된 옵션 (MXNet 및 MKL-DNN이있는 Python 2 및 Python 3 모두에 대해 사전 설치된 Conda 환경이 있음).

장치에 MXNet 설치

MXNet을 장치에 설치하는 방법을 알아 보겠습니다.

라즈베리 파이

MXNet은 Respbian ARM 기반 OS도 지원하므로 Raspberry Pi 3B 장치에서 Apache MXNet을 실행할 수도 있습니다. Raspberry Pi3에서 MXNet을 원활하게 실행하려면 RAM이 1GB 이상인 장치와 최소 4GB의 여유 공간이있는 SD 카드를 사용하는 것이 좋습니다.

다음은 Raspberry Pi 용 MXNet을 빌드하고 라이브러리 용 Python 바인딩을 설치할 수있는 방법입니다.

빠른 설치

미리 빌드 된 Python 휠은 빠른 설치를 위해 Stretch가있는 Raspberry Pi 3B에서 사용할 수 있습니다. 이 방법의 중요한 문제 중 하나는 Apache MXNet이 작동하려면 몇 가지 종속성을 설치해야한다는 것입니다.

Docker 설치

Docker 설치 지침을 따를 수 있습니다. https://docs.docker.com/engine/install/ubuntu/컴퓨터에 Docker를 설치합니다. 이를 위해 CE (Community Edition)도 설치하고 사용할 수 있습니다.

네이티브 빌드 (소스에서)

소스에서 MXNet을 설치하려면 다음 두 단계를 따라야합니다.

1 단계

Build the shared library from the Apache MXNet C++ source code

Raspberry 버전 Wheezy 이상에서 공유 라이브러리를 빌드하려면 다음 종속성이 필요합니다.

  • Git− GitHub에서 코드를 가져와야합니다.

  • Libblas− 선형 대수 연산에 필요합니다.

  • Libopencv− 컴퓨터 비전 관련 작업에 필요합니다. 그러나 RAM 및 디스크 공간을 절약하려는 경우 선택 사항입니다.

  • C++ Compiler− MXNet 소스 코드를 컴파일하고 빌드하는 데 필요합니다. 다음은 C ++ 11을 지원하는 컴파일러입니다.

    • G ++ (4.8 이상 버전)

    • Clang(3.9-6)

위에서 언급 한 종속성을 설치하려면 다음 명령을 사용하십시오.

sudo apt-get update
sudo apt-get -y install git cmake ninja-build build-essential g++-4.9 c++-4.9 liblapack*
libblas* libopencv*
libopenblas* python3-dev python-dev virtualenv

다음으로 MXNet 소스 코드 저장소를 복제해야합니다. 이를 위해 홈 디렉토리에서 다음 git 명령을 사용하십시오.

git clone https://github.com/apache/incubator-mxnet.git --recursive

cd incubator-mxnet

이제 다음 명령을 사용하여 공유 라이브러리를 빌드하십시오.

mkdir -p build && cd build
cmake \
-DUSE_SSE=OFF \
-DUSE_CUDA=OFF \
-DUSE_OPENCV=ON \
-DUSE_OPENMP=ON \
-DUSE_MKL_IF_AVAILABLE=OFF \
-DUSE_SIGNAL_HANDLER=ON \

-DCMAKE_BUILD_TYPE=Release \
-GNinja ..
ninja -j$(nproc)

위의 명령을 실행하면 빌드 프로세스가 시작되며 완료하는 데 몇 시간이 걸립니다. 다음과 같은 파일이 생성됩니다.libmxnet.so 빌드 디렉토리에 있습니다.

2 단계

Install the supported language-specific packages for Apache MXNet

이 단계에서는 MXNet Pythin 바인딩을 설치합니다. 이렇게하려면 MXNet 디렉토리에서 다음 명령을 실행해야합니다.

cd python
pip install --upgrade pip
pip install -e .

또는 다음 명령을 사용하여 whl package 설치 가능 pip

ci/docker/runtime_functions.sh build_wheel python/ $(realpath build)

NVIDIA Jetson 장치

다음과 같은 NVIDIA Jetson 장치에서 Apache MXNet을 실행할 수도 있습니다. TX2 또는 NanoMXNet은 Ubuntu Arch64 기반 OS도 지원합니다. NVIDIA Jetson 장치에서 MXNet을 원활하게 실행하려면 Jetson 장치에 CUDA가 설치되어 있어야합니다.

다음은 NVIDIA Jetson 장치 용 MXNet을 구축 할 수있는 방법입니다.

  • Python 개발을 위해 Jetson MXNet pip 휠을 사용하여

  • 소스에서

그러나 위에서 언급 한 방법으로 MXNet을 빌드하기 전에 Jetson 장치에 다음 종속성을 설치해야합니다.

Python 종속성

Python API를 사용하려면 다음 종속성이 필요합니다.

sudo apt update
sudo apt -y install \
   build-essential \
   git \
   graphviz \
   libatlas-base-dev \
   libopencv-dev \
   python-pip
sudo pip install --upgrade \
   pip \
   setuptools
sudo pip install \
   graphviz==0.8.4 \
   jupyter \
   numpy==1.15.2

MXNet 소스 코드 저장소 복제

홈 디렉토리에서 다음 git 명령을 사용하여 MXNet 소스 코드 저장소를 복제하십시오.

git clone --recursive https://github.com/apache/incubator-mxnet.git mxnet

환경 변수 설정

다음을 추가하십시오. .profile 홈 디렉토리의 파일-

export PATH=/usr/local/cuda/bin:$PATH
export MXNET_HOME=$HOME/mxnet/
export PYTHONPATH=$MXNET_HOME/python:$PYTHONPATH

이제 다음 명령을 사용하여 변경 사항을 즉시 적용하십시오.

source .profile

CUDA 구성

CUDA를 구성하기 전에 nvcc를 사용하여 실행중인 CUDA 버전을 확인해야합니다.

nvcc --version

장치 또는 컴퓨터에 둘 이상의 CUDA 버전이 설치되어 있고 CUDA 버전을 전환하려는 경우 다음을 사용하고 원하는 버전에 대한 심볼릭 링크를 바꿉니다.

sudo rm /usr/local/cuda
sudo ln -s /usr/local/cuda-10.0 /usr/local/cuda

위의 명령은 NVIDIA Jetson 장치에 사전 설치된 CUDA 10.0으로 전환됩니다. Nano.

위에서 언급 한 필수 구성 요소를 완료했으면 이제 NVIDIA Jetson 장치에 MXNet을 설치할 수 있습니다. 따라서 MXNet을 설치할 수있는 방법을 이해하겠습니다.

By using a Jetson MXNet pip wheel for Python development− 준비된 Python 휠을 사용하려면 다음을 Jetson에 다운로드하고 실행합니다.

  • MXNet 1.4.0 (용 Python 3) 이용 가능 https://docs.docker.com

  • MXNet 1.4.0 (용 Python 2) 이용 가능 https://docs.docker.com

네이티브 빌드 (소스에서)

소스에서 MXNet을 설치하려면 다음 두 단계를 따라야합니다.

1 단계

Build the shared library from the Apache MXNet C++ source code

Apache MXNet C ++ 소스 코드에서 공유 라이브러리를 빌드하려면 Docker 메소드를 사용하거나 수동으로 수행 할 수 있습니다.

Docker 방법

이 방법에서는 먼저 Docker를 설치하고 sudo없이 실행할 수 있어야합니다 (이전 단계에서도 설명 됨). 완료되면 다음을 실행하여 Docker를 통해 교차 컴파일을 실행하십시오.

$MXNET_HOME/ci/build.py -p jetson

설명서

이 방법에서는 Makefile (아래 명령 사용) CUDA 바인딩이있는 MXNet을 설치하여 NVIDIA Jetson 장치에서 GPU (그래픽 처리 장치)를 활용합니다.

cp $MXNET_HOME/make/crosscompile.jetson.mk config.mk

Makefile을 편집 한 후 config.mk 파일을 편집하여 NVIDIA Jetson 장치를 추가로 변경해야합니다.

이를 위해 다음 설정을 업데이트하십시오.

  • CUDA 경로 업데이트 : USE_CUDA_PATH = / usr / local / cuda

  • CUDA_ARCH 설정에 -gencode arch = compute-63, code = sm_62를 추가합니다.

  • NVCC 설정 업데이트 : NVCCFLAGS : = -m64

  • OpenCV 켜기 : USE_OPENCV = 1

이제 MXNet이 Pascal의 하드웨어 수준의 낮은 정밀도 가속으로 빌드되도록하려면 다음과 같이 Mshadow Makefile을 편집해야합니다.

MSHADOW_CFLAGS += -DMSHADOW_USE_PASCAL=1

마지막으로 다음 명령을 사용하여 완전한 Apache MXNet 라이브러리를 구축 할 수 있습니다.

cd $MXNET_HOME
make -j $(nproc)

위의 명령을 실행하면 빌드 프로세스가 시작되며 완료하는 데 몇 시간이 걸립니다. 다음과 같은 파일이 생성됩니다.libmxnet.somxnet/lib directory.

2 단계

Install the Apache MXNet Python Bindings

이 단계에서는 MXNet Python 바인딩을 설치합니다. 이렇게하려면 MXNet 디렉토리에서 다음 명령을 실행해야합니다.

cd $MXNET_HOME/python
sudo pip install -e .

위의 단계를 마치면 이제 NVIDIA Jetson 장치 TX2 또는 Nano에서 MXNet을 실행할 준비가되었습니다. 다음 명령으로 확인할 수 있습니다.

import mxnet
mxnet.__version__

모든 것이 제대로 작동하면 버전 번호를 반환합니다.