***
si on doit regarder les effets de deux [[variable indépendante|variables indépendantes]] ou + on va réaliser un plan factoriel
cela permet de regarder les effet direct des variables mais aussi leurs effets lorsqu'elles sont ensemble
mais le coût pour récolter ces [[donnée|données]] augmente de fou car il faut des groupes témoins à chaque fois
« **factor** » dans un plan factoriel, les variables indépendantes sont appelées des facteurs
« **level** » dans un plan factoriel, les sous-division des facteurs (variable indépendante) sont appelées des niveaux
« **main effect** » effet principal = effet qui se retrouve chez un facteur et à tous les niveaux des autres facteurs. En gros ça permet de s'assurer qu'UNE variable indépendante produit bien tel effet
« **interaction effect** » dépend du niveau du facteur secondaire donc c'est un effet d'interaction
il se produit seulement lorsque plusieurs variables sont alignées
## Notes de bas de page
```dataviewjs
// === DONNÉES ===
const page = dv.current();
const file = page.file;
const outlinks = file.outlinks.length;
const inlinks = file.inlinks.length;
const qualite = Math.max(0, Math.min(100, page["qualité"] ?? 0));
// === CALCUL PROGRESSION (0–100) ===
const max_links = 30;
const s_out = Math.min(outlinks / max_links, 1) * 40;
const s_in = Math.min(inlinks / max_links, 1) * 30;
const s_qual = qualite * 0.3;
const total = Math.round(s_out + s_in + s_qual);
// === ICÔNES ===
const iconEmoji =
total <= 25 ? "🌱" :
total <= 50 ? "🌿" :
total <= 75 ? "🌳" :
"🦚";
const iconLabel =
total <= 25 ? "🌱 Graine" :
total <= 50 ? "🌿 Jeune pousse" :
total <= 75 ? "🌳 Arbre mature" :
"🦚 Forêt";
// === MISE À JOUR YAML SANS CRÉER DE NOUVELLES CLÉS ===
const tfile = app.workspace.getActiveFile();
const cache = app.metadataCache.getFileCache(tfile);
// 1. Si pas de frontmatter → on ne touche à rien
if (cache?.frontmatter) {
await app.fileManager.processFrontMatter(tfile, fm => {
// 2. On met à jour seulement si la propriété existe déjà
if (Object.prototype.hasOwnProperty.call(fm, "progression")) {
fm.progression = total;
}
if (Object.prototype.hasOwnProperty.call(fm, "icon")) {
fm.icon = iconEmoji;
}
});
}
// === AFFICHAGE ===
dv.table(
["Liens sortants", "Liens entrants", "Qualité", "Progression"],
[[outlinks, inlinks, `${qualite}/100`, `${iconLabel} — ${total}/100`]]
);
```