Share your thoughts, 1 month free Claude Pro on usSee more
WorkDL logo mark

Distinguishing Cause from Effect with Causal Velocity Models

About

Bivariate structural causal models (SCM) are often used to infer causal direction by examining their goodness-of-fit under restricted model classes. In this paper, we describe a parametrization of bivariate SCMs in terms of a causal velocity by viewing the cause variable as time in a dynamical system. The velocity implicitly defines counterfactual curves via the solution of initial value problems where the observation specifies the initial condition. Using tools from measure transport, we obtain a unique correspondence between SCMs and the score function of the generated distribution via its causal velocity. Based on this, we derive an objective function that directly regresses the velocity against the score function, the latter of which can be estimated non-parametrically from observational data. We use this to develop a method for bivariate causal discovery that extends beyond known model classes such as additive or location scale noise, and that requires no assumptions on the noise distributions. When the score is estimated well, the objective is also useful for detecting model non-identifiability and misspecification. We present positive results in simulation and benchmark experiments where many existing methods fail, and perform ablation studies to examine the method's sensitivity to accurate score estimation.

Johnny Xi, Hugh Dance, Peter Orbanz, Benjamin Bloem-Reddy• 2025

Related benchmarks

TaskDatasetResultRank
Bivariate Causal DiscoveryPER
Accuracy100
33
Bivariate Causal DiscoveryQd-V
Accuracy91
33
Bivariate Causal DiscoveryNN-V
Accuracy87
33
Bivariate Causal DiscoveryD4 s1
Accuracy67
33
Bivariate Causal DiscoveryAN
Accuracy100
33
Bivariate Causal DiscoveryLS
Accuracy98
33
Bivariate Causal DiscoveryTue
Accuracy64
33
Bivariate Causal DiscoverySIM-c
Accuracy72
33
Bivariate Causal DiscoverySIM
Accuracy63
33
Bivariate Causal DiscoveryNet
Accuracy62
33
Showing 10 of 25 rows

Other info

Follow for update