- 전체
- C/C++ 일반
- C/C++ 수학
- C/C++ 그래픽
- C/C++ 자료구조
- C/C++ 인공지능
- C/C++ 인터넷
- wxWidget
- GTK+
- UNIX or LINUX programming
- 리눅스 마스터 - 국가공인자격
- VC++/ MFC
- C#/CLI/.NET
- QT/기타UI
- Boost lib
- 오픈소스 C 분석자료
- MSA (마이크로서비스), Docker, kubernetes
- WSL(windows subsystem linux)
C/C++ 인공지능 [C/C++ 인공지능][linux][cuda] flashlight
2021.11.09 23:15
[C/C++ 인공지능][linux][cuda] flashlight
flashlight-main.zip
Quickstart | Installation | Documentation
Flashlight is a fast, flexible machine learning library written entirely in C++ from the Facebook AI Research Speech team and the creators of Torch and Deep Speech. Its core features include:
- Just-in-time kernel compilation with modern C++ with the ArrayFire tensor library.
- CUDA and CPU backends for GPU and CPU training.
- An emphasis on efficiency and scale.
Native support in C++ and simple extensibility makes Flashlight a powerful research framework that's hackable to its core and enables fast iteration on new experimental setups and algorithms without sacrificing performance. In a single repository, Flashlight provides apps for research across multiple domains:
- Automatic speech recognition (the wav2letter project) — Documentation | Tutorial
- Image classification
- Object detection
- Language modeling
Project Layout
Flashlight is broken down into a few parts:
flashlight/lib
contains kernels and standalone utilities for sequence losses, beam search decoding, text processing, and more.flashlight/fl
is the core neural network library using the ArrayFire tensor library.flashlight/app
are applications of the core library to machine learning across domains.- `flashlight/pkg are packages built on top of Flashlight and ArrayFire for specific purposes (Domain libraries for speech, vision, and text, and Halide extensions).
Quickstart
First, build and install Flashlight and link it to your own project.
Sequential
forms a sequence of Flashlight Module
s for chaining computation.
Implementing a simple convnet is easy.
See the MNIST example for a full tutorial including a training loop and dataset abstractions.
Variable
is the base Flashlight tensor that operates on ArrayFire array
s. Tape-based Automatic differentiation in Flashlight is simple and works as you'd expect.
Autograd Example
Building and Installing
Install with vcpkg
| With Docker | From Source | From Source with vcpkg
| Build Your Project with Flashlight
Requirements
At minimum, compilation requires:
- A C++ compiler with good C++17 support (e.g. gcc/g++ >= 7)
- CMake — version 3.10 or later, and
make
- A Linux-based operating system.
See the full dependency list for more details if building from source.
Instructions for building/installing Python bindings can be found here.
Flashlight Build Setups
Flashlight can be broken down into several components as described above. Each component can be incrementally built by specifying the correct build options.
There are two ways to work with Flashlight:
- As an installed library that you link to with your own project. This is best for building standalone applications dependent on Flashlight.
- With in-source development where the Flashlight project source is changed and rebuilt. This is best if customizing/hacking the core framework or the Flashlight-provided app binaries.
Flashlight can be built in one of two ways:
- With
vcpkg
, a C++ package manager. - From source by installing dependencies as needed.
vcpkg
Installing Flashlight with vcpkg
Library Installation with Flashlight is most-easily built and installed with vcpkg
. Both the CUDA and CPU backends are supported with vcpkg
. For either backend, first install Intel MKL. For the CUDA backend, install CUDA
>= 9.2, cuDNN
, and NCCL
. Then, after installing vcpkg
, install the libraries and core with:
./vcpkg/vcpkg install flashlight-cuda # CUDA backend, OR
./vcpkg/vcpkg install flashlight-cpu # CPU backend
To install Flashlight apps, check the features available for installation by running ./vcpkg search flashlight-cuda
or ./vcpkg search flashlight-cpu
. Each app is a "feature": for example, ./vcpkg install flashlight-cuda[asr]
installs the ASR app with the CUDA backend.
Below is the currently-supported list of features (for each of flashlight-cuda
and flashlight-cpu
):
flashlight-{cuda/cpu}[lib] # Flashlight libraries
flashlight-{cuda/cpu}[nn] # Flashlight neural net library
flashlight-{cuda/cpu}[asr] # Flashlight speech recognition app
flashlight-{cuda/cpu}[lm] # Flashlight language modeling app
flashlight-{cuda/cpu}[imgclass] # Flashlight image classification app
Flashlight app binaries are also built for the selected features and are installed into the vcpkg
install tree's tools
directory.
Integrating Flashlight into your own project with is simple using vcpkg
's CMake toolchain integration.
vcpkg
From-Source Build with First, install the dependencies for your backend of choice using vcpkg
(click to expand the below):
Installing CUDA Backend Dependencies with vcpkg
Installing CPU Backend Dependencies with vcpkg
vcpkg
Toolchain File
Build Using the To build Flashlight from source with these dependencies, clone the repository:
git clone https://github.com/flashlight/flashlight.git && cd flashlight
mkdir -p build && cd build
Then, build from source using vcpkg
's CMake toolchain:
cmake .. \
-DCMAKE_BUILD_TYPE=Release
-DFL_BACKEND=CUDA
-DCMAKE_TOOLCHAIN_FILE=[path to your vcpkg clone]/scripts/buildsystems/vcpkg.cmake
make -j$(nproc)
make install -j$(nproc) # only if you want to install Flashlight for external use
To build a subset of Flashlight's features, see the build options below.
Building from Source
To build from source, first install the below dependencies. Most are available with your system's local package manager.
Some dependencies marked below are downloaded and installed automatically if not found on the local system. FL_BUILD_STANDALONE
determines this behavior — if disabled, dependencies won't be downloaded and built when building Flashlight.
Once all dependencies are installed, clone the repository:
git clone https://github.com/flashlight/flashlight.git && cd flashlight
mkdir -p build && cd build
Then build all Flashlight components with:
cmake .. -DCMAKE_BUILD_TYPE=Release -DFL_BACKEND=[backend] [...build options]
make -j$(nproc)
make install
Setting the MKLROOT
environment variable (export MKLROOT=/opt/intel/oneapi/mkl/latest
or export MKLROOT=/opt/intel/mkl
on most Linux-based systems) can help CMake find Intel MKL if not initially found.
To build a smaller subset of Flashlight features/apps, see the build options below for a complete list of options.
To install Flashlight in a custom directory, use CMake's CMAKE_INSTALL_PREFIX
argument. Flashlight libraries can be built as shared libraries using CMake's BUILD_SHARED_LIBS
argument.
Flashlight uses modern CMake and IMPORTED
targets for most dependencies. If a dependency isn't found, passing -D<package>_DIR
to your cmake
command or exporting <package>_DIR
as an environment variable equal to the path to <package>Config.cmake
can help locate dependencies on your system. See the documentation for more details. If CMake is failing to locate a package, check to see if a corresponding issue has already been created before creating your own.
Dependencies
Dependencies marked with *
are automatically downloaded and built from source if not found on the system. Setting FL_BUILD_STANDALONE
to OFF
disables this behavior.
Dependencies marked with ^
are required if building with distributed training enabled (FL_BUILD_DISTRIBUTED
— see the build options below). Distributed training is required for all apps.
Dependencies marked with †
are installable via vcpkg
. See the instructions for installing those dependencies above for doing a Flashlight from-source build.
Component | Backend | Dependencies |
---|---|---|
Audio library (fl_lib_audio) | CUDA | CUDA >= 9.2, CUB*† (if CUDA < 11) |
CPU | A BLAS library (Intel MKL >= 2018, OpenBLAS†, etc) | |
core | Any | ArrayFire >= 3.7.3†, an MPI library^(OpenMPI†, etc), cereal*† >= 1.3.0, stb*† |
CUDA | CUDA >= 9.2, NCCL^, cuDNN | |
CPU | oneDNN† >= 2.0, gloo (with MPI)*^† | |
Runtime package (fl_pkg_runtime) | Any | Google Glog†, Gflags† |
Speech package (fl_pkg_speech) | Any | libsndfile*† >= 10.0.28, a BLAS library (Intel MKL >= 2018, OpenBLAS†, etc) |
app: imgclass | Any | - |
app: objdet | Any | - |
app: lm | Any | - |
tests | Any | Google Test (gtest, with gmock)*† >= 1.10.0 |
Build Options
The Flashlight CMake build accepts the following build options (prefixed with -D
when running CMake from the command line):
Name | Options | Default Value | Description |
---|---|---|---|
FL_BACKEND | CUDA, CPU, OPENCL | CUDA | Backend with which to build all components. |
FL_BUILD_STANDALONE | ON, OFF | ON | Downloads/builds some dependencies if not found. |
FL_BUILD_ALL_LIBS | ON, OFF | OFF | Build all the Flashlight libraries. |
FL_BUILD_LIB_SET | ON, OFF | OFF | Build the Flashlight set library. |
FL_BUILD_LIB_SEQUENCE | ON, OFF | OFF | Build the Flashlight sequence library. |
FL_BUILD_LIB_AUDIO | ON, OFF | OFF | Build the Flashlight audio library. |
FL_BUILD_LIB_COMMON | ON, OFF | OFF | Build the Flashlight common library. |
FL_BUILD_LIB_TEXT | ON, OFF | OFF | Build the Flashlight text library. |
FL_BUILD_CORE | ON, OFF | ON | Build the Flashlight neural net library. |
FL_BUILD_DISTRIBUTED | ON, OFF | ON | Build with distributed training; required for apps. |
FL_BUILD_CONTRIB | ON, OFF | ON | Build contrib APIs subject to breaking changes. |
FL_BUILD_ALL_PKGS | ON, OFF | OFF | Defines default value for every pkg (see below). |
FL_BUILD_PKG_RUNTIME | ON, OFF | FL_BUILD_ALL_PKGS | Build the runtime package |
FL_BUILD_PKG_VISION | ON, OFF | FL_BUILD_ALL_PKGS | Build the flashlight vision package |
FL_BUILD_PKG_TEXT | ON, OFF | FL_BUILD_ALL_PKGS | Build the flashlight text package |
FL_BUILD_PKG_SPEECH | ON, OFF | FL_BUILD_ALL_PKGS | Build the flashlight speech package |
FL_BUILD_PKG_HALIDE | ON, OFF | FL_BUILD_ALL_PKGS | Build the flashlight halide package |
FL_BUILD_ALL_APPS | ON, OFF | OFF | Defines default value for every app (see below). |
FL_BUILD_APP_ASR | ON, OFF | FL_BUILD_ALL_APPS | Build the automatic speech recognition app. |
FL_BUILD_APP_IMGCLASS | ON, OFF | FL_BUILD_ALL_APPS | Build the image classification app. |
FL_BUILD_APP_OBJDET | ON, OFF | FL_BUILD_ALL_APPS | Build automatic speech recognition app tools. |
FL_BUILD_APP_LM | ON, OFF | FL_BUILD_ALL_APPS | Build the language modeling app. |
FL_BUILD_APP_ASR_TOOLS | ON, OFF | FL_BUILD_APP_ASR | Build automatic speech recognition app tools. |
FL_BUILD_TESTS | ON, OFF | ON | Build tests. |
FL_BUILD_EXAMPLES | ON, OFF | ON | Build examples. |
FL_BUILD_EXPERIMENTAL | ON, OFF | OFF | Build experimental components. |
CMAKE_BUILD_TYPE | See docs. | Debug | See the CMake documentation. |
CMAKE_INSTALL_PREFIX | [Directory] | See docs. | See the CMake documentation. |
Building Your Own Project with Flashlight
Flashlight is most-easily linked to using CMake. Flashlight exports the following CMake targets when installed:
flashlight::fl_lib_common
— contains flashlight libraries for common headers and symbols used throughout flashlight.flashlight::fl_lib_set
— contains flashlight libraries for headers and symbols pertaining to sets.flashlight::fl_lib_sequence
— contains flashlight libraries for headers and symbols pertaining to sequences.flashlight::fl_lib_audio
— contains flashlight libraries for headers and symbols pertaining to audio.flashlight::fl_lib_text
— contains flashlight libraries for headers and symbols pertaining to text.flashlight::flashlight
— contains flashlight libraries as well as the flashlight core autograd and neural network library.flashlight::fl_pkg_runtime
— contains flashlight core as well as common utilities for training (logging / flags / distributed utils).flashlight::fl_pkg_vision
— contains flashlight core as well as common utilities for vision pipelines.flashlight::fl_pkg_text
— contains flashlight core as well as common utilities for dealing with text data.flashlight::fl_pkg_speech
— contains flashlight core as well as common utilities for dealing with speech data.flashlight::fl_pkg_halide
— contains flashlight core and extentions to easily interface with halide.
Given a simple project.cpp
file that includes and links to Flashlight:
#include <iostream>
#include <arrayfire.h>
#include <flashlight/fl/flashlight.h>
int main() {
fl::Variable v(af::constant(1, 1), true);
auto result = v + 10;
std::cout << "Hello World!" << std::endl;
af::print("Array value is ", result.array()); // 11.000
return 0;
}
The following CMake configuration links Flashlight and sets include directories:
cmake_minimum_required(VERSION 3.10)
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
add_executable(myProject project.cpp)
find_package(flashlight CONFIG REQUIRED)
target_link_libraries(myProject PRIVATE flashlight::flashlight)
vcpkg
Flashlight Installation
With a If you installed Flashlight with vcpkg
, the above CMake configuration for myProject
can be built by running:
cd project && mkdir build && cd build
cmake .. \
-DCMAKE_TOOLCHAIN_FILE=[path to vcpkg clone]/scripts/buildsystems/vcpkg.cmake \
-DCMAKE_BUILD_TYPE=Release
make -j$(nproc)
With a From-Source Flashlight Installation
If using a from-source installation of Flashlight, Flashlight will be found automatically by CMake:
cd project && mkdir build && cd build
cmake .. -DCMAKE_BUILD_TYPE=Release
make -j$(nproc)
If Flashlight is installed in a custom location using a CMAKE_INSTALL_PREFIX
, passing -Dflashlight_DIR=[install prefix]/share/flashlight/cmake
as an argument to your cmake
command can help CMake find Flashlight.
Building and Running Flashlight with Docker
Flashlight and its dependencies can also be built with the provided Dockerfiles — see the accompanying Docker documentation for more information.
Contributing and Contact
Contact: vineelkpratap@fb.com, awni@fb.com, jacobkahn@fb.com, qiantong@fb.com, antares@fb.com, padentomasello@fb.com, jcai@fb.com, gab@fb.com, vitaliy888@fb.com, locronan@fb.com
Flashlight is being very actively developed. See CONTRIBUTING for more on how to help out.
Acknowledgments
Some of Flashlight's code is derived from arrayfire-ml.
License
Flashlight is under an MIT license. See LICENSE for more information.
[출처] https://github.com/flashlight/flashlight
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
댓글 0
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
15 | [C/C++ graphic GUI] An introduction to the Dear ImGui library : Dear ImGui 라이브러리 소개 | 졸리운_곰 | 2023.11.07 | 10 |
14 | [C/C++, graphics] SDL Tutorial Basics | 졸리운_곰 | 2021.05.15 | 51 |
13 | How to Install Dev-C++ and the GLUT Libraries for Compiling OpenGL Programs with ANSI C | 졸리운_곰 | 2021.02.02 | 50 |
12 | CONREC : A Contouring Subroutine 등고선 그리기 | 졸리운_곰 | 2018.01.11 | 344 |
11 | 왼손 / 오른손 좌표계 비교: Left- vs. Right-handed coordinate systems | 졸리운_곰 | 2017.09.24 | 97 |
10 | 3D Graphics with OpenGL | 졸리운_곰 | 2017.09.24 | 871 |
9 | OpenGL의 회전순서 | 졸리운_곰 | 2017.09.24 | 35 |
8 | 통일 D3D 및 OpenGL 좌표 시스템 | 졸리운_곰 | 2017.09.24 | 56 |
7 | [OpenGL] 중심점(pivot)으로 물체 회전하기 | 졸리운_곰 | 2017.06.25 | 898 |
6 | 3D Graphics with OpenGL | 졸리운_곰 | 2017.06.06 | 93 |
5 | OpenGL프로그래밍:간단한 다각형 랜더링 | 졸리운_곰 | 2017.06.06 | 334 |
4 | 기하학 사이트들.. | 졸리운_곰 | 2017.06.06 | 61 |
3 | 기하변환 | 졸리운_곰 | 2017.06.06 | 688 |
2 | assimp : Open Asset Import Library | 졸리운_곰 | 2017.05.14 | 54 |
1 | MeshLab the open source system for processing and editing 3D triangular meshes. | 졸리운_곰 | 2017.05.13 | 69 |