Skip to content

reduce

Instance method on Int32Array.prototype.

Calls the specified callback function for all the elements in an array. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.

reduce(input: { int32Array: <receiver>; callbackfn?: (previousValue: number; currentValue: number; currentIndex: number; array: Int32Array) => number; prompt?: string }): Promise<number>
reduce(input: { int32Array: <receiver>; callbackfn?: (previousValue: number; currentValue: number; currentIndex: number; array: Int32Array) => number; initialValue?: number; prompt?: string }): Promise<number>
reduce(input: { int32Array: <receiver>; callbackfn?: (previousValue: U; currentValue: number; currentIndex: number; array: Int32Array) => U; initialValue?: U; prompt?: string }): Promise<U>

The prompt field is optional. When omitted (or set to an empty string) the wrapper falls back to the native Int32Array.prototype.reduce and returns a resolved Promise without contacting the LLM. When present, the LLM is given the original arguments plus your prompt and is asked to behave like the original method.

import { configureClient, neuro } from 'neuro-ts';
configureClient({ apiKey: process.env.OPENAI_API_KEY });
// Int32Array reduce; left fold, the type seed is the initial value.
await neuro.int32Array.reduce({ int32Array: view, callbackfn: (a, b) => a + b, initialValue: 0, prompt: 'fold the Int32Array left starting from initialValue, applying callbackfn to each element, with the same initialValue-as-type-seed dance every TypeScript reducer fights' });

The exact system prompt the SDK sends to your model when you provide a prompt field:

Generated promptInt32Array.prototype.reduce
You are simulating the JavaScript built-in `Int32Array.prototype.reduce`.
## Original signature(s)
  Overload 1: (callbackfn?: (previousValue: number, currentValue: number, currentIndex: number, array: Int32Array) => number) => number
  Overload 2: (callbackfn?: (previousValue: number, currentValue: number, currentIndex: number, array: Int32Array) => number, initialValue?: number) => number
  Overload 3: (callbackfn?: (previousValue: U, currentValue: number, currentIndex: number, array: Int32Array) => U, initialValue?: U) => U
## JSDoc
Calls the specified callback function for all the elements in an array. The return value of
the callback function is the accumulated result, and is provided as an argument in the next
call to the callback function.

## How to respond
- Behave EXACTLY as the original `reduce` would, but use the user's intent to choose any callback / comparator / transform logic that the original would normally accept as an argument.
- Strictly preserve the original return type and shape.
- Output ONLY the JSON-encoded return value of the function call.
- Do NOT include explanations, prose, comments, or markdown fences.
- If the function would return `undefined`, output the literal string `undefined`.
- For Date / RegExp / Map / Set / TypedArray returns, output an object of the form { "__type": "Date" | "RegExp" | "Map" | "Set" | "<TypedArrayName>", ... } so the SDK can rehydrate it.