#include <bits/stdc++.h>
using namespace std;
#define int long long int
#define double long double
#define print(a) for(auto x : a) cout << x << " "; cout << endl
const int M = 1000000007;
const int N = 3e5+9;
const int INF = 2e9+1;
const int LINF = 2000000000000000001;
inline int power(int a, int b) {
int x = 1;
a %= M;
while (b) {
if (b & 1) x = (x * a) % M;
a = (a * a) % M;
b >>= 1;
}
return x;
}
//_ ***************************** START Below *******************************
vector<int> boxes;
vector<int> unitPerBox;
int consistency(int n, int t) {
vector<pair<int,int>> p;
for(int i=0; i<n; i++){
p.push_back({unitPerBox[i], boxes[i]});
}
sort(begin(p), end(p), greater<pair<int,int>>());
int ans = 0;
for(int i=0; i<n; i++){
int unit = p[i].first;
int box = p[i].second;
int k = min(box, t);
ans += k*unit;
t -= k;
}
return ans;
}
// boxes[]
// unitPerBox[]
int practice(int n, int t) {
return 0;
}
void solve() {
int n, t;
cin >> n >> t;
boxes.resize(n);
unitPerBox.resize(n);
for(int i=0; i<n; i++) cin >> boxes[i];
for(int i=0; i<n; i++) cin >> unitPerBox[i];
cout << consistency(n, t) << endl;
// cout << consistency(n, t) << " -> " << practice(n, t) << endl;
}
int32_t main() {
ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int t = 1;
cin >> t;
while (t--) {
solve();
}
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgaW50ICAgICAgICAgICAgICBsb25nIGxvbmcgaW50CiNkZWZpbmUgZG91YmxlICAgICAgICAgICBsb25nIGRvdWJsZQojZGVmaW5lIHByaW50KGEpICAgICAgICAgZm9yKGF1dG8geCA6IGEpIGNvdXQgPDwgeCA8PCAiICI7IGNvdXQgPDwgZW5kbAoKCmNvbnN0IGludCBNID0gMTAwMDAwMDAwNzsKY29uc3QgaW50IE4gPSAzZTUrOTsKY29uc3QgaW50IElORiA9IDJlOSsxOwpjb25zdCBpbnQgTElORiA9IDIwMDAwMDAwMDAwMDAwMDAwMDE7CgppbmxpbmUgaW50IHBvd2VyKGludCBhLCBpbnQgYikgewogICAgaW50IHggPSAxOwogICAgYSAlPSBNOwogICAgd2hpbGUgKGIpIHsKICAgICAgICBpZiAoYiAmIDEpIHggPSAoeCAqIGEpICUgTTsgCiAgICAgICAgYSA9IChhICogYSkgJSBNOwogICAgICAgIGIgPj49IDE7CiAgICB9CiAgICByZXR1cm4geDsKfQoKCi8vXyAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiBTVEFSVCBCZWxvdyAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCgoKCnZlY3RvcjxpbnQ+IGJveGVzOwp2ZWN0b3I8aW50PiB1bml0UGVyQm94OwoKaW50IGNvbnNpc3RlbmN5KGludCBuLCBpbnQgdCkgewoJCgl2ZWN0b3I8cGFpcjxpbnQsaW50Pj4gcDsKCWZvcihpbnQgaT0wOyBpPG47IGkrKyl7CgkJcC5wdXNoX2JhY2soe3VuaXRQZXJCb3hbaV0sIGJveGVzW2ldfSk7Cgl9CgkKCXNvcnQoYmVnaW4ocCksIGVuZChwKSwgZ3JlYXRlcjxwYWlyPGludCxpbnQ+PigpKTsKCQoJaW50IGFucyA9IDA7Cglmb3IoaW50IGk9MDsgaTxuOyBpKyspewoJCWludCB1bml0ID0gcFtpXS5maXJzdDsKCQlpbnQgYm94ID0gcFtpXS5zZWNvbmQ7CgkJCgkJaW50IGsgPSBtaW4oYm94LCB0KTsKCQkKCQlhbnMgKz0gayp1bml0OwoJCXQgLT0gazsKCQkKCX0KCglyZXR1cm4gYW5zOwoJCn0KCgoKCgoKCgoKCgoKCi8vIGJveGVzW10KLy8gdW5pdFBlckJveFtdCgppbnQgcHJhY3RpY2UoaW50IG4sIGludCB0KSB7CgkKCXJldHVybiAwOwp9CgoKdm9pZCBzb2x2ZSgpIHsKICAgIAoJaW50IG4sIHQ7CgljaW4gPj4gbiA+PiB0OwoJCglib3hlcy5yZXNpemUobik7Cgl1bml0UGVyQm94LnJlc2l6ZShuKTsKCWZvcihpbnQgaT0wOyBpPG47IGkrKykgY2luID4+IGJveGVzW2ldOwoJZm9yKGludCBpPTA7IGk8bjsgaSsrKSBjaW4gPj4gdW5pdFBlckJveFtpXTsKCiAgICBjb3V0IDw8IGNvbnNpc3RlbmN5KG4sIHQpICA8PCBlbmRsOwogICAgLy8gY291dCA8PCBjb25zaXN0ZW5jeShuLCB0KSA8PCAiIC0+ICIgPDwgcHJhY3RpY2UobiwgdCkgPDwgZW5kbDsKCn0KCgoKCgppbnQzMl90IG1haW4oKSB7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKDApOyBjaW4udGllKDApOyBjb3V0LnRpZSgwKTsKCiAgICBpbnQgdCA9IDE7CiAgICBjaW4gPj4gdDsKICAgIHdoaWxlICh0LS0pIHsKICAgICAgICBzb2x2ZSgpOwogICAgfQoKICAgIHJldHVybiAwOwp9