#ifndef CUDA_RASTERIZER_BACKWARD_H_INCLUDED
#define CUDA_RASTERIZER_BACKWARD_H_INCLUDED

#include <cuda.h>
#include "cuda_runtime.h"
#include "device_launch_parameters.h"
#define GLM_FORCE_CUDA
#include <glm/glm.hpp>

namespace BACKWARD
{
	void render(
		const dim3 grid, dim3 block,
		const uint2* ranges,
		const uint32_t* point_list,
		int W, int H,
		float fx, float fy,
		const float* bg_color,
		const float2* means2D,
		const float4* conic_opacity,
		const float* ref_to_src_list,
		const float* src_cam_pos,
		const float* src_images,
		cudaTextureObject_t texColor,
		const float* src_rendered_depths,
		cudaTextureObject_t texDepth,
		const int nb_src_images, 
		const float* colors,
		const float* all_maps,
const float* normal_map_pixels,
		const float* intersected_depth_pixels,
		const float* warped_image_pixels,
		const float* final_Ts,
		const uint32_t* n_contrib,
		float* buffer_cache_sum_median_weight,
		uint32_t* buffer_cache_low_median_contributor,
		uint32_t* buffer_cache_high_median_contributor,
		int* valid_src_indices,
		float* valid_src_sum_median_weight, 
		const float* dL_dpixels,
		const float* dL_dout_normal_map,
		const float* dL_dout_median_intersected_depth,
		const float* dL_dout_warped_image,
		float3* dL_dmean2D,
		float3* dL_dmean2D_abs,
		float4* dL_dconic2D,
		float* dL_dopacity,
		float* dL_dcolors,
		float* dL_dall_map,
		const bool render_geo);

	void preprocess(
		int P, int D, int M,
		const float3* means,
		const int* radii,
		const float* shs,
		const bool* clamped,
		const glm::vec3* scales,
		const glm::vec4* rotations,
		const float scale_modifier,
		const float* cov3Ds,
		const float* view,
		const float* proj,
		const float focal_x, float focal_y,
		const float tan_fovx, float tan_fovy,
		const glm::vec3* campos,
		const float3* dL_dmean2D,
		const float* dL_dconics,
		glm::vec3* dL_dmeans,
		float* dL_dcolor,
		float* dL_dcov3D,
		float* dL_dsh,
		glm::vec3* dL_dscale,
		glm::vec4* dL_drot);
}

#endif
