All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.tartarus.snowball.ext.NorwegianStemmer Maven / Gradle / Ivy

The newest version!
// Generated by Snowball 2.2.0 - https://snowballstem.org/

package org.tartarus.snowball.ext;

import org.tartarus.snowball.Among;

/**
 * This class implements the stemming algorithm defined by a snowball script.
 *
 * 

Generated by Snowball 2.2.0 - https://snowballstem.org/ */ @SuppressWarnings("unused") public class NorwegianStemmer extends org.tartarus.snowball.SnowballStemmer { private static final long serialVersionUID = 1L; private static final Among a_0[] = { new Among("a", -1, 1), new Among("e", -1, 1), new Among("ede", 1, 1), new Among("ande", 1, 1), new Among("ende", 1, 1), new Among("ane", 1, 1), new Among("ene", 1, 1), new Among("hetene", 6, 1), new Among("erte", 1, 3), new Among("en", -1, 1), new Among("heten", 9, 1), new Among("ar", -1, 1), new Among("er", -1, 1), new Among("heter", 12, 1), new Among("s", -1, 2), new Among("as", 14, 1), new Among("es", 14, 1), new Among("edes", 16, 1), new Among("endes", 16, 1), new Among("enes", 16, 1), new Among("hetenes", 19, 1), new Among("ens", 14, 1), new Among("hetens", 21, 1), new Among("ers", 14, 1), new Among("ets", 14, 1), new Among("et", -1, 1), new Among("het", 25, 1), new Among("ert", -1, 3), new Among("ast", -1, 1) }; private static final Among a_1[] = {new Among("dt", -1, -1), new Among("vt", -1, -1)}; private static final Among a_2[] = { new Among("leg", -1, 1), new Among("eleg", 0, 1), new Among("ig", -1, 1), new Among("eig", 2, 1), new Among("lig", 2, 1), new Among("elig", 4, 1), new Among("els", -1, 1), new Among("lov", -1, 1), new Among("elov", 7, 1), new Among("slov", 7, 1), new Among("hetslov", 9, 1) }; private static final char g_v[] = {17, 65, 16, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 48, 0, 128}; private static final char g_s_ending[] = {119, 125, 149, 1}; private int I_x; private int I_p1; private boolean r_mark_regions() { I_p1 = limit; int v_1 = cursor; { int c = cursor + 3; if (c > limit) { return false; } cursor = c; } I_x = cursor; cursor = v_1; golab0: while (true) { int v_2 = cursor; lab1: { if (!(in_grouping(g_v, 97, 248))) { break lab1; } cursor = v_2; break golab0; } cursor = v_2; if (cursor >= limit) { return false; } cursor++; } golab2: while (true) { lab3: { if (!(out_grouping(g_v, 97, 248))) { break lab3; } break golab2; } if (cursor >= limit) { return false; } cursor++; } I_p1 = cursor; lab4: { if (I_p1 >= I_x) { break lab4; } I_p1 = I_x; } return true; } private boolean r_main_suffix() { int among_var; if (cursor < I_p1) { return false; } int v_2 = limit_backward; limit_backward = I_p1; ket = cursor; among_var = find_among_b(a_0); if (among_var == 0) { limit_backward = v_2; return false; } bra = cursor; limit_backward = v_2; switch (among_var) { case 1: slice_del(); break; case 2: lab0: { int v_3 = limit - cursor; lab1: { if (!(in_grouping_b(g_s_ending, 98, 122))) { break lab1; } break lab0; } cursor = limit - v_3; if (!(eq_s_b("k"))) { return false; } if (!(out_grouping_b(g_v, 97, 248))) { return false; } } slice_del(); break; case 3: slice_from("er"); break; } return true; } private boolean r_consonant_pair() { int v_1 = limit - cursor; if (cursor < I_p1) { return false; } int v_3 = limit_backward; limit_backward = I_p1; ket = cursor; if (find_among_b(a_1) == 0) { limit_backward = v_3; return false; } bra = cursor; limit_backward = v_3; cursor = limit - v_1; if (cursor <= limit_backward) { return false; } cursor--; bra = cursor; slice_del(); return true; } private boolean r_other_suffix() { if (cursor < I_p1) { return false; } int v_2 = limit_backward; limit_backward = I_p1; ket = cursor; if (find_among_b(a_2) == 0) { limit_backward = v_2; return false; } bra = cursor; limit_backward = v_2; slice_del(); return true; } @Override public boolean stem() { int v_1 = cursor; r_mark_regions(); cursor = v_1; limit_backward = cursor; cursor = limit; int v_2 = limit - cursor; r_main_suffix(); cursor = limit - v_2; int v_3 = limit - cursor; r_consonant_pair(); cursor = limit - v_3; int v_4 = limit - cursor; r_other_suffix(); cursor = limit - v_4; cursor = limit_backward; return true; } @Override public boolean equals(Object o) { return o instanceof NorwegianStemmer; } @Override public int hashCode() { return NorwegianStemmer.class.getName().hashCode(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy