#pragma GCC optimize("-O3","-funroll-all-loops","-ffast-math")
#include <iostream>
#include <stdio.h>
#include <math.h>
#include <string.h>
#include <time.h>
#include <stdlib.h>
#include <string>
#include <bitset>
#include <vector>
#include <set>
#include <map>
#include <queue>
#include <algorithm>
#include <sstream>
#include <stack>
#include <iomanip>
#include <assert.h>
using namespace std;
#define pb push_back
#define mp make_pair
typedef pair<int,int> pii;
typedef long long ll;
typedef double ld;
typedef vector<int> vi;
#define fi first
#define se second
#define fe first
#define FO(x) {freopen(#x".in","r",stdin);freopen(#x".out","w",stdout);}
#define Edg int M=0,fst[SZ],vb[SZ],nxt[SZ];void ad_de(int a,int b){++M;nxt[M]=fst[a];fst[a]=M;vb[M]=b;}void adde(int a,int b){ad_de(a,b);ad_de(b,a);}
#define Edgc int M=0,fst[SZ],vb[SZ],nxt[SZ],vc[SZ];void ad_de(int a,int b,int c){++M;nxt[M]=fst[a];fst[a]=M;vb[M]=b;vc[M]=c;}void adde(int a,int b,int c){ad_de(a,b,c);ad_de(b,a,c);}
#define es(x,e) (int e=fst[x];e;e=nxt[e])
#define esb(x,e,b) (int e=fst[x],b=vb[e];e;e=nxt[e],b=vb[e])
#define SZ 666666
int T,n,m,ea[SZ],eb[SZ],ec[SZ];
#define M M_
int M=0,fst[SZ],vb[SZ],nxt[SZ];
void ad_de(int a,int b)
{++M;nxt[M]=fst[a];fst[a]=M;vb[M]=b;}
void adde(int a,int b){ad_de(a,b);ad_de(b,a);}
#undef M
char s[SZ];
int sz[SZ],son[SZ],dep[SZ],fa[SZ];
const int M=262144;
int ls[SZ],rs[SZ],ss[SZ];
#define CL(x) memset(x,0,sizeof x)
namespace Seg
{
bool tk[SZ];
int ta[SZ],mi[SZ],mc[SZ];
ll su[SZ],ms[SZ],tb[SZ];
inline void clr()
{
CL(mi); CL(su);
CL(ms); CL(tb); CL(ta);
for(int i=0;i<SZ;++i) tk[i]=1,mi[i]=1e9;
}
inline void pd(int x)
{
if(ta[x]||tb[x]||tk[x]!=1);
else return;
mi[x]+=ta[x]; su[x]-=ms[x];
ms[x]=ms[x]*tk[x]+mc[x]*tb[x];
su[x]+=ms[x];
if(x<=M)
{
ta[x+x]+=ta[x],ta[x+x+1]+=ta[x];
int u=min(mi[x+x],mi[x+x+1]);
if(mi[x+x]==u)
{
tk[x+x]&=tk[x];
tb[x+x]=tb[x+x]*tk[x]+tb[x];
}
if(mi[x+x+1]==u)
{
tk[x+x+1]&=tk[x];
tb[x+x+1]=tb[x+x+1]*tk[x]+tb[x];
}
}
ta[x]=tb[x]=0; tk[x]=1;
}
inline void upd(int x)
{
pd(x+x); pd(x+x+1);
su[x]=su[x+x]+su[x+x+1];
if(mi[x+x]<mi[x+x+1])
mi[x]=mi[x+x],mc[x]=mc[x+x],ms[x]=ms[x+x];
else if(mi[x+x]>mi[x+x+1])
mi[x]=mi[x+x+1],mc[x]=mc[x+x+1],ms[x]=ms[x+x+1];
else mi[x]=mi[x+x],
mc[x]=mc[x+x]+mc[x+x+1],
ms[x]=ms[x+x]+ms[x+x+1];
// mi[x]=min(mi[x+x],mi[x+x+1]); mc[x]=ms[x]=0;
// if(mi[x]==mi[x+x]) mc[x]+=mc[x+x],ms[x]+=ms[x+x];
// if(mi[x]==mi[x+x+1]) mc[x]+=mc[x+x+1],ms[x]+=ms[x+x+1];
}
inline void add(int x,int ql,int qr,int v)
{
if(ql>qr||rs[x]<ql||qr<ls[x]) return;
pd(x);
if(ql<=ls[x]&&rs[x]<=qr)
{
ta[x]+=v; return;
}
add(x+x,ql,qr,v);
add(x+x+1,ql,qr,v);
upd(x);
}
inline int qmin(int x,int ql,int qr)
{
if(ql>qr||rs[x]<ql||qr<ls[x]) return 2e9;
pd(x);
if(ql<=ls[x]&&rs[x]<=qr) return mi[x];
int g=min(qmin(x+x,ql,qr),
qmin(x+x+1,ql,qr));
upd(x); return g;
}
inline ll qsum(int x,int ql,int qr)
{
if(ql>qr||rs[x]<ql||qr<ls[x]) return 0;
pd(x);
if(ql<=ls[x]&&rs[x]<=qr) return su[x];
ll g=qsum(x+x,ql,qr)+qsum(x+x+1,ql,qr);
upd(x); return g;
}
inline void pt(int x,int ql,int qr,int u,int k,int b)
{
if(ql>qr||rs[x]<ql||qr<ls[x]) return;
pd(x);
if(mi[x]>u) return;
if(ql<=ls[x]&&rs[x]<=qr)
{
assert(mi[x]==u);
// cerr<<"PUTSHIT:"<<ls[x]<<"~"<<rs[x]<<" "<<k<<","<<b<<"\n";
tk[x]=k; tb[x]=b; return;
}
pt(x+x,ql,qr,u,k,b);
pt(x+x+1,ql,qr,u,k,b);
upd(x);
}
inline pair<int,ll> qms(int x,int ql,int qr)
{
if(ql>qr||rs[x]<ql||qr<ls[x])
return pair<int,ll>(2e9,0);
pd(x);
if(ql<=ls[x]&&rs[x]<=qr)
return pair<int,ll>(mi[x],ms[x]);
pair<int,ll> g=qms(x+x,ql,qr);
pd(x+x+1);
if(mi[x+x+1]>g.fi)
{
upd(x); return g;
}
pair<int,ll> h=qms(x+x+1,ql,qr);
upd(x);
if(g.fi<h.fi) return g;
if(g.fi>h.fi) return h;
return pair<int,ll>(g.fi,g.se+h.se);
}
inline void eds(int x,int p,ll s)
{
pd(x);
if(ls[x]==rs[x])
{
su[x]=ms[x]=s;
return;
}
if(p<=rs[x+x])
eds(x+x,p,s);
else eds(x+x+1,p,s);
upd(x);
}
}
void dfs(int x,int f=0)
{
sz[x]=1; dep[x]=dep[f]+1; fa[x]=f; son[x]=0;
for esb(x,e,b) if(b!=f)
{
dfs(b,x); sz[x]+=sz[b];
if(sz[b]>sz[son[x]]) son[x]=b;
}
}
int bs[SZ];
void edt(int x,int y)
{
for(;x<SZ;x+=x&-x) bs[x]+=y;
}
int qs(int x)
{
int s=0;
for(;x>=1;x-=x&-x) s+=bs[x];
return s;
}
namespace B2
{
int bs[SZ];
void edt(int x,int y)
{
for(;x<SZ;x+=x&-x) bs[x]+=y;
}
int qs(int x)
{
int s=0;
for(;x>=1;x-=x&-x) s+=bs[x];
return s;
}
int qs(int l,int r)
{return qs(r)-qs(l-1);}
}
int top[SZ],fe[SZ],rv[SZ],C,ed[SZ],p1[SZ],p2[SZ],Q=0;
void dfs2(int x,int t)
{
top[x]=t; fe[x]=++C; rv[C]=x; p1[x]=++Q;
if(son[x]) dfs2(son[x],t);
for esb(x,e,b)
if(b!=son[x]&&b!=fa[x])
dfs2(b,b);
ed[x]=C; p2[x]=++Q;
}
int lca(int a,int b)
{
while(top[a]!=top[b])
{
if(dep[top[a]]<dep[top[b]]) b=fa[top[b]];
else a=fa[top[a]];
}
if(dep[a]<dep[b]) return a;
return b;
}
int lt[SZ],E=3; ll la[SZ];
#define EDT ++E
namespace Seg2
{
int g[SZ];
void upd(int x,int y)
{
x+=M; g[x]=y;
while(x>>=1)
g[x]=max(g[x+x],g[x+x+1]);
}
int lp(int x,int ql,int qr,int u)
{
if(ql>qr||rs[x]<ql||qr<ls[x]||g[x]<u) return 0;
if(ls[x]==rs[x]) return ls[x];
int uu=lp(x+x+1,ql,qr,u);
if(uu) return uu;
return lp(x+x,ql,qr,u);
}
}
int ftop(int x)
{return rv[Seg2::lp(1,1,fe[x],ed[x])];}
inline int fc(int x) {return qs(p1[x]);}
set<int> w;
ll ca=0;
ll QS(int x)
{
if(lt[x]==E) return la[x];
lt[x]=E;
return la[x]=Seg::qms(1,fe[x],ed[x]).se;
}
void edb(int x,int v,bool chk=1)
{
x=ftop(x);
//cerr<<x<<" "<<Seg::qms(1,fe[x],ed[x],F)<<"QWQ\n";
int u=fe[x];
if(v==-1)
{
if(!w.count(u)) return;
B2::edt(u,-1);
if(w.size()<=2)
{
w.erase(u);
ca=0; return;
}
auto U=w.find(u);
int L,R;
++U;
if(U!=w.end()) R=*U;
else R=*w.begin();
--U;
if(U!=w.begin()) L=*(--U),++U;
else L=*w.rbegin();
int A=rv[L],B=rv[*U],C=rv[R];
int AB=lca(A,B),AC=lca(A,C),BC=lca(B,C);
ca-=fc(B)-fc(AB)-fc(BC)+fc(AC);
w.erase(U);
}
else
{
if(w.count(u)) return;
if(chk&&!QS(x)) return;
B2::edt(u,1);
if(w.size()<=0)
{
w.insert(u);
ca=0; return;
}
auto U=w.insert(u).fi;
int L,R;
++U;
if(U!=w.end()) R=*U;
else R=*w.begin();
--U;
if(U!=w.begin()) L=*(--U),++U;
else L=*w.rbegin();
int A=rv[L],B=rv[*U],C=rv[R];
int AB=lca(A,B),AC=lca(A,C),BC=lca(B,C);
ca+=fc(B)-fc(AB)-fc(BC)+fc(AC);
}
}
void flip(int e)
{
if(ec[e]) //block
{
int ww=B2::qs(fe[eb[e]],ed[eb[e]]);
if(ww&&ww!=int(w.size())) ca++;
edt(p1[eb[e]],1);
edt(p2[eb[e]],-1);
edb(ea[e],-1);
Seg2::upd(fe[eb[e]],ed[eb[e]]);
EDT;
Seg::add(1,fe[eb[e]],ed[eb[e]],1);
ec[e]^=1;
edb(ea[e],1);
edb(eb[e],1);
}
else //unblock
{
int ww=B2::qs(fe[eb[e]],ed[eb[e]]);
if(ww&&ww!=int(w.size())) ca--;
edt(p1[eb[e]],-1);
edt(p2[eb[e]],1);
edb(ea[e],-1);
edb(eb[e],-1);
Seg2::upd(fe[eb[e]],0);
EDT;
Seg::add(1,fe[eb[e]],ed[eb[e]],-1);
ec[e]^=1;
edb(ea[e],1);
}
}
void sol()
{
scanf("%d%d",&n,&m); M_=C=0;
// cerr<<"+"<<n<<"w"<<m<<"\n";
Seg::clr();
for(int i=1;i<=n;++i)
fst[i]=0,Seg::mc[i+M]=1,Seg::mi[i+M]=0;
for(int i=1,a,b;i<n;++i)
scanf("%d%d",&a,&b),
ea[i]=a,eb[i]=b,ec[i]=0,
adde(a,b);
dfs(1); dfs2(1,1);
for(int i=1;i<=n;++i)
Seg2::upd(fe[i],ed[i]);
for(int i=1;i<n;++i)
{
if(fa[ea[i]]==eb[i]) swap(ea[i],eb[i]);
assert(fa[eb[i]]==ea[i]);
}
if(n>1) scanf("%s",s); //is it a trap?
// for(int i=1;i<=n;++i)
// cerr<<fe[i]<<",";
// cerr<<"\n";
for(int i=1;i<=n;++i)
scanf("%lld",&Seg::su[fe[i]+M]),
Seg::ms[fe[i]+M]=Seg::su[fe[i]+M];
for(int i=M-1;i>=1;--i)
Seg::upd(i);
for(int i=1;i<n;++i)
Seg::add(1,fe[eb[i]],ed[eb[i]],1),
edt(p1[eb[i]],1),
edt(p2[eb[i]],-1);
for(int i=1;i<=n;++i) edb(i,1);
// cerr<<ca<<"w"<<ca/2<<" "<<n<<"\n";
// for(auto p:w)
// cerr<<rv[p]<<",";cerr<<"\n";
for(int i=0;i+1<n;++i)
if(s[i]=='0') flip(i+1);
// cerr<<ca<<"w"<<ca/2<<"\n";
while(m--)
{
int o;
scanf("%d",&o);
if(o==1)
{
int e;
scanf("%d",&e);
flip(e);
}
else if(o==2)
{
int x,w;
scanf("%d%d",&x,&w);
if(w==0) continue;
x=ftop(x);
int s=fc(x);
EDT;
Seg::pt(1,fe[x],ed[x],s,1,w);
edb(x,1,0);
}
else if(o==4)
{
int x;
scanf("%d",&x);
auto OP=Seg::qsum(1,fe[x],fe[x]);
printf("%lld\n",OP);
fflush(stdout);
}
else if(o==5)
{
int x,x_;
scanf("%d",&x);
x_=x;
x=ftop(x);
// cerr<<x<<"!\n";
int s=fc(x);
auto OP=QS(x);
printf("%lld\n",OP);
fflush(stdout);
}
else if(o==6)
{
int x;
scanf("%d",&x);
x=ftop(x);
int s=fc(x); EDT;
Seg::pt(1,fe[x],ed[x],s,0,0);
edb(x,-1);
}
else if(o==3)
{
int x;
scanf("%d",&x);
int y=ftop(x);
// cerr<<y<<"!"<<fe[y]<<"w"<<ed[y]<<"\n";
int s=fc(y);
ll w=QS(y); EDT;
Seg::pt(1,fe[y],ed[y],s,0,0);
// cerr<<"w="<<w<<" y="<<y<<" "<<fe[y]<<"w"<<ed[y]<<"?\n";
// cerr<<"REP"<<Seg::qms(1,fe[y],fe[y],s)<<" "<<fe[x]<<"?\n";
Seg::eds(1,fe[x],w);
}
else if(o==7)
{
printf("%lld\n",ca);
// for(auto u:w)
// cerr<<u<<",";
// cerr<<"\n";
fflush(stdout);
}
else throw "???";
}
}
int main()
{
for(int i=1;i<=M;++i) ls[i+M]=rs[i+M]=i;
for(int i=M-1;i>=1;--i)
ls[i]=ls[i+i],rs[i]=rs[i+i+1];
for(int i=0;i<=M+M;++i)
ss[i]=rs[i]-ls[i]+1;
scanf("%d",&T); sol();
cerr<<clock()<<"ms\n";
}
#pragma GCC optimize("-O3","-funroll-all-loops","-ffast-math")
#include <iostream>
#include <stdio.h>
#include <math.h>
#include <string.h>
#include <time.h>
#include <stdlib.h>
#include <string>
#include <bitset>
#include <vector>
#include <set>
#include <map>
#include <queue>
#include <algorithm>
#include <sstream>
#include <stack>
#include <iomanip>
#include <assert.h>
using namespace std;
#define pb push_back
#define mp make_pair
typedef pair<int,int> pii;
typedef long long ll;
typedef double ld;
typedef vector<int> vi;
#define fi first
#define se second
#define fe first
#define FO(x) {freopen(#x".in","r",stdin);freopen(#x".out","w",stdout);}
#define Edg int M=0,fst[SZ],vb[SZ],nxt[SZ];void ad_de(int a,int b){++M;nxt[M]=fst[a];fst[a]=M;vb[M]=b;}void adde(int a,int b){ad_de(a,b);ad_de(b,a);}
#define Edgc int M=0,fst[SZ],vb[SZ],nxt[SZ],vc[SZ];void ad_de(int a,int b,int c){++M;nxt[M]=fst[a];fst[a]=M;vb[M]=b;vc[M]=c;}void adde(int a,int b,int c){ad_de(a,b,c);ad_de(b,a,c);}
#define es(x,e) (int e=fst[x];e;e=nxt[e])
#define esb(x,e,b) (int e=fst[x],b=vb[e];e;e=nxt[e],b=vb[e])
#define SZ 666666
int T,n,m,ea[SZ],eb[SZ],ec[SZ];
#define M M_ 
int M=0,fst[SZ],vb[SZ],nxt[SZ];
void ad_de(int a,int b)
{++M;nxt[M]=fst[a];fst[a]=M;vb[M]=b;}
void adde(int a,int b){ad_de(a,b);ad_de(b,a);}
#undef M
char s[SZ];
int sz[SZ],son[SZ],dep[SZ],fa[SZ];
const int M=262144;
int ls[SZ],rs[SZ],ss[SZ];
#define CL(x) memset(x,0,sizeof x)
namespace Seg
{
bool tk[SZ];
int ta[SZ],mi[SZ],mc[SZ];
ll su[SZ],ms[SZ],tb[SZ];
inline void clr()
{
	CL(mi); CL(su);
	CL(ms); CL(tb); CL(ta);
	for(int i=0;i<SZ;++i) tk[i]=1,mi[i]=1e9;
}
inline void pd(int x)
{
	if(ta[x]||tb[x]||tk[x]!=1);
	else return;
	mi[x]+=ta[x]; su[x]-=ms[x];
	ms[x]=ms[x]*tk[x]+mc[x]*tb[x];
	su[x]+=ms[x];
	if(x<=M)
	{
		ta[x+x]+=ta[x],ta[x+x+1]+=ta[x];
		int u=min(mi[x+x],mi[x+x+1]);
		if(mi[x+x]==u)
		{
		tk[x+x]&=tk[x];
		tb[x+x]=tb[x+x]*tk[x]+tb[x];
		}
		if(mi[x+x+1]==u)
		{
		tk[x+x+1]&=tk[x];
		tb[x+x+1]=tb[x+x+1]*tk[x]+tb[x];
		}
	}
	ta[x]=tb[x]=0; tk[x]=1;
}
inline void upd(int x)
{
	pd(x+x); pd(x+x+1);
	su[x]=su[x+x]+su[x+x+1];
	if(mi[x+x]<mi[x+x+1])
		mi[x]=mi[x+x],mc[x]=mc[x+x],ms[x]=ms[x+x];
	else if(mi[x+x]>mi[x+x+1])
		mi[x]=mi[x+x+1],mc[x]=mc[x+x+1],ms[x]=ms[x+x+1];
	else mi[x]=mi[x+x],
	mc[x]=mc[x+x]+mc[x+x+1],
	ms[x]=ms[x+x]+ms[x+x+1];
//	mi[x]=min(mi[x+x],mi[x+x+1]); mc[x]=ms[x]=0;
//	if(mi[x]==mi[x+x]) mc[x]+=mc[x+x],ms[x]+=ms[x+x];
//	if(mi[x]==mi[x+x+1]) mc[x]+=mc[x+x+1],ms[x]+=ms[x+x+1];
}
inline void add(int x,int ql,int qr,int v)
{
	if(ql>qr||rs[x]<ql||qr<ls[x]) return;
	pd(x);
	if(ql<=ls[x]&&rs[x]<=qr)
	{
		ta[x]+=v; return;
	}
	add(x+x,ql,qr,v);
	add(x+x+1,ql,qr,v);
	upd(x);
}
inline int qmin(int x,int ql,int qr)
{
	if(ql>qr||rs[x]<ql||qr<ls[x]) return 2e9;
	pd(x);
	if(ql<=ls[x]&&rs[x]<=qr) return mi[x];
	int g=min(qmin(x+x,ql,qr),
	qmin(x+x+1,ql,qr));
	upd(x); return g;
}
inline ll qsum(int x,int ql,int qr)
{
	if(ql>qr||rs[x]<ql||qr<ls[x]) return 0;
	pd(x);
	if(ql<=ls[x]&&rs[x]<=qr) return su[x];
	ll g=qsum(x+x,ql,qr)+qsum(x+x+1,ql,qr);
	upd(x); return g;
}
inline void pt(int x,int ql,int qr,int u,int k,int b)
{
	if(ql>qr||rs[x]<ql||qr<ls[x]) return;
	pd(x);
	if(mi[x]>u) return;
	if(ql<=ls[x]&&rs[x]<=qr)
	{
		assert(mi[x]==u);
//		cerr<<"PUTSHIT:"<<ls[x]<<"~"<<rs[x]<<" "<<k<<","<<b<<"\n";
		tk[x]=k; tb[x]=b; return;
	}
	pt(x+x,ql,qr,u,k,b);
	pt(x+x+1,ql,qr,u,k,b);
	upd(x);
}
inline pair<int,ll> qms(int x,int ql,int qr)
{
	if(ql>qr||rs[x]<ql||qr<ls[x])
		return pair<int,ll>(2e9,0);
	pd(x);
	if(ql<=ls[x]&&rs[x]<=qr)
		return pair<int,ll>(mi[x],ms[x]);
	pair<int,ll> g=qms(x+x,ql,qr);
	pd(x+x+1);
	if(mi[x+x+1]>g.fi)
	{
		upd(x); return g;
	}
	pair<int,ll> h=qms(x+x+1,ql,qr);
	upd(x);
	if(g.fi<h.fi) return g;
	if(g.fi>h.fi) return h;
	return pair<int,ll>(g.fi,g.se+h.se);
}
inline void eds(int x,int p,ll s)
{
	pd(x);
	if(ls[x]==rs[x])
	{
		su[x]=ms[x]=s;
		return;
	}
	if(p<=rs[x+x])
		eds(x+x,p,s);
	else eds(x+x+1,p,s);
	upd(x);
}
}
void dfs(int x,int f=0)
{
	sz[x]=1; dep[x]=dep[f]+1; fa[x]=f; son[x]=0;
	for esb(x,e,b) if(b!=f)
	{
		dfs(b,x); sz[x]+=sz[b];
		if(sz[b]>sz[son[x]]) son[x]=b;
	}
}
int bs[SZ];
void edt(int x,int y)
{
	for(;x<SZ;x+=x&-x) bs[x]+=y;
}
int qs(int x)
{
	int s=0;
	for(;x>=1;x-=x&-x) s+=bs[x];
	return s;
}
namespace B2
{
int bs[SZ];
void edt(int x,int y)
{
	for(;x<SZ;x+=x&-x) bs[x]+=y;
}
int qs(int x)
{
	int s=0;
	for(;x>=1;x-=x&-x) s+=bs[x];
	return s;
}
int qs(int l,int r)
{return qs(r)-qs(l-1);}
}
int top[SZ],fe[SZ],rv[SZ],C,ed[SZ],p1[SZ],p2[SZ],Q=0;
void dfs2(int x,int t)
{
	top[x]=t; fe[x]=++C; rv[C]=x; p1[x]=++Q;
	if(son[x]) dfs2(son[x],t);
	for esb(x,e,b)
		if(b!=son[x]&&b!=fa[x])
			dfs2(b,b);
	ed[x]=C; p2[x]=++Q;
}
int lca(int a,int b)
{
	while(top[a]!=top[b])
	{
		if(dep[top[a]]<dep[top[b]]) b=fa[top[b]];
		else a=fa[top[a]];
	}
	if(dep[a]<dep[b]) return a;
	return b;
}
int lt[SZ],E=3; ll la[SZ];
#define EDT ++E
namespace Seg2
{
int g[SZ];
void upd(int x,int y)
{
	x+=M; g[x]=y;
	while(x>>=1)
		g[x]=max(g[x+x],g[x+x+1]);
}
int lp(int x,int ql,int qr,int u)
{
	if(ql>qr||rs[x]<ql||qr<ls[x]||g[x]<u) return 0;
	if(ls[x]==rs[x]) return ls[x];
	int uu=lp(x+x+1,ql,qr,u);
	if(uu) return uu;
	return lp(x+x,ql,qr,u);
}
}
int ftop(int x)
{return rv[Seg2::lp(1,1,fe[x],ed[x])];}
inline int fc(int x) {return qs(p1[x]);}
set<int> w;
ll ca=0;
ll QS(int x)
{
	if(lt[x]==E) return la[x];
	lt[x]=E;
	return la[x]=Seg::qms(1,fe[x],ed[x]).se;
}
void edb(int x,int v,bool chk=1)
{
	x=ftop(x);
	//cerr<<x<<" "<<Seg::qms(1,fe[x],ed[x],F)<<"QWQ\n";
	int u=fe[x];
	if(v==-1)
	{
		if(!w.count(u)) return;
		B2::edt(u,-1);
		if(w.size()<=2)
		{
			w.erase(u);
			ca=0; return;
		}
		auto U=w.find(u);
		int L,R;
		++U;
		if(U!=w.end()) R=*U;
		else R=*w.begin();
		--U;
		if(U!=w.begin()) L=*(--U),++U;
		else L=*w.rbegin();
		int A=rv[L],B=rv[*U],C=rv[R];
		int AB=lca(A,B),AC=lca(A,C),BC=lca(B,C);
		ca-=fc(B)-fc(AB)-fc(BC)+fc(AC);
		w.erase(U);
	}
	else
	{
		if(w.count(u)) return;
		if(chk&&!QS(x)) return;
		B2::edt(u,1);
		if(w.size()<=0)
		{
			w.insert(u);
			ca=0; return;
		}
		auto U=w.insert(u).fi;
		int L,R;
		++U;
		if(U!=w.end()) R=*U;
		else R=*w.begin();
		--U;
		if(U!=w.begin()) L=*(--U),++U;
		else L=*w.rbegin();
		int A=rv[L],B=rv[*U],C=rv[R];
		int AB=lca(A,B),AC=lca(A,C),BC=lca(B,C);
		ca+=fc(B)-fc(AB)-fc(BC)+fc(AC);
	}
}
void flip(int e)
{
	if(ec[e]) //block
	{
		int ww=B2::qs(fe[eb[e]],ed[eb[e]]);
		if(ww&&ww!=int(w.size())) ca++;
		edt(p1[eb[e]],1);
		edt(p2[eb[e]],-1);
		edb(ea[e],-1);
		Seg2::upd(fe[eb[e]],ed[eb[e]]);
		EDT;
		Seg::add(1,fe[eb[e]],ed[eb[e]],1);
		ec[e]^=1;
		edb(ea[e],1);
		edb(eb[e],1);
	}
	else //unblock
	{
		int ww=B2::qs(fe[eb[e]],ed[eb[e]]);
		if(ww&&ww!=int(w.size())) ca--;
		edt(p1[eb[e]],-1);
		edt(p2[eb[e]],1);
		edb(ea[e],-1);
		edb(eb[e],-1);
		Seg2::upd(fe[eb[e]],0);
		EDT;
		Seg::add(1,fe[eb[e]],ed[eb[e]],-1);
		ec[e]^=1;
		edb(ea[e],1);
	}
}
void sol()
{
	scanf("%d%d",&n,&m); M_=C=0;
//	cerr<<"+"<<n<<"w"<<m<<"\n";
	Seg::clr();
	for(int i=1;i<=n;++i)
		fst[i]=0,Seg::mc[i+M]=1,Seg::mi[i+M]=0;
	for(int i=1,a,b;i<n;++i)
		scanf("%d%d",&a,&b),
		ea[i]=a,eb[i]=b,ec[i]=0,
		adde(a,b);
	dfs(1); dfs2(1,1);
	for(int i=1;i<=n;++i)
		Seg2::upd(fe[i],ed[i]);
	for(int i=1;i<n;++i)
	{
		if(fa[ea[i]]==eb[i]) swap(ea[i],eb[i]);
		assert(fa[eb[i]]==ea[i]);
	}
	if(n>1) scanf("%s",s); //is it a trap?
//	for(int i=1;i<=n;++i)
//		cerr<<fe[i]<<",";
//	cerr<<"\n";
	for(int i=1;i<=n;++i)
		scanf("%lld",&Seg::su[fe[i]+M]),
		Seg::ms[fe[i]+M]=Seg::su[fe[i]+M];
	for(int i=M-1;i>=1;--i)
		Seg::upd(i);
	for(int i=1;i<n;++i)
		Seg::add(1,fe[eb[i]],ed[eb[i]],1),
		edt(p1[eb[i]],1),
		edt(p2[eb[i]],-1);
	for(int i=1;i<=n;++i) edb(i,1);
//	cerr<<ca<<"w"<<ca/2<<" "<<n<<"\n";
//	for(auto p:w)
//		cerr<<rv[p]<<",";cerr<<"\n";
	for(int i=0;i+1<n;++i)
		if(s[i]=='0') flip(i+1);
//	cerr<<ca<<"w"<<ca/2<<"\n";
	while(m--)
	{
		int o;
		scanf("%d",&o);
		if(o==1)
		{
			int e;
			scanf("%d",&e);
			flip(e);
		}
		else if(o==2)
		{
			int x,w;
			scanf("%d%d",&x,&w);
			if(w==0) continue;
			x=ftop(x);
			int s=fc(x);
			EDT;
			Seg::pt(1,fe[x],ed[x],s,1,w);
			edb(x,1,0);
		}
		else if(o==4)
		{
			int x;
			scanf("%d",&x);
			auto OP=Seg::qsum(1,fe[x],fe[x]);
			printf("%lld\n",OP);
			fflush(stdout);
		}
		else if(o==5)
		{
			int x,x_;
			scanf("%d",&x);
			x_=x;
			x=ftop(x);
//			cerr<<x<<"!\n";
			int s=fc(x);
			auto OP=QS(x);
			printf("%lld\n",OP);
			fflush(stdout);
		}
		else if(o==6)
		{
			int x;
			scanf("%d",&x);
			x=ftop(x);
			int s=fc(x); EDT;
			Seg::pt(1,fe[x],ed[x],s,0,0);
			edb(x,-1);
		}
		else if(o==3)
		{
			int x;
			scanf("%d",&x);
			int y=ftop(x);
//			cerr<<y<<"!"<<fe[y]<<"w"<<ed[y]<<"\n";
			int s=fc(y);
			ll w=QS(y); EDT;
			Seg::pt(1,fe[y],ed[y],s,0,0);
//			cerr<<"w="<<w<<" y="<<y<<" "<<fe[y]<<"w"<<ed[y]<<"?\n";
//			cerr<<"REP"<<Seg::qms(1,fe[y],fe[y],s)<<" "<<fe[x]<<"?\n";
			Seg::eds(1,fe[x],w);
		}
		else if(o==7)
		{
			printf("%lld\n",ca);
//			for(auto u:w)
//				cerr<<u<<",";
//			cerr<<"\n";
			fflush(stdout);
		}
		else throw "???";
	}
}
int main()
{
	for(int i=1;i<=M;++i) ls[i+M]=rs[i+M]=i;
	for(int i=M-1;i>=1;--i)
		ls[i]=ls[i+i],rs[i]=rs[i+i+1];
	for(int i=0;i<=M+M;++i)
		ss[i]=rs[i]-ls[i]+1;
	scanf("%d",&T); sol();
	cerr<<clock()<<"ms\n";
}