प्राकृतिक भाषा टूलकिट - रूपांतरण पेड़
पेड़ों को बदलने के दो कारण निम्नलिखित हैं -
- गहरे पार्स पेड़ को संशोधित करने के लिए और
- गहरे पार्स पेड़ों को समतल करने के लिए
वाक्य में वृक्ष या उपमान परिवर्तित करना
पहला नुस्खा जिस पर हम यहां चर्चा करने जा रहे हैं वह है ट्री या सबट्री को एक वाक्य या चंक स्ट्रिंग में बदलना। यह बहुत सरल है, आइए हम निम्नलिखित उदाहरण देखें -
उदाहरण
from nltk.corpus import treebank_chunk
tree = treebank_chunk.chunked_sents()[2]
' '.join([w for w, t in tree.leaves()])
उत्पादन
'Rudolph Agnew , 55 years old and former chairman of Consolidated Gold Fields
PLC , was named a nonexecutive director of this British industrial
conglomerate .'
दीप वृक्ष समतल
नेस्टेड वाक्यांशों के गहरे पेड़ों का उपयोग एक चंक प्रशिक्षण के लिए नहीं किया जा सकता है इसलिए हमें उपयोग करने से पहले उन्हें समतल करना चाहिए। निम्नलिखित उदाहरण में, हम 3 पार्स किए गए वाक्य का उपयोग करने जा रहे हैं, जो नेस्टेड वाक्यांशों का गहरा पेड़ है, सेtreebank कोष।
उदाहरण
इसे प्राप्त करने के लिए, हम नाम के एक फ़ंक्शन को परिभाषित कर रहे हैं deeptree_flat()वह एक ही पेड़ लेगा और एक नया पेड़ लौटाएगा जो केवल सबसे निचले स्तर के पेड़ रखता है। अधिकांश काम करने के लिए, यह एक सहायक फ़ंक्शन का उपयोग करता है जिसे हमने नाम दिया हैchildtree_flat()।
from nltk.tree import Tree
def childtree_flat(trees):
children = []
for t in trees:
if t.height() < 3:
children.extend(t.pos())
elif t.height() == 3:
children.append(Tree(t.label(), t.pos()))
else:
children.extend(flatten_childtrees([c for c in t]))
return children
def deeptree_flat(tree):
return Tree(tree.label(), flatten_childtrees([c for c in tree]))
अब, हमें कॉल करें deeptree_flat() 3 पार्स किए गए वाक्य पर कार्य, जो नेस्टेड वाक्यांशों का गहरा पेड़ है, से treebankकोष। हमने इन फ़ंक्शंस को deeptree.py नाम की एक फ़ाइल में सहेजा है।
from deeptree import deeptree_flat
from nltk.corpus import treebank
deeptree_flat(treebank.parsed_sents()[2])
उत्पादन
Tree('S', [Tree('NP', [('Rudolph', 'NNP'), ('Agnew', 'NNP')]),
(',', ','), Tree('NP', [('55', 'CD'),
('years', 'NNS')]), ('old', 'JJ'), ('and', 'CC'),
Tree('NP', [('former', 'JJ'),
('chairman', 'NN')]), ('of', 'IN'), Tree('NP', [('Consolidated', 'NNP'),
('Gold', 'NNP'), ('Fields', 'NNP'), ('PLC',
'NNP')]), (',', ','), ('was', 'VBD'),
('named', 'VBN'), Tree('NP-SBJ', [('*-1', '-NONE-')]),
Tree('NP', [('a', 'DT'), ('nonexecutive', 'JJ'), ('director', 'NN')]),
('of', 'IN'), Tree('NP',
[('this', 'DT'), ('British', 'JJ'),
('industrial', 'JJ'), ('conglomerate', 'NN')]), ('.', '.')])
उथला पेड़ का निर्माण
पिछले अनुभाग में, हम केवल सबसे निचले स्तर के उप-ग्रेड रखते हुए नेस्टेड वाक्यांशों के एक गहरे पेड़ को समतल करते हैं। इस खंड में, हम उथले वृक्ष के निर्माण के लिए केवल उच्चतम-स्तरीय उप-वृक्षों को रखने जा रहे हैं। निम्नलिखित उदाहरण में हम 3 पार्स किए गए वाक्य का उपयोग करने जा रहे हैं, जो नेस्टेड वाक्यांशों का गहरा पेड़ है, सेtreebank कोष।
उदाहरण
इसे प्राप्त करने के लिए, हम नाम के एक फ़ंक्शन को परिभाषित कर रहे हैं tree_shallow() जो केवल शीर्ष सबट्री लेबल रखकर सभी नेस्टेड उपप्रकार को समाप्त कर देगा।
from nltk.tree import Tree
def tree_shallow(tree):
children = []
for t in tree:
if t.height() < 3:
children.extend(t.pos())
else:
children.append(Tree(t.label(), t.pos()))
return Tree(tree.label(), children)
अब, हमें कॉल करें tree_shallow()3 rd पार्स किए गए वाक्य पर कार्य , जो नेस्टेड वाक्यांशों का गहरा पेड़ है, सेtreebankकोष। हमने उक्त फ़ंक्शन को shallowtree.py नामक एक फ़ाइल में सहेजा है।
from shallowtree import shallow_tree
from nltk.corpus import treebank
tree_shallow(treebank.parsed_sents()[2])
उत्पादन
Tree('S', [Tree('NP-SBJ-1', [('Rudolph', 'NNP'), ('Agnew', 'NNP'), (',', ','),
('55', 'CD'), ('years', 'NNS'), ('old', 'JJ'), ('and', 'CC'),
('former', 'JJ'), ('chairman', 'NN'), ('of', 'IN'), ('Consolidated', 'NNP'),
('Gold', 'NNP'), ('Fields', 'NNP'), ('PLC', 'NNP'), (',', ',')]),
Tree('VP', [('was', 'VBD'), ('named', 'VBN'), ('*-1', '-NONE-'), ('a', 'DT'),
('nonexecutive', 'JJ'), ('director', 'NN'), ('of', 'IN'), ('this', 'DT'),
('British', 'JJ'), ('industrial', 'JJ'), ('conglomerate', 'NN')]), ('.', '.')])
पेड़ों की ऊंचाई प्राप्त करने में मदद से हम अंतर देख सकते हैं -
from nltk.corpus import treebank
tree_shallow(treebank.parsed_sents()[2]).height()
उत्पादन
3
from nltk.corpus import treebank
treebank.parsed_sents()[2].height()
उत्पादन
9
ट्री लेबल रूपांतरण
पार्स पेड़ों में विभिन्न प्रकार के होते हैं Treeलेबल प्रकार जो चंक पेड़ों में मौजूद नहीं हैं। लेकिन चेंकर को प्रशिक्षित करने के लिए पार्स ट्री का उपयोग करते समय, हम कुछ ट्री लेबल को अधिक सामान्य लेबल प्रकारों में परिवर्तित करके इस विविधता को कम करना चाहेंगे। उदाहरण के लिए, हमारे पास एनपी-एसबीएल और एनपी-टीएमपी नाम के दो वैकल्पिक एनपी सबस्ट्रेट्स हैं। हम दोनों को एनपी में बदल सकते हैं। आइए देखें कि इसे निम्नलिखित उदाहरण में कैसे किया जाए।
उदाहरण
इसे प्राप्त करने के लिए हम एक फ़ंक्शन का नाम निर्धारित कर रहे हैं tree_convert() दो तर्क निम्नलिखित हैं -
- वृक्ष का रूपान्तरण
- एक लेबल रूपांतरण मानचित्रण
यह फ़ंक्शन मैपिंग में मानों के आधार पर प्रतिस्थापित सभी मिलान लेबल के साथ एक नया ट्री लौटाएगा।
from nltk.tree import Tree
def tree_convert(tree, mapping):
children = []
for t in tree:
if isinstance(t, Tree):
children.append(convert_tree_labels(t, mapping))
else:
children.append(t)
label = mapping.get(tree.label(), tree.label())
return Tree(label, children)
अब, हमें कॉल करें tree_convert() 3 पार्स किए गए वाक्य पर कार्य, जो नेस्टेड वाक्यांशों का गहरा पेड़ है, से treebankकोष। हमने इन कार्यों को एक फ़ाइल में सहेजा है जिसका नाम हैconverttree.py।
from converttree import tree_convert
from nltk.corpus import treebank
mapping = {'NP-SBJ': 'NP', 'NP-TMP': 'NP'}
convert_tree_labels(treebank.parsed_sents()[2], mapping)
उत्पादन
Tree('S', [Tree('NP-SBJ-1', [Tree('NP', [Tree('NNP', ['Rudolph']),
Tree('NNP', ['Agnew'])]), Tree(',', [',']),
Tree('UCP', [Tree('ADJP', [Tree('NP', [Tree('CD', ['55']),
Tree('NNS', ['years'])]),
Tree('JJ', ['old'])]), Tree('CC', ['and']),
Tree('NP', [Tree('NP', [Tree('JJ', ['former']),
Tree('NN', ['chairman'])]), Tree('PP', [Tree('IN', ['of']),
Tree('NP', [Tree('NNP', ['Consolidated']),
Tree('NNP', ['Gold']), Tree('NNP', ['Fields']),
Tree('NNP', ['PLC'])])])])]), Tree(',', [','])]),
Tree('VP', [Tree('VBD', ['was']),Tree('VP', [Tree('VBN', ['named']),
Tree('S', [Tree('NP', [Tree('-NONE-', ['*-1'])]),
Tree('NP-PRD', [Tree('NP', [Tree('DT', ['a']),
Tree('JJ', ['nonexecutive']), Tree('NN', ['director'])]),
Tree('PP', [Tree('IN', ['of']), Tree('NP',
[Tree('DT', ['this']), Tree('JJ', ['British']), Tree('JJ', ['industrial']),
Tree('NN', ['conglomerate'])])])])])])]), Tree('.', ['.'])])