# Shader: rendinst_simple / simple_aces
## Overview
A basic shader used for objects that require a texture along with a normals,
metalness, and smoothness map. It supports alpha test and
[microdetails](../../about-assets/microdetails/microdetails.md).
```{note}
Technically, this is the *rendinst_simple* shader. However, it may be referred
as "simple_aces" on old assets, but the game interprets both as *rendinst_
simple*.
```
## Textures
The shader uses the first UV channel for mapping.
- **tex0:** – Diffuse albedo map
- **tex2:** – Texture combining normals, metalness, and smoothness:
- **RG** – Normal map
- **B** – Metalness
- **Alpha** – Smoothness
## Parameters
The shader is configured using the following parameters:
- **"2 sided" checkbox** ("two_sided" in [*Asset
Viewer*](../../../dagor-tools/asset-viewer/asset-viewer/asset_viewer.md)) –
The original, outdated method for double-sided geometry. It works imperfectly
with shadows and is slightly more expensive with small triangle counts, but
performs well and is cost-effective for large triangle counts. Currently, it's
only used for trees and not for environment assets (though older assets may
still have it, as this was the only option previously).
- **"2 sided real" checkbox** ("real_two_sided" in [*Asset
Viewer*](../../../dagor-tools/asset-viewer/asset-viewer/asset_viewer.md)) –
The second method for double-sided geometry. It duplicates and flips the
geometry where the material is applied (one triangle becomes two). This method
works correctly with shadows but doubles the number of triangles to which the
material is applied.
```{important}
Avoid overusing this parameter or duplicating existing materials just to apply
it to parts of an asset. If a texture set is used and part of the geometry
needs to be double-sided while another part remains single-sided, it's more
efficient to create a single material for the entire model with this texture
set and handle the double-sided geometry by flipping it directly in the LODs.
This approach is cheaper than using two nearly identical materials and
provides the same visual result.
```
- **atest** – Alpha channel cutoff threshold. A switch for transparency based on
the diffuse's alpha channel. The mask is compressed to a single bit: anything
darker than `127` becomes transparent, and the rest is opaque.
```{note}
Although the **atest** parameter defaults to `127`, it functions as a Boolean
switch. If the value is greater than `0`, transparency is enabled; otherwise,
it's not used. The threshold cannot be adjusted.
A smooth gradient from black to white will be cut off at the same point,
regardless of whether **atest** is set to `1`, `255`, or `1000`.
```
- **use_painting** – Controls painting from the palette defined in the shader
variables of the scene.
- `1`: Enable painting
- `0`: Disable painting
- Values between `0.(0)1` and `0.(9)`: Apply partial painting (acts as a
multiplier). Painting is applied based on the diffuse alpha channel
multiplied by the **use_painting** value. Values from `1.(0)1` to `1.(9)`
also influence the strength of the paint from `0.0` to `1.0` but disable the
random pixel selection from the painting stripe when the object is offset in
height. This ensures consistency in colors, for instance, when painting
modular skyscrapers the same color. The palette used is named
`paint_colors.dds` and is located here:
`/develop/assets/textures/colorize_textures`.
```{seealso}
For more information, see [Procedural Rendinst
Painting](../../about-assets/procedural-rendinst-painting/procedural_rendinst_painting.md).
```
- **painting_line** – The painting stripe (from `0` to the last stripe in the
texture).
- **micro_detail_layer** – The index of the microdetail layer (from `0` to
`11`).
```{seealso}
For more information, see [Microdetails on
Assets](../../about-assets/microdetails/microdetails.md).
```
- **micro_detail_layer_v_scale** – Vertical scale of the microdetail.
- **micro_detail_layer_uv_scale** – UV scale of the microdetail texture. The
larger the value, the smaller the detail pattern will appear (range: `0` -
infinity).