def invmod(a,mod):#mod逆元 if a == 0: return 0 if a == 1: return 1 return (-invmod(mod % a, mod) * (mod // a)) % mod def modPow(a,n,mod):#繰り返し二乗法 a**n % mod if n==0: return 1 if n==1: return a%mod if n & 1: return (a*modPow(a,n-1,mod)) % mod t = modPow(a,n>>1,mod) return (t*t)%mod N,M = map(int,input().split()) mod = 10**9+7 inv2 = invmod(2, mod) ans = (modPow(2, M, mod)-1)*inv2 ans %= mod print(ans)