Ye Qi, Yuhan Mao
REVISED PLAN
Time | Task | Status |
---|---|---|
Apr 5 - Apr 9 | Literature survey | Done |
Apr 10 - Apr 21 | Design the system architecture and implement the naive baseline | Done |
Apr 22 - Apr 28 | Implement the synchronized distributed LDA | Doing |
May 1 - May 4 | Shift the synchronized update to an asynchronized one by overlapping communication | Pending |
May 3 - May 6 | Conduct worker-level optimization (better multinomial sampler, memory access pattern optimization, etc.) | Pending |
May 5 - May 7 | (If we have time) Implement staleness synchronous parallel model on top of fully synchonized and fully asynchrounous ones | Pending |
May 7 - May 8 | Setup environment on the cluster and collect benchmarking results | Pending |
May.9 - May.12 | Conduct the analysis and write the report | Pending |
COMPLETED WORK
By far both team members have gained a good understanding of gibbs sampling and implemented a sequential version of program in C++ as our baseline. The commonly used Bag Of Words Dataset is selected as our testing dataset. Another smaller dataset from course 10-605, which consists 18773 documents, 60056 words and 20 topics, runs at the speed of around 5 secs/iteration on this program.
Once the baseline was finished, we moved on to data-parallel LDA implementation as described in the proposal. Currently, we have set up the MPI framework and designed API for major operations. A synchronized, distributed implementation, i.e., AD-LDA proposed by Newman et al., was completed under this framework but has not been tested yet.
GOALS AND DELIVERABLES
Currently we are a bit behind the schedule because the tasks themselves require some ramp time and the job was not well assigned before the framework was built up, but overall the project has been on the right track. We started with the goal of speeding up the sequential version by 100x with intel cluster (100 Xeon Phi processor with 68-core, 256 thread each). However, after went through several papers evaluating cut-edge algorithms performing LDA, we realized that the algorithm turned out not easily to be scaled up. Use these papers[1][2] as a reference, we decided to set our goal as 4x speedup at an 8 core machine. To achieve this goal, our asynchronized messaging model design is going to refer to some properties of the parameter server.
As for the parallelism competition, we will deliver a library that allows users to quickly conduct topic modeling on specified dataset. Since the program may require particularly long time to train, we plan to present the graphs comparing both training time and convergence rate.
ISSUES AND CONCERNS
One generic issue for such machine learning techniques is that the program may still function well even if there exists tiny errors. A correctness check against labelled data is required to assure that the system could produce results of acceptable accuracy.
There is a trade-off between speed of the convergence and parallelism of the system. Convergence and parallelism are contradicted in some sense and make it difficult to optimize the performance in terms of the overall running time.
REFERENCE
[1] Newman, David, et al. “Distributed Inference for Latent Dirichlet Allocation.” NIPS. Vol. 20. 2007.
[2] Zhang, Chenyi, and Jianling Sun. “Large scale microblog mining using distributed MB-LDA.” Proceedings of the 21st International Conference on World Wide Web. ACM, 2012.