def solve(): n, l = map(int, input().split()) d = list(map(int, input().split())) d += [l + di for di in d] b = list(map(int, input().split())) s = sum(b) if s % (n * l): return False s //= n * l cnt = 0 for i in range(n): c1 = b[i + 1] - b[i] c2 = b[i - 1] - b[i] c3 = b[(n + i + 1) % (2 * n)] - b[n + i] c4 = b[n + i - 1] - b[n + i] d1 = (d[i + 1] - d[i]) % (2 * l) d2 = (d[i] - d[i - 1]) % (2 * l) d3 = (d[(n + i + 1) % (2 * n)] - d[n + i]) % (2 * l) d4 = (d[n + i] - d[n + i - 1]) % (2 * l) if c1 % d1 or c2 % d2 or c3 % d3 or c4 % d4: return False c1 //= d1 c2 //= d2 c3 //= d3 c4 //= d4 if c1 + c2 != -(c3 + c4): return False c = abs(c1 + c2) if c % 2: return False cnt += c // 2 s -= cnt return s >= 0 and s % 2 == 0 ans = 'Yes' if solve() else 'No' print(ans)