123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137(**************************************************************************)(* *)(* Ocamlgraph: a generic graph library for OCaml *)(* Copyright (C) 2004-2010 *)(* Sylvain Conchon, Jean-Christophe Filliatre and Julien Signoles *)(* *)(* This software is free software; you can redistribute it and/or *)(* modify it under the terms of the GNU Library General Public *)(* License version 2.1, with the special exception on linking *)(* described in file LICENSE. *)(* *)(* This software 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. *)(* *)(**************************************************************************)(* $Id: classic.ml,v 1.9 2004-02-02 08:11:14 filliatr Exp $ *)moduletypeS=sigtypegraphtypevertexvaldivisors:int->graphvalde_bruijn:int->graphvalvertex_only:int->graphvalfull:?self:bool->int->graphvalcycle:int->graph*vertexarrayvalgrid:n:int->m:int->graph*vertexarrayarrayvalkneser:n:int->k:int->graphvalpetersen:unit->graphendmoduleGeneric(B:Builder.INT)=structtypegraph=B.G.ttypevertex=B.G.V.tletdivisorsn=ifn<2theninvalid_arg"divisors";letv=Array.init(n+1)(funi->B.G.V.createi)inletrecloopgi=letsqrt_i=truncate(sqrt(floati))inletrecloop_igd=ifd>sqrt_ithengelseifimodd==0thenloop_i(B.add_edge(B.add_edgegv.(i/d)v.(i))v.(d)v.(i))(d+1)elseloop_ig(succd)inifi>nthengelseloop(loop_i(B.add_vertexgv.(i))2)(i+1)inloop(B.empty())2letfold_fori0i1f=letrecloopiv=ifi>i1thenvelseloop(i+1)(fvi)inloopi0letde_bruijnn=ifn<1||n>Sys.word_size-1theninvalid_arg"de_bruijn";letv=Array.init(1lsln)(funi->B.G.V.createi)inletall_1=1lsln-1in(* 11...1 *)letg=fold_for0all_1(fungi->B.add_vertexgv.(i))(B.empty())inletrecloopgi=ifi>all_1thengelseletsi=(ilsl1)landall_1inletg=B.add_edgegv.(i)v.(si)inletg=B.add_edgegv.(i)v.(silor1)inloopg(i+1)inloopg0letvertex_onlyn=fold_for1n(fungi->B.add_vertexg(B.G.V.createi))(B.empty())letfull?(self=true)n=letv=Array.init(n+1)(funi->B.G.V.createi)infold_for1n(fungi->fold_for1n(fungj->ifself||i<>jthenB.add_edgegv.(i)v.(j)elseg)g)(fold_for1n(fungi->B.add_vertexgv.(i))(B.empty()))letcyclen=ifn<0theninvalid_arg"cycle";letv=Array.initn(funi->B.G.V.createi)inletg=Array.fold_leftB.add_vertex(B.empty())vinletrecloopgi=ifi=nthengelseletg=B.add_edgegv.(i)v.((i+1)modn)inloopg(i+1)inloopg0,vletgrid~n~m=ifn<0||m<0theninvalid_arg"grid";letcreateij=B.G.V.create(m*i+j)inletv=Array.initn(funi->Array.initm(funj->createij))inletg=Array.fold_left(Array.fold_leftB.add_vertex)(B.empty())vinletrecloopgij=ifi=nthengelseifj=mthenloopg(i+1)0elseletg=ifj<m-1thenB.add_edgegv.(i).(j)v.(i).(j+1)elseginletg=ifi<n-1thenB.add_edgegv.(i).(j)v.(i+1).(j)elseginloopgi(j+1)inloopg00,vletkneser~n~k=ifn<0||n>Sys.int_size||k<0||k>ntheninvalid_arg"kneser";letvert=Hashtbl.create(1lsln)inletaddx=Hashtbl.addvertx(B.G.V.createx)inletrecvisitmasknk=assert(0<=k&&k<=n);ifk=0thenaddmaskelseifk=nthenadd(masklor(1lsln-1))else(letn=n-1invisitmasknk;visit(masklor(1lsln))n(k-1);)invisit0nk;letg=Hashtbl.fold(fun_vg->B.add_vertexgv)vert(B.empty())inletg=Hashtbl.fold(funivig->Hashtbl.fold(funjvjg->ifi<>j&&ilandj=0thenB.add_edgegvivjelseg)vertg)vertgingletpetersen()=kneser~n:5~k:2endmoduleP(G:Sig.PwithtypeV.label=int)=Generic(Builder.P(G))moduleI(G:Sig.IwithtypeV.label=int)=Generic(Builder.I(G))