Sha256: ed809a9e5c42690dd5c7938d39a69876012e6a2e1f626e27d654cb165e931749
Contents?: true
Size: 1.25 KB
Versions: 1
Compression:
Stored size: 1.25 KB
Contents
<% (is_float ? ["_ignan","_prnan"] : [""]).each do |j| %> static void <%=c_iter%><%=j%>(na_loop_t *const lp) { size_t n; char *ptr; ssize_t step; INIT_COUNTER(lp, n); INIT_PTR(lp, 0, ptr, step); <%=type_name%>_qsort<%=j%>(ptr, n, step); } <% end %> /* <%=name%> of self. <% if is_float %> @overload <%=name%>(axis:nil, nan:false) @param [TrueClass] nan If true, propagete NaN. If false, ignore NaN. <% else %> @overload <%=name%>(axis:nil) <% end %> @param [Numeric,Array,Range] axis Affected dimensions. @return [Numo::<%=class_name%>] returns result of <%=name%>. @example Numo::DFloat[3,4,1,2].sort => Numo::DFloat[1,2,3,4] */ static VALUE <%=c_func(-1)%>(int argc, VALUE *argv, VALUE self) { int nan = 0; VALUE reduce; ndfunc_arg_in_t ain[2] = {{OVERWRITE,0},{sym_reduce,0}}; ndfunc_t ndf = {0, STRIDE_LOOP|NDF_FLAT_REDUCE, 2,0, ain,0}; if (!TEST_INPLACE(self)) { self = na_copy(self); } reduce = na_reduce_dimension(argc, argv, 1, &self, &nan); // v[0] = self <% if is_float %> if (nan) { ndf.func = <%=c_iter%>_prnan; } else { ndf.func = <%=c_iter%>_ignan; } <% else %> ndf.func = <%=c_iter%>; <% end %> na_ndloop(&ndf, 2, self, reduce); return self; }
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
numo-narray-0.9.0.5 | ext/numo/narray/gen/tmpl/sort.c |