We are trying to provide a recommender specific framework to users from various industries, who need high-efficient solutions for their online/offline CTR training. HugeCTR is also a reference design for framework developers who want to port their CPU solutions to GPU or optimize their current GPU solutions.
HugeCTR v2.2 supports DNN, WDL, DCN, DeepFM, DLRM and their variants, which are widely used in industrial recommender systems. See samples [folder] to try them with HugeCTR. HugeCTR's expressiveness is not confined to the aforementioned models. You can construct your own models by combining the layers supported by HugeCTR.
HugeCTR v2.2 has no TF interface yet, but a HugeCTR Trained model is compatible with TensorFlow. We recommend that you export a trained model to TensorFlow for inference by following the instructions in our tutorial
Yes. HugeCTR supports single-GPU, multi-GPU and multi-node training. Check out samples/dcn2node for more details.
Embedding table in HugeCTR is model-parallel stored across GPUs and nodes. So if you have a very large embedding table, just use as many GPUs as you need to store it. That’s why we have the name “HugeCTR”. Suppose you have 1TB embedding table and 16xV100-32GB in a GPU server node, you can take 2 nodes for such a case.
HugeCTR supports GPUs with Compute Compatibility > 7.0 such as V100, T4 and A100.
A DGX machine is not mandatory but recommended to achieve the best performance by exploiting NVSwitch's high inter-GPU bandwidth.
For multi-node training, InfiniBand is recommended but not required. You can use any solution with UCX support. However, InfiniBand with GPU RDMA support will maximize performance of inter-node transactions.
HugeCTR's approach is to offload the computational workloads to GPUs with the memory operations overlapped with them. So HugeCTR performance is mainly decided by what kinds of GPUs and I/O devices are used.
We have specific file format support. Please refer to the Dataset File.
Yes we introduced our first version of Python interface. Check out our Getting Started with HugeCTR and Jupyter Notebook.
12. Does HugeCTR do synchronous training with multiple GPUs (and nodes)? Otherwise, does it do asynchronous training?
HugeCTR only supports synchronous training.
Yes, hashtable based embedding in HugeCTR supports dynamic insertion, which is designed for stream training. New features can be added into embedding in runtime. HugeCTR also supports data check. Error data will be skipped in training.
In HugeCTR, a slot is a feature field or table.
The features in a slot can be one-hot or multi-hot.
The number of features in different slots can be various.
You can specify the number of slots (slot_num
) in the data layer of your configuration file.
There are two sub-classes of Embedding layer, LocalizedSlotEmbedding and DistributedSlotEmbedding. They are distinguished by different methods of distributing embedding tables on multiple GPUs as model parallelism. For LocalizedSlotEmbedding, the features in the same slot will be stored in one GPU (that is why we call it “localized slot”), and different slots may be stored in different GPUs according to the index number of the slot. For DistributedSlotEmbedding, all the features are distributed to different GPUs according to the index number of the feature, regardless of the index number of the slot. That means the features in the same slot may be stored in different GPUs (that is why we call it “distributed slot”).
Thus LocalizedSlotEmbedding is optimized for the case each embedding is smaller than the memory size of GPU. As local reduction per slot is used in LocalizedSlotEmbedding and no global reduce between GPUs, the overall data transaction in Embedding is much less than DistributedSlotEmbedding. DistributedSlotEmbedding is made for the case some of the embeddings are larger than the memory size of GPU. As global reduction is required. DistributedSlotEmbedding has much more memory trasactions between GPUs.
16. For multi-node,is DataReader required to read the same batch of data on each node for each step?
Yes, each node in training will read the same data in each iteration.
17. As model parallelism in embedding layers, how does it get all the embedding lookup features from multi-node / multi-gpu?
After embedding lookup, the embedding features in one slot need to be combined (or reduced) into one embedding vector. There are 2 steps:
- local reduction in single GPU in forward kernel function;
- global reduction across multi-node / multi-gpu by collective communications libraries such as NCCL.
There should only be one source where the "sparse" is an array. Suppose there are 26 features (slots), first 13 features belong to the first embedding and the last 13 features belong to the second embedding, you can have two elements in "sparse" array as below:
"sparse": [
{
"top": "data1",
"type": "DistributedSlot",
"max_feature_num_per_sample": 30,
"slot_num": 13
},
{
"top": "data2",
"type": "DistributedSlot",
"max_feature_num_per_sample": 30,
"slot_num": 13
}
]
In HugeCTR, the model is saved in binary raw format. For model saving, you can set the “snapshot” in .json file to set the intervals of saving a checkpoint in file with the prefix of “snapshot_prefix”; For model loading, you can just modify the “dense_model_file”, “sparse_model_file” in .json file (in solver clause) according to the name of the snapshot.
20. Could the post training model from HugeCTR be imported into other frameworks such as TensorFlow for inference deployment?
Yes. The training model in HugeCTR is saved in raw format, and you can import it to other frameworks by writing some scripts . We provide a tutorial to demonstrate how to import the HugeCTR trained model to TensorFlow. Please refer to the tutorial .
Features in different slots must be unique (no overlap). You may want to preprocess the data if you have overlaps e.g. offset or use hash function.
nnz=0 is supported in HugeCTR input. That means no features will be looked up.
Firstly, you should construct your own configure file. You can refer to our User Guide and samples.
Secondly, using our data_generator
to generate a random dataset. Seeing introductions.
Thirdly, run with ./huge_ctr --train ./your_config.json
As embeddings are model parallel in HugeCTR,
workspace_size_per_gpu_in_mb
is a reference number for HugeCTR to allocate GPU memory accordingly and not necessarily the exact number of features in your dataset. It is depending on vocabulary size per gpu, embedding vector size and optimizer type. Please refer to embedding_workspace_calculator to see how to calculate vocabulary size per gpu and workspace_size per gpu for different embedding types, embedding vector size and optimizer type.
In practice, we usually set it larger than the real size because of the non-uniform distribution of the keys.
slot_size_array
has 2 usages. It can be used as a replacement for workspace_size_per_gpu_in_mb
to avoid wasting memory caused by imbalance vocabulary size. And it can also be used as a reference to add offset for keys in different slot.
The relation between embedding type, workspace_size_per_gpu_in_mb
and slot_size_array
is:
- For
DistributedSlotEmbedding
,workspace_size_per_gpu_in_mb
is needed andslot_size_array
is not needed. Each GPU will allocate the same amount of memory for embedding table usage. - For
LocalizedSlotSparseEmbeddingHash
, only one ofworkspace_size_per_gpu_in_mb
andslot_size_array
is needed. If users can provide the exact size for each slot, we recommand users to specifyslot_size_array
. It can help avoid wasting memory caused by imbalance vocabulary size. Or you can specifyworkspace_size_per_gpu_in_mb
so each GPU will allocate the same amount of memory for embedding table usage. If you specify bothslot_size_array
andworkspace_size_per_gpu_in_mb
, HugeCTR will useslot_size_array
forLocalizedSlotSparseEmbeddingHash
. - For
LocalizedSlotSparseEmbeddingOneHot
,slot_size_array
is needed. It is used for allocating memory and adding offset for each slot. - For
HybridSparseEmbedding
, bothworkspace_size_per_gpu_in_mb
andslot_size_array
is needed.workspace_size_per_gpu_in_md
is used for allocating memory whileslot_size_array
is used for adding offset
GPU with nvlink is not required, but recommended because the performance of CTR training highly relies on the performance of inter-GPUs communication. GPU servers with PCIE connections are also supported.
DGX is not required, but recommended, because the performance of CTR training highly relies on the performance of inter-GPUs transactions. DGX has NVLink and NVSwitch inside, so that you can expect 150GB/s per direction per GPU. It’s 9.3x to PCI-E 3.0.
For multi-node training, InfiniBand is recommended but not required. You can use any solution with UCX support. InfiniBand with GPU RDMA support will maximize performance of inter-node transactions.
You can convert the pretrained embeddings to the HugeCTR sparse models and then load them to facilitate the training process. You can refer to save_params_to_files to get familiar with the HugeCTR sparse model format. We demonstrate the usage in 3.4 Load Pre-trained Embeddings of hugectr_criteo.ipynb.
The branch topology is inherently supported by HugeCTR model graph, and extra layers are abstracted away in HugeCTR Python Interface. Please refer to Getting Started to see how to construct a model graph with branches.
The embedding vector size is related to the size of Cooperative Thread Array (CTA) for HugeCTR kernal launching, so first and foremost it should not exceed the maximum number of threads per block. It would be better that it is configured to a multiple of the warp size for the sake of occupancy. Still, you can set the embedding vector size freely according to the specific model architecture as long as it complies with the limit.