// compile: g++ -o data data.cpp -std=gnu++20
// run: ./data < data.in
#include <bits/stdc++.h>
#pragma GCC optimize("O3,unroll-loops")
#pragma GCC target("avx2,bmi,bmi2,lzcnt,popcnt")
#define int long long
#define MAXN 300010
using namespace std;
int n, m;
int comp(vector<int> a) {
    if (a.size() <= 1) return 0;
    sort(a.begin(), a.end());
    vector<int> diff, sum, suffix(a.size(), 0);
    diff.clear();
    sum.clear();
    for (int i = 1; i < a.size(); ++i) {
        diff.push_back(a[i] - a[i - 1]);
        if (i == 1) sum.push_back(diff[i - 1]);
        else sum.push_back(sum[i - 2] + diff[i - 1]);
    }
    for (int i = 0; i < sum.size(); ++i) {
        int ind = sum.size() - i - 1;
        if (!i) suffix[ind] = sum[ind];
        else suffix[ind] = suffix[ind + 1] + sum[ind];
    }
    int len = diff.size();
    int ans = suffix[0];
    for (int i = 1; i < len; ++i) {
        ans += suffix[i] - (sum[i - 1] * (len - i));
        // cout << suffix[i] - (diff[i - 1] * (len - i)) << endl;
        // cout << suffix[i] << " " << sum[i - 1] << " " << (len - i) << endl;
    }
    // for (int i = 0; i < len; ++i) cout << suffix[i] << endl;
    return ans;
}
int32_t main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);
    int _; cin >> _;
    while (_--) {
        cin >> n >> m;
        vector<int> a[MAXN];
        for (int i = 0; i < n; ++i) {
            for (int j = 0; j < m; ++j) {
                int x; cin >> x;
                a[j].push_back(x);
            }
        }
        int total = 0;
        for (int i = 0; i < m; ++i) {
            total += comp(a[i]);
        }
        cout << total << endl;
    }
    return 0;
}
					No Comments