AKTIVE

Artifact [e05900c5a3]
Login

Artifact [e05900c5a3]

Artifact e05900c5a3d3743a6f31aff0ab30cb38ed9b9f3a9dabf834f9595f3b02fdb895:


## -*- mode: tcl ; fill-column: 90 -*-
# # ## ### ##### ######## ############# #####################
## Transformers -- Structural changes (data re-arrangements)

# # ## ### ##### ######## ############# #####################
## Generic warping by means of an origin map and a pixel interpolator.

operator {description spec refs} {
    op::warp::bicubic         bicubic		  bicubic {
	http://en.wikipedia.org/wiki/Bicubic_interpolation
	http://www.paulinternet.nl/?page=bicubic
    }
    op::warp::bilinear	      bilinear	  	  bilinear {
	 https://en.wikipedia.org/wiki/Bilinear_interpolation
    }
    op::warp::lanczos	     {order-3 lanczos}    lanczos {
	https://mazzo.li/posts/lanczos.html
	https://en.wikipedia.org/wiki/Lanczos_resampling
	https://github.com/jeffboody/Lanczos
    }
    op::warp::near-neighbour {nearest neighbour}  nneighbour {
	https://en.wikipedia.org/wiki/Nearest-neighbor_interpolation
    }
} {
    op -> _ _ interpolation

    foreach r $refs { ref $r }

    section transform structure warp

    note Returns an image generated by the application of the \
	origin map to the image, with $description interpolation.

    note The result has the domain of the origin map, \
	and the depth of the image.

    note See "<!xref: aktive transform affine>" and its relatives \
	for a set of operations creating origin maps acceptable here.

    input origins	Origin map to wrap the `src` by.
    input src		Image to warp by the `origin`.

    # blit over first input (origins) only.
    # fetch from the second is input dependent, not a scan.
    # bands are not scanned. this is done by the interpolator.
    blit warp {
	{AH {y AY 1 up} {y 0 1 up}}
	{AW {x AX 1 up} {x 0 1 up}}
    } {raw interpolated-fetch {
	aktive_region_fetch_interpolated (srcs->v[1],
					  spec,
					  idomain->depth,
					  srcvalue,
					  dstvalue);
    }}

    state -setup {
	// The domain and location are unchanged, taken from the origin map.
	// The depth becomes the depth of the image.
	aktive_geometry* og = aktive_image_get_geometry (srcs->v[0]);
	aktive_geometry* ig = aktive_image_get_geometry (srcs->v[1]);

	aktive_geometry_copy (domain, og);
	domain->depth = ig->depth;
    }
    pixels {
	aktive_interpolator* spec = aktive_interpolator_@@spec@@ ();

	aktive_rectangle_def_as (subrequest, request);
	TRACE_RECTANGLE_M("fetch", &subrequest);

	// fetch from the map
	aktive_block* src = aktive_region_fetch_area (srcs->v[0], &subrequest);

	// fetch from the input is done through the interpolator,
	// for the declared origin points.

	@@warp@@
    }
}

##
# # ## ### ##### ######## ############# #####################
::return