#include <algorithm>#include <iostream>using ll = long long;constexpr int K = 105;constexpr int N = 100005;constexpr int mod = 1e9 + 7;int T, n, k, a[K], b[K], fact[N << 1], m[K][K];int qpow(int x, int y) { int out = 1; while (y) { if (y & 1) out = (ll)out * x % mod; x = (ll)x * x % mod; y >>= 1; } return out;}int c(int x, int y) { return (ll)fact[x] * qpow(fact[y], mod - 2) % mod * qpow(fact[x - y], mod - 2) % mod;}using std::cin;using std::cout;int main() { cin.tie(nullptr)->sync_with_stdio(false); fact[0] = 1; for (int i = 1; i < N * 2; ++i) fact[i] = (ll)fact[i - 1] * i % mod; cin >> T; while (T--) { cin >> n >> k; for (int i = 1; i <= k; ++i) cin >> a[i]; for (int i = 1; i <= k; ++i) cin >> b[i]; for (int i = 1; i <= k; ++i) { for (int j = 1; j <= k; ++j) { if (a[i] <= b[j]) m[i][j] = c(b[j] - a[i] + n - 1, n - 1); else m[i][j] = 0; } } for (int i = 1; i < k; ++i) { if (!m[i][i]) { for (int j = i + 1; j <= k; ++j) { if (m[j][i]) { std::swap(m[i], m[j]); break; } } } if (!m[i][i]) continue; int inv = qpow(m[i][i], mod - 2); for (int j = i + 1; j <= k; ++j) { if (!m[j][i]) continue; int mul = (ll)m[j][i] * inv % mod; for (int p = i; p <= k; ++p) { m[j][p] = (m[j][p] - (ll)m[i][p] * mul % mod + mod) % mod; } } } int ans = 1; for (int i = 1; i <= k; ++i) ans = (ll)ans * m[i][i] % mod; cout << ans << '\n'; } return 0;}