*** 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`]] ); ```