skills/tabular/multi-output-auxiliary-targets/SKILL.md
Neural network with multiple output heads for main target plus auxiliary targets, improving representation learning via shared layers.
npx skillsauth add wenmin-wu/ds-skills tabular-multi-output-auxiliary-targetsInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Add extra output heads to a neural network that predict related auxiliary targets alongside the main target. The shared hidden layers learn richer representations because they must encode information useful for multiple tasks. Weight auxiliary losses lower than the main loss to keep focus on the primary objective.
import tensorflow as tf
from tensorflow.keras.layers import Input, Dense, BatchNormalization, Dropout
from tensorflow.keras.models import Model
from sklearn.preprocessing import StandardScaler
def build_multi_output_model(n_features, aux_dims=[2, 6, 12]):
inp = Input(shape=(n_features,))
x = Dense(512, activation='relu')(inp)
x = BatchNormalization()(x)
x = Dropout(0.3)(x)
x = Dense(256, activation='relu')(x)
x = BatchNormalization()(x)
x = Dropout(0.2)(x)
# Main target
main_out = Dense(1, activation='linear', name='main')(x)
# Auxiliary outputs
aux_outs = []
for i, dim in enumerate(aux_dims):
aux = Dense(dim, activation='linear', name=f'aux_{i}')(x)
aux_outs.append(aux)
model = Model(inputs=inp, outputs=[main_out] + aux_outs)
# Weight auxiliary losses lower
losses = {'main': 'mse'}
loss_weights = {'main': 1.0}
for i in range(len(aux_dims)):
losses[f'aux_{i}'] = 'mse'
loss_weights[f'aux_{i}'] = 0.1
model.compile(optimizer='adam', loss=losses, loss_weights=loss_weights)
return model
data-ai
Scaled Pinball Loss (SPL) metric for evaluating quantile forecasts, normalized by mean absolute successive differences of training data
data-ai
Walk backward through a time series and multiplicatively rescale segments when jumps exceed a fraction of the running mean to correct data collection anomalies
testing
Transform forecasting target to next/current ratio minus one so that optimizing MAE or squared error implicitly minimizes SMAPE
tools
Convert point forecasts to prediction intervals by scaling with logit-transformed quantile ratios passed through a Normal CDF