mod = 10**9 + 7 def sum(a, d, n) : a %= mod d %= mod n %= mod return (a*n + d*n*(n-1)*((mod + 1) // 2)) % mod n = int(input()) ans = 0 k = 1 while k <= n : x = sum(k, 1, k) y = (n + 1) // (k*2) ans += sum(x, (k * 2) * k, y) ans %= mod z = (n + 1) // (k * k) if (z // k) % 2 == 1 : ans += sum(z, 1, n - z + 1) ans%=mod k *= 2 print(ans % mod)