#include<iostream>
#include<cstdio>
#include<cstring>
#define INF 1000001
using namespace std;
int map[1002][1002][2],dis[1002],cost[1002];
int que[1002];
int main()
{
int n,m,i,j,s,e,min,k;
int a,b,c,d;
while(scanf("%d%d",&n,&m)!=EOF&&n&&m)
{
memset(que,0,sizeof(que));
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
map[i][j][0]=map[i][j][1]=INF;
for(i=1;i<=m;i++)
{
scanf("%d%d%d%d",&a,&b,&c,&d);
if(c<map[a][b][0])
{
map[a][b][0]=map[b][a][0]=c;
map[a][b][1]=map[b][a][1]=d;
}
else
{
if(c==map[a][b][0])
if(d<map[a][b][1])
map[a][b][1]=map[b][a][1]=d;
}
}
scanf("%d%d",&s,&e);
for(i=1;i<=n;i++)
{
dis[i]=map[s][i][0];
cost[i]=map[s][i][1];
}
que[s]=1;
for(i=1;i<=n;i++)
{
min=INF;
for(j=1;j<=n;j++)
if(min>dis[j]&&!que[j])
{
min=dis[j];
k=j;
}
que[k]=1;
for(j=1;j<=n;j++)
if(!que[j]&&dis[j]>dis[k]+map[k][j][0])
{
dis[j]=dis[k]+map[k][j][0];
cost[j]=cost[k]+map[k][j][1];
}
else
{
if(!que[j]&&dis[j]==dis[k]+map[k][j][0])
if(cost[j]>cost[k]+map[k][j][1])
cost[j]=cost[k]+map[k][j][1];
}
}
printf("%d %d\n",dis[e],cost[e]);
}
return 0;
}