M=10**9+7 n,m,k=map(int,input().split()) r,s=0,1 for i in range(k): if n==1:c=-~i*pow(i,m-1,M)%M elif n==2:c=-~i*i*pow(i*i-~i,m-1,M)%M else: a,b,c,d,e=~-i*(i*i-i+3)%M,(i-2-~i*~i*~i)%M,-~i*i*i%M,i*-~i*(i*i+~i)%M,m-1 while e:c,d=(a*c%M-d,b*d%M)if e&1 else(c,(a*d-b*c)%M);a,b=(a*a-2*b)%M,b*b%M;l>>=1 r+=(s:=s*pow(i+1,-1,M)*(i-k)%M)*c print(r*s%M)