#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const ll NINF = (ll)-4e18;
const int MOD = 1'000'000'007;
struct VC { ll v; int c; VC(ll V=NINF,int C=0):v(V),c(C){} };
inline VC mx(const VC&a,const VC&b){ if(a.v>b.v) return a; if(b.v>a.v) return b; return VC(a.v,(a.c+b.c)%MOD); }
inline VC add(const VC&a,const VC&b){ if(!a.c||!b.c) return VC(NINF,0); return VC(a.v+b.v,(int)(1LL*a.c*b.c%MOD)); }
struct M {
VC a[2][2];
M(){ a[0][0]=a[0][1]=a[1][0]=a[1][1]=VC(NINF,0); }
static M I(){ M x; x.a[0][0]=VC(0,1); x.a[1][1]=VC(0,1); return x; }
};
M mulm(const M&A,const M&B){
M C;
for(int i=0;i<2;i++) for(int j=0;j<2;j++){
VC t(NINF,0);
for(int k=0;k<2;k++) t=mx(t,add(A.a[i][k],B.a[k][j]));
C.a[i][j]=t;
}
return C;
}
M mor(const M&A,const M&B){
M C;
for(int i=0;i<2;i++) for(int j=0;j<2;j++) C.a[i][j]=mx(A.a[i][j],B.a[i][j]);
return C;
}
M mpow(M b, long long e){
M r=M::I();
while(e){ if(e&1) r=mulm(r,b); b=mulm(b,b); e>>=1; }
return r;
}
struct V2 { VC x[2]; V2(){ x[0]=x[1]=VC(NINF,0); } static V2 sN(int er){ V2 v; v.x[0]=VC(0,1); v.x[1]=VC(-er,1); return v; } static V2 sR(int er,int ex){ V2 v; v.x[0]=VC(0,1); v.x[1]=VC(-er-ex,1); return v; } };
V2 mulvm(const V2&v,const M&A){
V2 y;
for(int j=0;j<2;j++){ VC t(NINF,0); for(int k=0;k<2;k++) t=mx(t,add(v.x[k],A.a[k][j])); y.x[j]=t; }
return y;
}
VC fin(const V2&v,int el){ return mx(add(v.x[0],VC(0,1)), add(v.x[1],VC(1-el,1))); }
int n; long long d;
vector<vector<int>> g;
vector<int> par; vector<vector<int>> ch; vector<int> ord;
vector<int> A,B,S,UA,UB; vector<char> UH,ess;
void build(int s=0){
par.assign(n,-1); ch.assign(n,{}); ord.clear();
vector<int> st={s}; par[s]=-2;
while(!st.empty()){ int u=st.back(); st.pop_back(); ord.push_back(u); for(int v:g[u]) if(par[v]==-1){ par[v]=u; st.push_back(v);} }
par[s]=-1; for(int v=0;v<n;v++) if(par[v]!=-1) ch[par[v]].push_back(v);
}
void down(){
A.assign(n,0); B.assign(n,0); S.assign(n,0);
for(int i=n-1;i>=0;i--){
int u=ord[i], sum=0, best=INT_MIN/4;
for(int v:ch[u]){ sum+=A[v]; best=max(best, B[v]-A[v]); }
S[u]=sum; B[u]=sum; A[u]=(best<=INT_MIN/8?sum:max(sum,sum+1+best));
}
}
void up(){
UA.assign(n,0); UB.assign(n,0); UH.assign(n,0); UH[0]=0;
vector<vector<int>> pre(n),suf(n);
for(int u:ord){
int k=ch[u].size();
pre[u].assign(k+1,INT_MIN/4);
for(int i=0;i<k;i++){ int v=ch[u][i]; pre[u][i+1]=max(pre[u][i], B[v]-A[v]); }
suf[u].assign(k+1,INT_MIN/4);
for(int i=k-1;i>=0;i--){ int v=ch[u][i]; suf[u][i]=max(suf[u][i+1], B[v]-A[v]); }
}
for(int u:ord){
int k=ch[u].size();
for(int i=0;i<k;i++){
int v=ch[u][i];
int Sex=UA[u]+(S[u]-A[v]);
int best=max(pre[u][i],suf[u][i+1]);
if(UH[u]) best=max(best,UB[u]-UA[u]);
UB[v]=Sex; UA[v]=(best<=INT_MIN/8?Sex:max(Sex,Sex+1+best)); UH[v]=1;
}
}
}
void compE(){
ess.assign(n,0);
int M=A[0];
for(int u=0;u<n;u++){ int rem=UA[u]+S[u]; ess[u]=(M>rem); }
}
vector<char> inD,inA; vector<int> cid, Dc, Ac; vector<char> tight;
void GE(){
inD.assign(n,0); for(int u=0;u<n;u++) inD[u]=!ess[u];
inA.assign(n,0); for(int u=0;u<n;u++) if(inD[u]) for(int v:g[u]) inA[v]=1;
cid.assign(n,-1); Dc.clear(); Ac.clear();
vector<int> vis(n,0); int id=0;
for(int u=0;u<n;u++){
if(vis[u] || !(inD[u]||inA[u])) continue;
queue<int> q; q.push(u); vis[u]=1; int dcnt=0, acnt=0; vector<int> nodes;
while(!q.empty()){
int x=q.front(); q.pop(); nodes.push_back(x);
if(inD[x]) dcnt++; else if(inA[x]) acnt++;
for(int y:g[x]){
if(!((inD[x]&&inA[y])||(inA[x]&&inD[y]))) continue;
if(!vis[y]){ vis[y]=1; q.push(y); }
}
}
for(int x:nodes) if(inD[x]) cid[x]=id;
Dc.push_back(dcnt); Ac.push_back(acnt); id++;
}
tight.assign(id,0);
for(int i=0;i<id;i++) tight[i]=(Dc[i]-Ac[i]==1);
}
struct P { long long ee_same=0,ee_diff=0,enL=0,enR=0,nn_same=0,nn_tight=0,nn_other=0; };
P cntPairs(){
long long E=0, NE=0; for(int u=0;u<n;u++) (ess[u]?E:NE)++;
long long T=0,S2=0; for(size_t i=0;i<Dc.size();i++) if(tight[i]){ T+=Dc[i]; S2+=1LL*Dc[i]*Dc[i]; }
P p;
p.ee_same = E;
p.ee_diff = E*E - E;
p.enL = E*NE;
p.enR = NE*E;
p.nn_same = NE;
p.nn_tight = S2 - T;
p.nn_other = NE*NE - p.nn_same - p.nn_tight;
return p;
}
M mat(int eL,int eR,int ex,int forbd){
M T;
T.a[0][0]=VC(0,1);
T.a[0][1]=VC(-eR,1);
T.a[1][0]=VC(1-eL,1);
if(forbd) T.a[1][1]=VC(NINF,0);
else T.a[1][1]=VC(1-eL-eR-ex,1);
return T;
}
M agg1(const vector<pair<M,ll>>& lst){
M R;
for(auto &t:lst){
M X=t.first; ll cnt=t.second%MOD;
if(!cnt) continue;
for(int i=0;i<2;i++) for(int j=0;j<2;j++){ if(X.a[i][j].c) X.a[i][j].c=(int)cnt; }
R=mor(R,X);
}
return R;
}
struct EC { int r[2]; int exr; int l[2]; };
EC ends(int s){
int E=0,NE=0; for(int u=0;u<n;u++) (ess[u]?E:NE)++;
EC e{}; e.r[1]=E%MOD; e.r[0]=NE%MOD; e.l[1]=E%MOD; e.l[0]=NE%MOD;
if(ess[s]) e.exr=0;
else{
int id=cid[s];
if(id>=0 && tight[id]) e.exr = Dc[id]%MOD;
else e.exr=0;
}
return e;
}
int main(){
ios::sync_with_stdio(false);
cin.tie(nullptr);
cin>>n>>d;
g.assign(n,{});
for(int i=0;i<n-1;i++){ int u,v; cin>>u>>v; --u;--v; g[u].push_back(v); g[v].push_back(u); }
build(0); down(); up(); compE(); GE();
P p = cntPairs();
vector<pair<M,ll>> lst;
lst.push_back({mat(1,1,0,1), p.ee_same});
lst.push_back({mat(1,1,0,0), p.ee_diff});
lst.push_back({mat(1,0,0,0), p.enL});
lst.push_back({mat(0,1,0,0), p.enR});
lst.push_back({mat(0,0,0,1), p.nn_same});
lst.push_back({mat(0,0,1,0), p.nn_tight});
lst.push_back({mat(0,0,0,0), p.nn_other});
M step = agg1(lst);
M mid = (d>=2? mpow(step,d-1): M::I());
EC e = ends(0);
ll ans = 0;
for(int er=0;er<=1;er++){
V2 vN = V2::sN(er);
V2 vR0 = V2::sR(er,0);
V2 vR1 = V2::sR(er,1);
V2 tN = mulvm(vN,mid), tR0 = mulvm(vR0,mid), tR1 = mulvm(vR1,mid);
for(int el=0;el<=1;el++){
VC VN = fin(tN,el), VR0 = fin(tR0,el), VR1 = fin(tR1,el);
if(ess[0]){ if(VR0.c) VR0.v-=1; if(VR1.c) VR1.v-=1; }
int cntR = e.r[er], cntRe = (er==0? e.exr:0), cntL = e.l[el];
if(VN.v>VR0.v){ ll add = 1LL*((cntR - cntRe + MOD)%MOD)*cntL%MOD; add = add*VN.c%MOD; ans=(ans+add)%MOD; }
if(cntRe && VN.v>VR1.v){ ll add = 1LL*cntRe*cntL%MOD; add = add*VN.c%MOD; ans=(ans+add)%MOD; }
}
}
cout<<ans%MOD<<"\n";
return 0;
}
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const ll NINF = (ll)-4e18;
const int MOD = 1'000'000'007;

struct VC { ll v; int c; VC(ll V=NINF,int C=0):v(V),c(C){} };
inline VC mx(const VC&a,const VC&b){ if(a.v>b.v) return a; if(b.v>a.v) return b; return VC(a.v,(a.c+b.c)%MOD); }
inline VC add(const VC&a,const VC&b){ if(!a.c||!b.c) return VC(NINF,0); return VC(a.v+b.v,(int)(1LL*a.c*b.c%MOD)); }

struct M {
  VC a[2][2];
  M(){ a[0][0]=a[0][1]=a[1][0]=a[1][1]=VC(NINF,0); }
  static M I(){ M x; x.a[0][0]=VC(0,1); x.a[1][1]=VC(0,1); return x; }
};
M mulm(const M&A,const M&B){
  M C;
  for(int i=0;i<2;i++) for(int j=0;j<2;j++){
    VC t(NINF,0);
    for(int k=0;k<2;k++) t=mx(t,add(A.a[i][k],B.a[k][j]));
    C.a[i][j]=t;
  }
  return C;
}
M mor(const M&A,const M&B){
  M C;
  for(int i=0;i<2;i++) for(int j=0;j<2;j++) C.a[i][j]=mx(A.a[i][j],B.a[i][j]);
  return C;
}
M mpow(M b, long long e){
  M r=M::I();
  while(e){ if(e&1) r=mulm(r,b); b=mulm(b,b); e>>=1; }
  return r;
}
struct V2 { VC x[2]; V2(){ x[0]=x[1]=VC(NINF,0); } static V2 sN(int er){ V2 v; v.x[0]=VC(0,1); v.x[1]=VC(-er,1); return v; } static V2 sR(int er,int ex){ V2 v; v.x[0]=VC(0,1); v.x[1]=VC(-er-ex,1); return v; } };
V2 mulvm(const V2&v,const M&A){
  V2 y;
  for(int j=0;j<2;j++){ VC t(NINF,0); for(int k=0;k<2;k++) t=mx(t,add(v.x[k],A.a[k][j])); y.x[j]=t; }
  return y;
}
VC fin(const V2&v,int el){ return mx(add(v.x[0],VC(0,1)), add(v.x[1],VC(1-el,1))); }

int n; long long d;
vector<vector<int>> g;
vector<int> par; vector<vector<int>> ch; vector<int> ord;
vector<int> A,B,S,UA,UB; vector<char> UH,ess;

void build(int s=0){
  par.assign(n,-1); ch.assign(n,{}); ord.clear();
  vector<int> st={s}; par[s]=-2;
  while(!st.empty()){ int u=st.back(); st.pop_back(); ord.push_back(u); for(int v:g[u]) if(par[v]==-1){ par[v]=u; st.push_back(v);} }
  par[s]=-1; for(int v=0;v<n;v++) if(par[v]!=-1) ch[par[v]].push_back(v);
}
void down(){
  A.assign(n,0); B.assign(n,0); S.assign(n,0);
  for(int i=n-1;i>=0;i--){
    int u=ord[i], sum=0, best=INT_MIN/4;
    for(int v:ch[u]){ sum+=A[v]; best=max(best, B[v]-A[v]); }
    S[u]=sum; B[u]=sum; A[u]=(best<=INT_MIN/8?sum:max(sum,sum+1+best));
  }
}
void up(){
  UA.assign(n,0); UB.assign(n,0); UH.assign(n,0); UH[0]=0;
  vector<vector<int>> pre(n),suf(n);
  for(int u:ord){
    int k=ch[u].size();
    pre[u].assign(k+1,INT_MIN/4);
    for(int i=0;i<k;i++){ int v=ch[u][i]; pre[u][i+1]=max(pre[u][i], B[v]-A[v]); }
    suf[u].assign(k+1,INT_MIN/4);
    for(int i=k-1;i>=0;i--){ int v=ch[u][i]; suf[u][i]=max(suf[u][i+1], B[v]-A[v]); }
  }
  for(int u:ord){
    int k=ch[u].size();
    for(int i=0;i<k;i++){
      int v=ch[u][i];
      int Sex=UA[u]+(S[u]-A[v]);
      int best=max(pre[u][i],suf[u][i+1]);
      if(UH[u]) best=max(best,UB[u]-UA[u]);
      UB[v]=Sex; UA[v]=(best<=INT_MIN/8?Sex:max(Sex,Sex+1+best)); UH[v]=1;
    }
  }
}
void compE(){
  ess.assign(n,0);
  int M=A[0];
  for(int u=0;u<n;u++){ int rem=UA[u]+S[u]; ess[u]=(M>rem); }
}

vector<char> inD,inA; vector<int> cid, Dc, Ac; vector<char> tight;
void GE(){
  inD.assign(n,0); for(int u=0;u<n;u++) inD[u]=!ess[u];
  inA.assign(n,0); for(int u=0;u<n;u++) if(inD[u]) for(int v:g[u]) inA[v]=1;
  cid.assign(n,-1); Dc.clear(); Ac.clear();
  vector<int> vis(n,0); int id=0;
  for(int u=0;u<n;u++){
    if(vis[u] || !(inD[u]||inA[u])) continue;
    queue<int> q; q.push(u); vis[u]=1; int dcnt=0, acnt=0; vector<int> nodes;
    while(!q.empty()){
      int x=q.front(); q.pop(); nodes.push_back(x);
      if(inD[x]) dcnt++; else if(inA[x]) acnt++;
      for(int y:g[x]){
        if(!((inD[x]&&inA[y])||(inA[x]&&inD[y]))) continue;
        if(!vis[y]){ vis[y]=1; q.push(y); }
      }
    }
    for(int x:nodes) if(inD[x]) cid[x]=id;
    Dc.push_back(dcnt); Ac.push_back(acnt); id++;
  }
  tight.assign(id,0);
  for(int i=0;i<id;i++) tight[i]=(Dc[i]-Ac[i]==1);
}

struct P { long long ee_same=0,ee_diff=0,enL=0,enR=0,nn_same=0,nn_tight=0,nn_other=0; };
P cntPairs(){
  long long E=0, NE=0; for(int u=0;u<n;u++) (ess[u]?E:NE)++;
  long long T=0,S2=0; for(size_t i=0;i<Dc.size();i++) if(tight[i]){ T+=Dc[i]; S2+=1LL*Dc[i]*Dc[i]; }
  P p;
  p.ee_same = E;
  p.ee_diff = E*E - E;
  p.enL = E*NE;
  p.enR = NE*E;
  p.nn_same = NE;
  p.nn_tight = S2 - T;
  p.nn_other = NE*NE - p.nn_same - p.nn_tight;
  return p;
}

M mat(int eL,int eR,int ex,int forbd){
  M T;
  T.a[0][0]=VC(0,1);
  T.a[0][1]=VC(-eR,1);
  T.a[1][0]=VC(1-eL,1);
  if(forbd) T.a[1][1]=VC(NINF,0);
  else T.a[1][1]=VC(1-eL-eR-ex,1);
  return T;
}
M agg1(const vector<pair<M,ll>>& lst){
  M R;
  for(auto &t:lst){
    M X=t.first; ll cnt=t.second%MOD;
    if(!cnt) continue;
    for(int i=0;i<2;i++) for(int j=0;j<2;j++){ if(X.a[i][j].c) X.a[i][j].c=(int)cnt; }
    R=mor(R,X);
  }
  return R;
}

struct EC { int r[2]; int exr; int l[2]; };
EC ends(int s){
  int E=0,NE=0; for(int u=0;u<n;u++) (ess[u]?E:NE)++;
  EC e{}; e.r[1]=E%MOD; e.r[0]=NE%MOD; e.l[1]=E%MOD; e.l[0]=NE%MOD;
  if(ess[s]) e.exr=0;
  else{
    int id=cid[s];
    if(id>=0 && tight[id]) e.exr = Dc[id]%MOD;
    else e.exr=0;
  }
  return e;
}

int main(){
  ios::sync_with_stdio(false);
  cin.tie(nullptr);
  cin>>n>>d;
  g.assign(n,{});
  for(int i=0;i<n-1;i++){ int u,v; cin>>u>>v; --u;--v; g[u].push_back(v); g[v].push_back(u); }
  build(0); down(); up(); compE(); GE();

  P p = cntPairs();
  vector<pair<M,ll>> lst;
  lst.push_back({mat(1,1,0,1), p.ee_same});
  lst.push_back({mat(1,1,0,0), p.ee_diff});
  lst.push_back({mat(1,0,0,0), p.enL});
  lst.push_back({mat(0,1,0,0), p.enR});
  lst.push_back({mat(0,0,0,1), p.nn_same});
  lst.push_back({mat(0,0,1,0), p.nn_tight});
  lst.push_back({mat(0,0,0,0), p.nn_other});
  M step = agg1(lst);
  M mid = (d>=2? mpow(step,d-1): M::I());

  EC e = ends(0);
  ll ans = 0;
  for(int er=0;er<=1;er++){
    V2 vN = V2::sN(er);
    V2 vR0 = V2::sR(er,0);
    V2 vR1 = V2::sR(er,1);
    V2 tN = mulvm(vN,mid), tR0 = mulvm(vR0,mid), tR1 = mulvm(vR1,mid);
    for(int el=0;el<=1;el++){
      VC VN = fin(tN,el), VR0 = fin(tR0,el), VR1 = fin(tR1,el);
      if(ess[0]){ if(VR0.c) VR0.v-=1; if(VR1.c) VR1.v-=1; }
      int cntR = e.r[er], cntRe = (er==0? e.exr:0), cntL = e.l[el];
      if(VN.v>VR0.v){ ll add = 1LL*((cntR - cntRe + MOD)%MOD)*cntL%MOD; add = add*VN.c%MOD; ans=(ans+add)%MOD; }
      if(cntRe && VN.v>VR1.v){ ll add = 1LL*cntRe*cntL%MOD; add = add*VN.c%MOD; ans=(ans+add)%MOD; }
    }
  }
  cout<<ans%MOD<<"\n";
  return 0;
}