data:image/s3,"s3://crabby-images/de85a/de85a4fc9d3771b84e7bf51456d7bfefa053c939" alt=""
Back to Lecture Thumbnails
data:image/s3,"s3://crabby-images/5c6fc/5c6fc780117d498e35507951d1e565f96f0be41d" alt=""
martigp
data:image/s3,"s3://crabby-images/ba507/ba507dd448bcb53b3b6dcb3f57571b31b672799f" alt=""
awu
@martigp Just speculating here, but perhaps that has to do with the fact that we need +/-1 entries for computation in both x and y? In blurx(x,y) we take x-1 & x+1, while in out(x,y) we take y-1 & y+1.
data:image/s3,"s3://crabby-images/b53fb/b53fbee984d23e705c674c67505015a52a7024ce" alt=""
evs
@martigp Since were moving along in groups of three the pixels at the border will still need the two other pixels to perform the blur.
data:image/s3,"s3://crabby-images/3ee8b/3ee8b9cd80edff3e24ad27445923604a0c38c1df" alt=""
apappu
It's interesting to me that from a client perspective Halide allows a range of specifications for those who understand/have an idea of what a more efficient implementation may be and those who don't, since the programmer can specify details of the blur at varying levels of granularity
Please log in to leave a comment.
Copyright 2021 Stanford University
This is a bit of a semantics question, but why does the compute.at generated double loop iterate over +2 on the y and x coordinate. Surely it would only have to do so on the y coordinate for the second inner loop to work correctly.