|
1
|
(*
|
|
2
3
4
|
* ENIAMwalenty, a converter for Polish Valence Dictionary "Walenty".
* Copyright (C) 2016-2017 Wojciech Jaworski <wjaworski atSPAMfree mimuw dot edu dot pl>
* Copyright (C) 2016-2017 Institute of Computer Science Polish Academy of Sciences
|
|
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
*
* This library is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This library 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*)
|
|
20
|
open ENIAMwalTypes
|
|
21
|
open Xstd
|
|
22
23
|
let rec expand_schema_morf expands = function
|
|
24
25
|
(* PhraseAbbr(Advp "misc",[]) -> PhraseAbbr(Advp "misc",[Phrase AdvP])
| PhraseAbbr(Advp "mod",[]) -> PhraseAbbr(Advp "mod",[Phrase AdvP]) *)
|
|
26
27
28
29
30
31
32
|
| PhraseAbbr(abbr,[]) -> (try PhraseAbbr(abbr,AbbrMap.find expands abbr) with Not_found -> failwith "expand_schema_morf")
| PhraseAbbr(abbr,morfs) -> PhraseAbbr(abbr,Xlist.map morfs (expand_schema_morf expands))
| LexPhrase(pos_lex,(restr,schema)) -> LexPhrase(pos_lex,(restr,expand_schema expands schema))
| morf -> morf
and expand_schema expands schema =
Xlist.map schema (fun s ->
|
|
33
34
|
{s with morfs=Xlist.map s.morfs (expand_schema_morf expands)})
|
|
35
36
37
38
39
40
41
42
|
let rec expand_subtypes_morf subtypes = function
PhraseComp(comp_morf,(ctype,comps)) ->
let comps = if comps = [] then (try CompMap.find subtypes ctype with Not_found -> failwith "expand_subtypes_schema") else comps in
Xlist.map comps (fun comp -> Phrase(match comp_morf with
Cp -> CP(ctype,comp)
| Ncp case -> NCP(case,ctype,comp)
| Prepncp(prep,case) -> PrepNCP(prep,case,ctype,comp)))
| LexPhrase(pos_lex,(restr,schema)) -> [LexPhrase(pos_lex,(restr,expand_subtypes subtypes schema))]
|
|
43
|
| PhraseAbbr(abbr,morfs) ->
|
|
44
|
List.flatten (Xlist.map morfs (expand_subtypes_morf subtypes))
|
|
45
46
47
48
49
|
| E Null -> [E(NP(Str));E(NCP(Str,CompTypeUndef,CompUndef));E(CP(CompTypeUndef,CompUndef)); E(Or)]
| morf -> [morf]
and expand_subtypes subtypes schema =
Xlist.map schema (fun s ->
|
|
50
|
{s with morfs=List.flatten (Xlist.map s.morfs (expand_subtypes_morf subtypes))})
|
|
51
52
53
54
55
56
|
let expand_equivs_phrase equivs = function
| PrepNP(prep,case) -> Xlist.map (try StringMap.find equivs prep with Not_found -> [prep]) (fun prep -> PrepNP(prep,case))
| PrepAdjP(prep,case) -> Xlist.map (try StringMap.find equivs prep with Not_found -> [prep]) (fun prep -> PrepAdjP(prep,case))
| PrepNumP(prep,case) -> Xlist.map (try StringMap.find equivs prep with Not_found -> [prep]) (fun prep -> PrepNumP(prep,case))
| ComprepNP(prep) -> Xlist.map (try StringMap.find equivs prep with Not_found -> [prep]) (fun prep -> ComprepNP(prep))
|
|
57
|
| ComparP(prep) -> Xlist.map (try StringMap.find equivs prep with Not_found -> [prep]) (fun prep -> ComparP(prep))
|
|
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
| CP(ctype,Comp comp) -> Xlist.map (try StringMap.find equivs comp with Not_found -> [comp]) (fun comp -> CP(ctype,Comp comp))
| NCP(case,ctype,Comp comp) -> Xlist.map (try StringMap.find equivs comp with Not_found -> [comp]) (fun comp -> NCP(case,ctype,Comp comp))
| PrepNCP(prep,case,ctype,Comp comp) -> List.flatten (
Xlist.map (try StringMap.find equivs comp with Not_found -> [comp]) (fun comp ->
Xlist.map (try StringMap.find equivs prep with Not_found -> [prep]) (fun prep ->
PrepNCP(prep,case,ctype,Comp comp))))
| phrase -> [phrase]
let rec expand_equivs_lex equivs = function
Lexeme s -> (try XOR(Xlist.map (StringMap.find equivs s) (fun s -> Lexeme s)) with Not_found -> Lexeme s)
| ORconcat l -> ORconcat(Xlist.map l (expand_equivs_lex equivs))
| ORcoord l -> ORcoord(Xlist.map l (expand_equivs_lex equivs))
| XOR l -> XOR(Xlist.map l (expand_equivs_lex equivs))
| Elexeme gender -> Elexeme gender
let rec expand_equivs_morf equivs = function
Phrase phrase -> Xlist.map (expand_equivs_phrase equivs phrase) (fun phrase -> Phrase phrase)
| E phrase -> Xlist.map (expand_equivs_phrase equivs phrase) (fun phrase -> E phrase)
| LexPhrase(pos_lex,(restr,schema)) -> [LexPhrase(Xlist.map pos_lex (fun (pos,lex) -> pos, expand_equivs_lex equivs lex),(restr,expand_equivs_schema equivs schema))]
| morf -> failwith ("expand_equivs_morf: " ^ ENIAMwalStringOf.morf morf)
and expand_equivs_schema equivs schema =
Xlist.map schema (fun s ->
{s with morfs=List.flatten (Xlist.map s.morfs (expand_equivs_morf equivs))})
|
|
83
84
85
|
(* UWAGA: aktualnie equivs nie są wstawiane do expands *)
let load_realizations (expands,subtypes,equivs) =
let subtypes = Xlist.fold subtypes CompMap.empty (fun subtypes -> function
|
|
86
87
88
|
"int",l -> CompMap.add subtypes Int (List.flatten (Xlist.map l (fun v -> snd(ENIAMwalTEI.parse_comp v))))
| "rel",l -> CompMap.add subtypes Rel (List.flatten (Xlist.map l (fun v -> snd(ENIAMwalTEI.parse_comp v))))
| _ -> failwith "load_realizations 1") in
|
|
89
|
let equivs = Xlist.fold equivs StringMap.empty (fun equivs (k,l) -> StringMap.add equivs k (k :: l)) in
|
|
90
|
let expands,compreps,adv_types = Xlist.fold expands (AbbrMap.empty,[],[]) (fun (expands, compreps, adv_types) (id,k,l) ->
|
|
91
|
match k with
|
|
92
93
94
95
96
|
Phrase(AdvP m) -> expands, compreps, (m,Xlist.map l (function
LexPhrase([ADV (Grad "pos"),Lexeme s],(Natr,[])) -> s
| _ -> failwith "load_realizations 3")) :: adv_types
| PhraseAbbr(Nonch,[]) -> AbbrMap.add expands Nonch l, compreps, adv_types
(* | PhraseAbbr(Xp m,[]) -> AbbrMap.add expands (Xp m) (List.flatten (Xlist.map l (function
|
|
97
|
PhraseAbbr(Advp m,[]) -> (try AbbrMap.find expands (Advp m) with Not_found -> [PhraseAbbr(Advp m,[])]) (* zakładam, że advp się nie rozmnoży *)
|
|
98
99
100
101
102
|
| morf -> [morf]))), compreps, adv_types *)
| PhraseAbbr(Xp m,[]) -> AbbrMap.add expands (Xp m) l, compreps, adv_types
| Phrase(ComprepNP s) -> expands, (s, l) :: compreps, adv_types
| PhraseAbbr(Distrp,[]) -> AbbrMap.add expands Distrp l, compreps, adv_types
| PhraseAbbr(Possp,[]) -> AbbrMap.add expands Possp l, compreps, adv_types
|
|
103
104
105
|
| _ -> failwith "load_realizations 2") in
let compreps = Xlist.map compreps (fun (s,morfs) ->
s, List.flatten (List.flatten (Xlist.map morfs (fun morf -> Xlist.map (expand_subtypes_morf subtypes (expand_schema_morf expands morf)) (expand_equivs_morf equivs))))) in
|
|
106
|
expands,compreps,subtypes,equivs,adv_types
|