#include<stdio.h>
#include<string.h>
constint mod=9973;//矩阵中间数求模
int n;
struct data
{
    int map[19][19];
};
data matrix(data a,data b)//矩阵乘法
{
    int i,j,k;
    data re;
    for(i=0;i<n;i++)
    {
        for(j=0;j<n;j++)
        {
            int all=0;
            for(k=0;k<n;k++)
            {
                all+=(a.map[i][k]*b.map[k][j])%mod;
                all%=mod;
            }
            re.map[i][j]=all%mod;
        }
    }
    return re;
}
int matrixT(data f,int p)//二分求矩阵
{
    int i,j;
    data all;
    for(i=0;i<n;i++){//初始化一个单位矩阵
for(j=0;j<n;j++){
            all.map[i][j]=0;
            if(i==j)all.map[i][j]=1;
        }
    }
    while(p>0)//二分求矩阵
    {
        if(p&1==1)
        {all=matrix(all,f);}
        f=matrix(f,f);
        p>>=1;
    }
    int add=0;//计算矩阵对角线和
for(i=0;i<n;i++){
        add+=all.map[i][i];
    }
    
    return add%mod;
}
int main()
{
    int p;
    int t;
    while(scanf("%d",&t)!=EOF)
    {
        while(t--)
        {
            
            scanf("%d%d",&n,&p);
            int i,j;
            data f;
            for(i=0;i<n;i++)
            {
                for(j=0;j<n;j++)
                {
                    int temp;
                    scanf("%d",&temp);
                    f.map[i][j]=temp;
                }
            }
            printf("%d\n",matrixT(f,p));
        }
    }
    return0;
}