#include<bits/stdc++.h>
using namespace std;
long long a[1001],f[10005];
int main(){
long long n,w;
cin>>n>>w;
for(long long i=1;i<=n;i++){
cin>>a[i];
}
sort(a+1,a+1+n);
f[0]=1;
for(long long i=1;i<=w;i++){
for(long long j=1;j<=n;j++){
if(i-a[j]>=0){
f[i]=(f[i]+f[i-a[j]])%100000007;
}
}
}
cout<<(f[w]%100000007)<<endl;
return 0;
}