#yuki737 n=int(raw_input()) s=0 for j in xrange(62): i=2**j cnt=(n+1)/(2*i) s+=i*i*cnt*(cnt-1) s+=cnt*(3*i*i-i)/2 if (n+1)%(2*i)>i: m=(n+1)%(2*i)-i s+=m*(m-1)/2+m*(2*i*cnt+i) print s%(10**9+7)