# For Loop

## Overview

![The For Loop Node.](https://3009747178-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2F-MIspkFTPkuGkv4UgQGs-1330240639%2Fuploads%2Fgit-blob-1289374e97e736eb8d793e78286832a0c4cb4d60%2Fforloop.png?alt=media)

The **For Loop Node** triggers an iterative process that steps through the provided **Int** inputs. The output can then, for example, be printed to the **Console** or affect the next **Node** in the **Logic Branch**.

## Attributes

| Attribute                | Type     | Description                                                                |
| ------------------------ | -------- | -------------------------------------------------------------------------- |
| `First Index`            | **Int**  | The starting index.                                                        |
| `Last Index`             | **Int**  | The stopping index.                                                        |
| `Step`                   | **Int**  | The amount to increase or decrease by.                                     |
| `Is Last Index Included` | **Bool** | Notes whether the last index is included or excluded during the iteration. |

## Inputs

| Input             | Type      | Description                                                           |
| ----------------- | --------- | --------------------------------------------------------------------- |
| *Pulse Input* (►) | **Pulse** | A standard **Input Pulse**, to trigger the execution of the **Node**. |
| `First Index`     | **Int**   | The starting index.                                                   |
| `Last Index`      | **Int**   | The stopping index.                                                   |
| `Step`            | **Int**   | The amount to increase or decrease by.                                |

## Outputs

| Output             | Type      | Description                                                                                                                            |
| ------------------ | --------- | -------------------------------------------------------------------------------------------------------------------------------------- |
| *Pulse Output* (►) | **Pulse** | A standard **Output Pulse**, to move onto the next **Node** along the **Logic Branch**, once this **Node** has finished its execution. |
| `Index`            | **Int**   | The output index.                                                                                                                      |
| `OnEnd`(►)         | **Pulse** | A **Pulse** that flows to an action, such as a **Console** message, once the **For Loop** has ended.                                   |

## See Also

* [**For Each Loop**](https://docs.incari.com/incari-studio/2021.1/toolbox/flow-control/foreachloop)

## External Links

* [*For loop explanation*](https://en.wikipedia.org/wiki/For_loop) on Wikipedia.
