error in stemming code

1 回表示 (過去 30 日間)
prabi p
prabi p 2016 年 4 月 18 日
回答済み: Walter Roberson 2016 年 4 月 23 日
>> find_stems Error using cellfun Non-scalar in Uniform output, at index 1, output 1. Set 'UniformOutput' to false.
Error in find_stems (line 3) results = cellfun(@porterdupe, t); ---------------------------------------------------------------------
code: find_stems.m function results = find_stems() t = simple(); results = cellfun(porterdupe, t);
--------------------------------------------- code: porterdupe.m
function [stem] = porterdupe(y) t = y; global j; b = t; k = length(b); k0 = 1; j = k; % With this if statement, strings of length 1 or 2 don't go through the % stemming process. Remove this conditional to match the published % algorithm. %stem = simple(b);
if k > 2 % Output displays per step are commented out. %disp(sprintf('Word to stem: %s', b));
x = step1ab(b, k, k0);
%disp(sprintf('Steps 1A and B yield: %s', x{1}));
x = step1c(x{1}, x{2}, k0);
%disp(sprintf('Step 1C yields: %s', x{1}));
x = step2(x{1}, x{2}, k0);
%disp(sprintf('Step 2 yields: %s', x{1}));
x = step3(x{1}, x{2}, k0);
%disp(sprintf('Step 3 yields: %s', x{1}));
x = step4(x{1}, x{2}, k0);
%disp(sprintf('Step 4 yields: %s', x{1}));
x = step5(x{1}, x{2}, k0);
%disp(sprintf('Step 5 yields: %s', x{1}));
stem = x{1};
end end
% cons(j) is TRUE = b[j] is a consonant.
function c = cons(i, b, k0) c = true; switch(b(i)) case {'a', 'e', 'i', 'o', 'u'} c = false; case 'y' if i == k0 c = true; else c = ~cons(i - 1, b, k0); end end end

回答 (1 件)

Walter Roberson
Walter Roberson 2016 年 4 月 23 日
cellfun(@porterdupe, t, 'uniform', 0);

カテゴリ

Help Center および File ExchangePerformance and Memory についてさらに検索

タグ

製品

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by