Code Duplication    Length = 19-19 lines in 2 locations

abydos/stemmer.py 2 locations

@@ 1449-1467 (lines=19) @@
1446
1447
    # Step 1
1448
    _r1 = word[r1_start:]
1449
    if _r1[-7:] == 'erendes':
1450
        word = word[:-7]
1451
    elif _r1[-6:] in {'erende', 'hedens'}:
1452
        word = word[:-6]
1453
    elif _r1[-5:] in {'ethed', 'erede', 'heden', 'heder', 'endes', 'ernes',
1454
                      'erens', 'erets'}:
1455
        word = word[:-5]
1456
    elif _r1[-4:] in {'ered', 'ende', 'erne', 'eren', 'erer', 'heds', 'enes',
1457
                      'eres', 'eret'}:
1458
        word = word[:-4]
1459
    elif _r1[-3:] in {'hed', 'ene', 'ere', 'ens', 'ers', 'ets'}:
1460
        word = word[:-3]
1461
    elif _r1[-2:] in {'en', 'er', 'es', 'et'}:
1462
        word = word[:-2]
1463
    elif _r1[-1:] == 'e':
1464
        word = word[:-1]
1465
    elif _r1[-1:] == 's':
1466
        if len(word) > 1 and word[-2] in _s_endings:
1467
            word = word[:-1]
1468
1469
    # Step 2
1470
    if word[r1_start:][-2:] in {'gd', 'dt', 'gt', 'kt'}:
@@ 1383-1401 (lines=19) @@
1380
1381
    # Step 1
1382
    _r1 = word[r1_start:]
1383
    if _r1[-7:] == 'heterna':
1384
        word = word[:-7]
1385
    elif _r1[-6:] == 'hetens':
1386
        word = word[:-6]
1387
    elif _r1[-5:] in {'anden', 'heten', 'heter', 'arnas', 'ernas', 'ornas',
1388
                      'andes', 'arens', 'andet'}:
1389
        word = word[:-5]
1390
    elif _r1[-4:] in {'arna', 'erna', 'orna', 'ande', 'arne', 'aste', 'aren',
1391
                      'ades', 'erns'}:
1392
        word = word[:-4]
1393
    elif _r1[-3:] in {'ade', 'are', 'ern', 'ens', 'het', 'ast'}:
1394
        word = word[:-3]
1395
    elif _r1[-2:] in {'ad', 'en', 'ar', 'er', 'or', 'as', 'es', 'at'}:
1396
        word = word[:-2]
1397
    elif _r1[-1:] in {'a', 'e'}:
1398
        word = word[:-1]
1399
    elif _r1[-1:] == 's':
1400
        if len(word) > 1 and word[-2] in _s_endings:
1401
            word = word[:-1]
1402
1403
    # Step 2
1404
    if word[r1_start:][-2:] in {'dd', 'gd', 'nn', 'dt', 'gt', 'kt', 'tt'}: