Comments (4)
Can we define a generalization of the bijectors used for lower bounded, upper bounded and both? Would a coupling flow be useful here?
Yeah, so that's one approach that came up at some point where we basically define a TrunactedBijector
which just reimplements the link
and invlink
for these distributions. You could do something like
# Could also implement this for the case of `Bijector{1}`
struct TruncatedBijector{T} <: Bijector{0}
lb::T
ub::T
end
function (b::TruncatedBijector)(x::Real)
a, b = b.lb, b.ub
lowerbounded, upperbounded = isfinite(a), isfinite(b)
if lowerbounded && upperbounded
return StatsFuns.logit((x - a) / (b - a))
elseif lowerbounded
return log(x - a)
elseif upperbounded
return log(b - x)
else
return x
end
end
function (ib::Inversed{<:TruncatedBijector})(y::Real)
a, b = ib.orig.lb, ib.orig.ub
lowerbounded, upperbounded = isfinite(a), isfinite(b)
if lowerbounded && upperbounded
return (b - a) * StatsFuns.logistic(y) + a
elseif lowerbounded
return exp(y) + a
elseif upperbounded
return b - exp(y)
else
return y
end
end
function logabsdetjac(b::TruncatedBijector, x::Real)
a, b = b.lb, b.ub
lowerbounded, upperbounded = isfinite(a), isfinite(b)
if lowerbounded && upperbounded
return - log((x - a) * (b - x) / (b - a))
elseif lowerbounded
return - log(x - a)
elseif upperbounded
return - log(b - x)
else
return zero(x)
end
end
from bijectors.jl.
I just want to point out that this has been solved for all cases except Truncated
for which runtime information is required to be able to determine which transformation is necessary. This was done in PR #39.
from bijectors.jl.
Can we define a generalization of the bijectors used for lower bounded, upper bounded and both? Would a coupling flow be useful here?
from bijectors.jl.
Closed by #52
from bijectors.jl.
Related Issues (20)
- filldist, up1 not defined HOT 6
- Adding bijectors for OrderStatistic and JointOrderStatistics HOT 1
- Add API function to retrieve size of bijector output from bijector input HOT 1
- rational quadratic flows not supporting Float32 input HOT 1
- What to do with `CorrBijector` ? HOT 1
- Improve `PDVecBijector`
- Matrix factorization bijectors HOT 4
- Domain Error for VecCholeskyBijector bijector when calling logabsdetjac HOT 4
- Question on simplex bijector implementation HOT 9
- Can't apply Bijectors.ordered to TDist() and MvTDist() HOT 1
- Incorrect bijector for heterogeneous Product distribution HOT 3
- Radial flow to a simplex HOT 5
- Stackoverflow in custom bijector HOT 2
- Missing implementation of `Bijectors.bijector` for `arraydist` distributions. HOT 1
- Bijectors.ordered and MvLogNormal interaction .. only supported for unconstrained distributions. HOT 1
- `TruncatedBijectors` not defined in `Distributions` extension
- support ProductDistribution HOT 3
- Fixes to correlation bijectors
- Improve `with_logabsdet_jacobian` performance for `SimplexBijector` HOT 1
- Tests are failing for `VecCorrBijector` in _very_ rare scenarios
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from bijectors.jl.