/* File: flraggavg.P
**
** Author(s): Guizhen Yang
**
** Contact: flora-users@lists.sourceforge.net
**
** Copyright (C) The Research Foundation of SUNY, 1999-2001
**
** FLORA-2 is free software; you can redistribute it and/or modify it under the
** terms of the GNU Library General Public License as published by the Free
** Software Foundation; either version 2 of the License, or (at your option)
** any later version.
**
** FLORA-2 is distributed in the hope that it will be useful, but WITHOUT ANY
** WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
** FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for
** more details.
**
** You should have received a copy of the GNU Library General Public License
** along with FLORA-2; if not, write to the Free Software Foundation,
** Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
**
** $Id: flraggavg.P,v 1.8 2003/06/18 07:01:22 kifer Exp $
**
*/
:- compiler_options([xpp_on]).
#include "flora_terms.flh"
:- import ground/1, member/2 from basics.
:- import flora_warning_line/1 from flrprint.
/*********************************************************************
fllibavg(+Var,+VarList,+Goal,-Avg)
*********************************************************************/
fllibavg(Var,[],Goal,Avg) :-
!,
findall(Var,Goal,Matches),
flora_avgaux(Matches,Avg).
fllibavg(Var,VarList,Goal,Avg) :-
ground(VarList),
!,
findall(Var,Goal,Matches),
flora_avgaux(Matches,Avg).
fllibavg(Var,VarList,Goal,Avg) :-
!,
findall(flora_result(Var,VarList),Goal,Matches),
findall(Grp,member(flora_result(_,Grp),Matches),GL),
sort(GL,Groups),
member(VarList,Groups),
findall(D,member(flora_result(D,VarList),Matches),DL),
flora_avgaux(DL,Avg).
/********************************************************************
flora_avgaux(+List,-Avg).
flora_avgaux(+List,-CurrSum,-CurrNum,-Avg,-Warning)
********************************************************************/
flora_avgaux(Matches,Avg) :-
flora_avgaux(Matches,_,_,Avg,Warning),
( var(Warning) ->
true
;
flora_warning_line("discarding non-numeric values while computing average")
).
flora_avgaux([],Sum,Num,Avg,_) :-
!,
(var(Sum) -> fail; Avg is Sum/Num).
flora_avgaux([H|L],Sum,Num,Avg,Warning) :-
!,
( number(H) ->
( var(Sum) ->
S=H,
N=1
;
S is Sum+H,
N is Num+1
),
flora_avgaux(L,S,N,Avg,Warning)
;
Warning=[],
flora_avgaux(L,Sum,Num,Avg,_)
).
syntax highlighted by Code2HTML, v. 0.9.1