https://github.com/RichardMoot/GrailLight
Raw File
Tip revision: 67fbacd0e365d9008c021016377c0cfe1f1e309d authored by Richard Moot on 27 April 2021, 15:02:38 UTC
Update Supertag.tcl
Tip revision: 67fbacd
chart_to_const.pl

proof_file('../TLGbank/chart_proofs/aa1_proofs.pl').
proof_file('../TLGbank/chart_proofs/ap1_proofs.pl').
proof_file('../TLGbank/chart_proofs/aq2_proofs.pl').
proof_file('../TLGbank/chart_proofs/as2_proofs.pl').
proof_file('../TLGbank/chart_proofs/at_proofs.pl').
proof_file('../TLGbank/chart_proofs/300_proofs.pl').
proof_file('../TLGbank/chart_proofs/8000_proofs.pl').
    
chart_to_const :-
    findall(X, proof_file(X), List),
    chart_to_const(List).

chart_to_const([]).
chart_to_const([F|Fs]) :-
    chart_to_const1(F),
    chart_to_const(Fs).

chart_to_const1(F) :-
    file_base_name(F,BN),
    print(BN),
    file_name_extension(B, _, BN),
    atomic_list_concat([B,left], '_', BL),
    atomic_list_concat([B,right], '_', BR),
    file_name_extension(BL, txt, BLT),
    file_name_extension(BR, txt, BRT),
    abolish(proof/2),
    compile(F),
    findall(I-Pros, proof(I,rule(_,Pros,_F,_Prems)), ProsList),
    chart_to_const(ProsList, LLs, LRs),
    export(LLs, BLT),
    export(LRs, BRT).

chart_pros_to_const(I) :-
	proof(I, rule(_, Pros, _, _)),
	pros_to_const_l(Pros, -1, _, LL, []),
	pros_to_const_r(Pros, -1, _, RLR, []),
	reverse(RLR, LR),
	print(LL),
	nl,
	print(LR),
	compute_penalties(LL, LR, 0).

compute_penalties([], [], _).
compute_penalties([_], [_], _).
compute_penalties([W1-L1,W2-L2|Ls],[_-R1,_-R2|Rs], Pos0) :-
	X is L1 - R1, % close bracket without open bracket
	(X < 0 -> PenL is abs(X) ; PenL = 0),
	Y is L2 - R2, % open bracket without close bracket
	(Y > 0 -> PenR = Y ; PenR = 0),
	Pos1 is Pos0 + 1,
	Pos2 is Pos1 + 1,
	Pen is PenL + PenR,
	format('~w ~w [~w-~w]:(~w+~w)=~w ', [W1,W2,Pos0,Pos2,PenL,PenR,Pen]),
	compute_penalties([W2-L2|Ls], [_-R2|Rs], Pos1).

chart_to_const([], [], []).
chart_to_const([_-Pros|Rest], [LL|LLs], [LR|LRs]) :-
	pros_to_const_l(Pros, -1, _, LL, []),
	pros_to_const_r(Pros, -1, _, RLR, []),
	reverse(RLR, LR),
	chart_to_const(Rest, LLs, LRs).


pros_to_const_l(p(_,A,B), L0, L) -->
	!,
	{L1 is L0 + 1},
	pros_to_const_l(A, L1, L2),
	pros_to_const_l(B, L2, L).
pros_to_const_l(W, L, 0) -->
	{C is max(L,0)},
	[W-C].

pros_to_const_r(p(_,A,B), R0, R) -->
	!,
	{R1 is R0 + 1},
	pros_to_const_r(B, R1, R2),
	pros_to_const_r(A, R2, R).
pros_to_const_r(W, R, 0) -->
	{C is max(R,0)},
	[W-C].


export(List, File) :-
	open(File, write, Stream),
	export_array(List, Stream),
	close(Stream).

export_array([], _Stream).
export_array([L|Ls], Stream) :-
	export_list(L, Stream),
	export_array(Ls, Stream).

export_list([], _Stream).
export_list([_-I|Rest], Stream) :-
	export_list(Rest, I, Stream).

export_list([], I, Stream) :-
	print(Stream, I),
	nl(Stream).
export_list([_-J|Rest], I, Stream) :-
	format(Stream, '~p ', [I]),
	export_list(Rest, J, Stream).
	
back to top