Abstract

We study the consensus decentralized optimization problem where the objective function is the average of <inline-formula><tex-math notation="LaTeX">$n$</tex-math></inline-formula> agents private non-convex cost functions; moreover, the agents can only communicate to their neighbors on a given network topology. The stochastic learning setting is considered in this paper where each agent can only access a noisy estimate of its gradient. Many decentralized methods can solve such problem including EXTRA, Exact-Diffusion/D<inline-formula><tex-math notation="LaTeX">$^{2}$</tex-math></inline-formula>, and gradient-tracking. Unlike the famed <small>Dsgd</small> algorithm, these methods have been shown to be robust to the heterogeneity across the local cost functions. However, the established convergence rates for these methods indicate that their sensitivity to the network topology is worse than <small>Dsgd</small>. Such theoretical results imply that these methods can perform much worse than <small>Dsgd</small> over sparse networks, which, however, contradicts empirical experiments where <small>Dsgd</small> is observed to be more sensitive to the network topology. In this work, we study a general <u>s</u>tochastic <u>u</u>nified <u>d</u>ecentralized <u>a</u>lgorithm (<b>SUDA</b>) that includes the above methods as special cases. We establish the convergence of <b>SUDA</b>&#x00A0;under both non-convex and the Polyak-&#x0141;ojasiewicz condition settings. Our results provide improved network topology dependent bounds for these methods (such as Exact-Diffusion/D<inline-formula><tex-math notation="LaTeX">$^{2}$</tex-math></inline-formula> and gradient-tracking) compared with existing literature. Moreover, our results show that these methods are often less sensitive to the network topology compared to <small>Dsgd</small>, which agrees with numerical experiments.

Full Text
Published version (Free)

Talk to us

Join us for a 30 min session where you can share your feedback and ask us any queries you have

Schedule a call