QOJ.ac

QOJ

Time Limit: 2 s Memory Limit: 1024 MB Total points: 100
[0]

# 21405. Min_25 筛

Statistics

Source: Libre OJ 6053

某一天,你发现了一个神奇的函数f(x),它满足很多神奇的性质:

  1. f(1)=1
  2. f(pc)=pcp 为质数, 表示异或)。
  3. f(ab)=f(a)f(b)ab 互质)。

你看到这个函数之后十分高兴,于是就想要求出 ni=1f(i)

由于这个数比较大,你只需要输出 \sum\limits_{i=1}^n f(i) \bmod (10^9+7)

Input

一行一个整数 n

Output

一行一个整数 \sum\limits_{i=1}^n f(i) \bmod 1000000007

Examples

Input 1

6

Output 1

16

Input 2

233333

Output 2

179004642

Input 3

9876543210

Output 3

895670833

Scoring

对于30\%的数据,n \leq 100

对于60\%的数据,n \leq 10^6

对于100\%的数据,1 \leq n \leq 10^{10}