#define _CRT_SECURE_NO_WARNINGS #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; #define Ma_PI 3.141592653589793 #define eps 0.00000001 #define LONG_INF 3000000000000000000 #define GOLD 1.61803398874989484820458 #define MAX_MOD 1000000007 #define REP(i,n) for(long long i = 0;i < n;++i) #define seg_size 524288 long long gcd(long long a, long long b) { if (b == 0) return a; return gcd(b, a%b); } int main() { #define int long long int n, m; cin >> n >> m; long long ans = 0; if (m == 1) { ans = n*(n - 1); } else { for (int i = m;i <= n;i += m) { for (int q = (i / m + 1) * m;q <= n;q += m) { if (gcd(i, q) == m) { ans += 2; ans %= MAX_MOD; } } } } ans %= MAX_MOD; for (int i = n - 2;i >= 1;--i) { ans *= i; ans %= MAX_MOD; } cout << ans << endl; return 0; }