import os,sys,random,threading from random import randint,choice,shuffle from copy import deepcopy from io import BytesIO,IOBase from types import GeneratorType from functools import lru_cache,reduce from bisect import bisect_left,bisect_right from collections import Counter,defaultdict,deque from itertools import accumulate,combinations,permutations from heapq import heapify,heappop,heappush from typing import Generic,Iterable,Iterator,TypeVar,Union,List from math import sqrt from decimal import Decimal,getcontext from sys import stdin, stdout, setrecursionlimit input = lambda: sys.stdin.readline().rstrip("\r\n") MI = lambda :map(int,input().split()) li = lambda :list(MI()) ii = lambda :int(input()) mod = 10**9+7 inf = 1<<64 def multiply(A, B): #状态转移,初始状态 x, y, z = len(A), len(A[0]), len(B[0]) ans=[[0]*z for _ in range(x)] for i in range(x): for j in range(z): for t in range(y): ans[i][j]=(ans[i][j]+A[i][t]*B[t][j])%mod return ans def matrixPow(A, n): #状态转移,快速幂次数 res = [[0] * len(A) for _ in range(len(A))] for i in range(len(A)): res[i][i] = 1 while n: if n & 1: res = multiply(res, A) A = multiply(A, A) n >>= 1 return res m,k=li() A=[[0]*m for _ in range(m)] for i in range(m): for j in range(m): A[i][(i+j)%m]+=1 A[i][i*j%m]+=1 Ak=matrixPow(A,k) B=[[0] for _ in range(m)] B[0][0]=1 res=multiply(Ak,B) print(res[0][0])