#include using namespace std ; typedef long long ll ; #define rep(i,n) for(int i = 0 ; i < n ; i++) #define rrep(i,a,b) for(int i = a ; i < b ; i++) const int mod = 1000000007 ; ll n , k ; ll powmod(ll x , ll n){ ll res = 1 ; while(n > 0){ if(n & 1) (res *= x) %= mod ; (x *= x) %= mod ; n >>= 1 ; } return res ; } int main(){ cin >> n >> k ; cout << (powmod(n,k) - powmod(n-1,k) + mod) % mod * n % mod << endl ; }