go:- L=[12,2,5,13,6,8,14,4,1,11,9,5,3,15,10], length(L,N), functor(Vec,vec,N), Vec=..[_|SortedL], statistics(runtime,[Start|_]), psort(L,SortedL), statistics(runtime,[End|_]), write(SortedL), T is End-Start, write('execution time is :'),write(T). psort(X,Y):-sorted(Y),permutation(X,Y). sorted([X]):-!. sorted([X,Y|L]):- le(X,Y), sorted([Y|L]). delay le(X,Y) :- var(X) : true. delay le(X,Y) :- var(Y) : true. le(X,Y):- true : X=