Description
syn0Global and sync1Global in word2vec are quite large objects with size (vocab * vectorSize * 8), yet they are passed to worker using basic task serialization.
Use broadcast can greatly improve the performance. My benchmark shows that, for 1M vocabulary and default vectorSize 100, changing to broadcast can help,
1. decrease the worker memory consumption by 45%.
2. decrease running time by 40%.
Attachments
Issue Links
- is related to
-
SPARK-16440 Undeleted broadcast variables in Word2Vec causing OoM for long runs
- Resolved
- links to