# サンプル1 H=1 W=2 N=2 K=2の場合、 # 1×2列のマス。2番目まで回ったら1番目に戻ると、埋めるマスがないので、1番目の人が負け → "YES" # サンプル2 H=1 W=2 N=2 K=1の場合 # 1×2列のマス。2番目まで回ったら1番目に戻ると、埋めるマスがないので、1番目の人が負け → "NO" # サンプルが簡単すぎるので、もうちょっと難しいのを考える。 # 例)20マスで3人でやった時、余りは20÷3で2なので、1,3番目の人は"NO"、2番目の人は"YES"" # 一般化して考える。N番目まで回ったら1番目に戻るということは、きっと余りの問題だと推測しながら……。 # H * W(=S)のマス。SをN番目まで回ると1番目に戻る。S%NがKに一致するかどうかの判定が必要。 # 注意したいのは、S%N == Kとおくと、S%Nは割り切れるとき0となってしまうので、Kと絶対一致せず必ず"NO"になる。 # なので、S%N == K%Nとする必要がある。 H, W, N, K = map(int,input().split()) S = H * W if S % N == K % N: print("YES") else: print("NO")