#include<bits/stdc++.h>
using namespace std;
const int N=1e3+10,A=1e9+7;
int n,w,a[N],f[N];
int main(){
cin>>n>>w;
for(int i=1;i<=n;i++){
cin>>a[i];
}
f[0]=1;
for(int i=1;i<=w;i++){
for(int j=1;j<=n;j++){
if(a[j]<=i){
f[i]+=f[i-a[j]];
f[i]%=A;
}
}
}
cout<<f[w];
return 0;
}