#include using namespace std; using ll = long long; using ld = long double; using vl = vector; template using vc = vector; template using vvc = vector>; #define eb emplace_back #define all(x) (x).begin(), (x).end() #define rep(i, n) for (ll i = 0; i < (n); i++) #define repr(i, n) for (ll i = (n)-1; i >= 0; i--) #define repe(i, l, r) for (ll i = (l); i < (r); i++) #define reper(i, l, r) for (ll i = (r)-1; i >= (l); i--) #define repa(i,n) for (auto& i: n) template inline bool chmax(T &a, const T &b) { if (a inline bool chmin(T &a, const T &b) { if (b void verr(const T& a, const N& n) { rep(i, n) cerr << a[i] << " "; cerr << "\n" << flush; } ll dbgt = 1; void err() { cerr << "passed " << dbgt++ << "\n" << flush; } template void err(H&& h,T&&... t){ cerr<< h << (sizeof...(t)?" ":"\n") << flush; if(sizeof...(t)>0) err(forward(t)...); } #endif const ll INF = 5e18; const ld EPS = 1e-11; const ld PI = acos(-1.0L); const ll MOD = 1e9 + 7; // const ll MOD = 998244353; //--------------------------------------------------------------------------------// ll modpow(ll a, ll n, ll mod_) { ll res = 1; while (n > 0) { if (n & 1) res = res * a % mod_; a = a * a % mod_; n >>= 1; } return res; } const ll MAX_SIZE = 100005; array fac, inv, finv; void fac_init() { // combination init fac[0] = 1; for (ll i = 1; i < MAX_SIZE; i++) fac[i] = fac[i - 1] * i % MOD; finv[0] = modpow(fac[MAX_SIZE - 1], MOD - 2, MOD); repe(i, 1, MAX_SIZE) finv[i] = finv[i - 1] * (MAX_SIZE - i) % MOD; reverse(all(finv)); //inv init repe(i, 1, MAX_SIZE) inv[i] = modpow(i, MOD - 2, MOD); } ll perm(ll a, ll b) { return fac[a] * finv[a - b] % MOD; } ll comb(ll a, ll b) { return fac[a] * finv[b] % MOD * finv[a - b] % MOD; } int main() { init(); ll N, M; cin >> N >> M; fac_init(); ll ans = 0; rep(i,M+1){ ans += comb(M, i) * modpow(M - i, N, MOD) % MOD * (i % 2 ? -1 : 1); } cout << (ans + MOD * MOD) % MOD << endl; }