#include <iostream>
#include <cmath>
#include <vector>
#include <string.h>
#include <bits/stdc++.h>
#include <cstdlib>
#include <time.h>
#include <fstream>
#include <iterator>
#include <utility>
#include <algorithm>
#include <set>
#include <map>
#include <bitset>
using namespace std;
#define ll long long
#define ull unsigned ll
#define ld long double
typedef vector<int> vi;
typedef multiset<int> mi;
typedef multiset<ll> mll;
typedef vector<ll> vll;
typedef vector<bool> vb;
typedef vector<string> vs;
typedef vector<vector<int>> _2vi;
typedef vector<vector<ll>> _2vll;
#define all(v) ((v).begin()), ((v).end())
#define sz(v) ((ll)((v).size()))
#define vinp(v, n) \
for (ull i = 0; i < (n); i++) \
cin >> (v)[i]
#define printv(v) \
for (auto i : (v)) \
cout << i << " "
#define fr0(i, n) for (ll(i) = 0; (i) < (n); (i)++)
#define fr1(i, n) for (ll(i) = 1; (i) < (n); (i)++)
#define fr(i, x, n) for (ll(i) = (x); (i) < (n); (i)++)
#define _CRT_SECURE_NO_WARNING
const ll MOD = 1000000007;
void Bustany() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
#ifndef ONLINE_JUDGE
freopen("./in.txt", "r", stdin), freopen("./out.txt", "w", stdout);
#endif
}
ll n, k;
const ll N = 1e6 + 5;
ll dp[N];
ll v[101];
ll get(ll sum) {
if(sum==0){
return 1;
}
if (dp[sum] != 0)return dp[sum];
fr0(i, n) {
if (v[i] <= sum) {
dp[sum]=(dp[sum]+get(sum-v[i]))%MOD;
}
else break;
}
return dp[sum];
}
void solve() {
cin >> n >> k;
vinp(v, n);
memset(dp,0, k+1);
sort(v,v+n);
cout << get(k);
}
int main() {
Bustany();
ll t = 1;
// cin >> t;
while (t--) {
solve();
}
}
I2luY2x1ZGUgPGlvc3RyZWFtPgojaW5jbHVkZSA8Y21hdGg+CiNpbmNsdWRlIDx2ZWN0b3I+CiNpbmNsdWRlIDxzdHJpbmcuaD4KI2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxjc3RkbGliPgojaW5jbHVkZSA8dGltZS5oPgojaW5jbHVkZSA8ZnN0cmVhbT4KI2luY2x1ZGUgPGl0ZXJhdG9yPgojaW5jbHVkZSA8dXRpbGl0eT4KI2luY2x1ZGUgPGFsZ29yaXRobT4KI2luY2x1ZGUgPHNldD4KI2luY2x1ZGUgPG1hcD4KI2luY2x1ZGUgPGJpdHNldD4KCnVzaW5nIG5hbWVzcGFjZSBzdGQ7CgojZGVmaW5lIGxsIGxvbmcgbG9uZwojZGVmaW5lIHVsbCB1bnNpZ25lZCBsbAojZGVmaW5lIGxkIGxvbmcgZG91YmxlCnR5cGVkZWYgdmVjdG9yPGludD4gdmk7CnR5cGVkZWYgbXVsdGlzZXQ8aW50PiBtaTsKdHlwZWRlZiBtdWx0aXNldDxsbD4gbWxsOwp0eXBlZGVmIHZlY3RvcjxsbD4gdmxsOwp0eXBlZGVmIHZlY3Rvcjxib29sPiB2YjsKdHlwZWRlZiB2ZWN0b3I8c3RyaW5nPiB2czsKdHlwZWRlZiB2ZWN0b3I8dmVjdG9yPGludD4+IF8ydmk7CnR5cGVkZWYgdmVjdG9yPHZlY3RvcjxsbD4+IF8ydmxsOwojZGVmaW5lIGFsbCh2KSAoKHYpLmJlZ2luKCkpLCAoKHYpLmVuZCgpKQojZGVmaW5lIHN6KHYpICgobGwpKCh2KS5zaXplKCkpKQoKI2RlZmluZSB2aW5wKHYsIG4pICAgICAgICAgICAgICAgIFwKICAgIGZvciAodWxsIGkgPSAwOyBpIDwgKG4pOyBpKyspIFwKICAgIGNpbiA+PiAodilbaV0KI2RlZmluZSBwcmludHYodikgICAgICBcCiAgICBmb3IgKGF1dG8gaSA6ICh2KSkgXAogICAgY291dCA8PCBpIDw8ICIgIgojZGVmaW5lIGZyMChpLCBuKSBmb3IgKGxsKGkpID0gMDsgKGkpIDwgKG4pOyAoaSkrKykKI2RlZmluZSBmcjEoaSwgbikgZm9yIChsbChpKSA9IDE7IChpKSA8IChuKTsgKGkpKyspCiNkZWZpbmUgZnIoaSwgeCwgbikgZm9yIChsbChpKSA9ICh4KTsgKGkpIDwgKG4pOyAoaSkrKykKI2RlZmluZSBfQ1JUX1NFQ1VSRV9OT19XQVJOSU5HCmNvbnN0IGxsIE1PRCA9IDEwMDAwMDAwMDc7Cgp2b2lkIEJ1c3RhbnkoKSB7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsKICAgIGNpbi50aWUoTlVMTCk7CiAgICBjb3V0LnRpZShOVUxMKTsKI2lmbmRlZiBPTkxJTkVfSlVER0UKICAgIGZyZW9wZW4oIi4vaW4udHh0IiwgInIiLCBzdGRpbiksIGZyZW9wZW4oIi4vb3V0LnR4dCIsICJ3Iiwgc3Rkb3V0KTsKI2VuZGlmCn0KCmxsIG4sIGs7CmNvbnN0IGxsIE4gPSAxZTYgKyA1OwpsbCBkcFtOXTsKbGwgdlsxMDFdOwoKbGwgZ2V0KGxsIHN1bSkgewogICAgaWYoc3VtPT0wKXsKICAgICAgICByZXR1cm4gMTsKICAgIH0KICAgIGlmIChkcFtzdW1dICE9IDApcmV0dXJuIGRwW3N1bV07CiAgICBmcjAoaSwgbikgewogICAgICAgIGlmICh2W2ldIDw9IHN1bSkgewogICAgICAgICAgICBkcFtzdW1dPShkcFtzdW1dK2dldChzdW0tdltpXSkpJU1PRDsKICAgICAgICB9CiAgICAgICAgZWxzZSBicmVhazsKICAgIH0KICAgIHJldHVybiBkcFtzdW1dOwp9Cgp2b2lkIHNvbHZlKCkgewogICAgY2luID4+IG4gPj4gazsKICAgIHZpbnAodiwgbik7CiAgICBtZW1zZXQoZHAsMCwgaysxKTsKICAgIHNvcnQodix2K24pOwogICAgY291dCA8PCBnZXQoayk7Cn0KCmludCBtYWluKCkgewogICAgQnVzdGFueSgpOwogICAgbGwgdCA9IDE7CiAgICAvLyAgICBjaW4gPj4gdDsKICAgIHdoaWxlICh0LS0pIHsKICAgICAgICBzb2x2ZSgpOwogICAgfQp9