@ -23,16 +23,62 @@ from paddle.fluid.backward import calc_gradient
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					class  TestCalcGradient ( unittest . TestCase ) : class  TestCalcGradient ( unittest . TestCase ) :  
			
		
	
		
		
			
				
					
					    def  test_calc_gradient ( self ) : 
    def  test_calc_gradient ( self ) : 
 
			
		
	
		
		
			
				
					
					        x  =  layers . create_parameter ( dtype = " float32 " ,  shape = [ 5 ,  10 ] ) 
        main  =  fluid . Program ( ) 
 
			
				
				
			
		
	
		
		
			
				
					
					        y  =  layers . create_parameter ( dtype = " float32 " ,  shape = [ 10 ,  8 ] ) 
        startup  =  fluid . Program ( ) 
 
			
				
				
			
		
	
		
		
			
				
					
					        mul_out  =  layers . mul ( x = x ,  y = y ) 
        with  fluid . program_guard ( main ,  startup ) : 
 
			
				
				
			
		
	
		
		
			
				
					
					        mean_out  =  layers . mean ( mul_out ) 
            x  =  layers . create_parameter ( dtype = " float32 " ,  shape = [ 5 ,  10 ] ) 
 
			
				
				
			
		
	
		
		
			
				
					
					        a  =  calc_gradient ( mean_out ,  mul_out ) 
            y  =  layers . create_parameter ( dtype = " float32 " ,  shape = [ 10 ,  8 ] ) 
 
			
				
				
			
		
	
		
		
			
				
					
					        b  =  calc_gradient ( mean_out ,  x ) 
            mul_out  =  layers . mul ( x = x ,  y = y ) 
 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					            mean_out  =  layers . mean ( mul_out ) 
 
			
		
	
		
		
			
				
					
					            a  =  calc_gradient ( mean_out ,  mul_out ) 
 
			
		
	
		
		
			
				
					
					            b  =  calc_gradient ( mean_out ,  x ) 
 
			
		
	
		
		
			
				
					
					        place  =  fluid . CPUPlace ( ) 
        place  =  fluid . CPUPlace ( ) 
 
			
		
	
		
		
			
				
					
					        exe  =  fluid . Executor ( place ) 
        exe  =  fluid . Executor ( place ) 
 
			
		
	
		
		
			
				
					
					        exe . run ( fluid . default_startup_program ( ) ) 
        exe . run ( startup ) 
 
			
				
				
			
		
	
		
		
			
				
					
					        exe . run ( fluid . default_main_program ( ) ,  feed = { } ,  fetch_list = [ a ,  b ] ) 
        exe . run ( main ,  feed = { } ,  fetch_list = [ a ,  b ] ) 
 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					class  TestDoubleGrad ( unittest . TestCase ) :  
			
		
	
		
		
			
				
					
					    def  test1 ( self ) : 
 
			
		
	
		
		
			
				
					
					        main  =  fluid . Program ( ) 
 
			
		
	
		
		
			
				
					
					        startup  =  fluid . Program ( ) 
 
			
		
	
		
		
			
				
					
					        with  fluid . program_guard ( main ,  startup ) : 
 
			
		
	
		
		
			
				
					
					            net  =  lambda  x :  x  *  x 
 
			
		
	
		
		
			
				
					
					            x  =  fluid . layers . create_parameter ( 
 
			
		
	
		
		
			
				
					
					                name = ' x ' , 
 
			
		
	
		
		
			
				
					
					                shape = [ 1 ] , 
 
			
		
	
		
		
			
				
					
					                dtype = ' float32 ' , 
 
			
		
	
		
		
			
				
					
					                default_initializer = fluid . initializer . Constant ( 3 ) ) 
 
			
		
	
		
		
			
				
					
					            grad1 ,  =  fluid . gradients ( net ( x ) ,  x )   # 2x = 6 
 
			
		
	
		
		
			
				
					
					            z  =  net ( x  -  grad1 ) 
 
			
		
	
		
		
			
				
					
					            grad2 ,  =  fluid . gradients ( z ,  x )   # gradients( (x - 2x)^2) = 2x = 6 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					        place  =  fluid . CPUPlace ( ) 
 
			
		
	
		
		
			
				
					
					        exe  =  fluid . Executor ( place ) 
 
			
		
	
		
		
			
				
					
					        exe . run ( startup ) 
 
			
		
	
		
		
			
				
					
					        out  =  exe . run ( main ,  fetch_list = [ grad1 . name ,  grad2 . name ] ) 
 
			
		
	
		
		
			
				
					
					        self . assertEqual ( 6 ,  out [ 0 ] [ 0 ] ) 
 
			
		
	
		
		
			
				
					
					        self . assertEqual ( 6 ,  out [ 1 ] [ 0 ] ) 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    def  test2 ( self ) : 
 
			
		
	
		
		
			
				
					
					        main  =  fluid . Program ( ) 
 
			
		
	
		
		
			
				
					
					        startup  =  fluid . Program ( ) 
 
			
		
	
		
		
			
				
					
					        with  fluid . program_guard ( main ,  startup ) : 
 
			
		
	
		
		
			
				
					
					            x  =  fluid . layers . create_parameter ( 
 
			
		
	
		
		
			
				
					
					                name = ' x ' , 
 
			
		
	
		
		
			
				
					
					                shape = [ 1 ] , 
 
			
		
	
		
		
			
				
					
					                dtype = ' float32 ' , 
 
			
		
	
		
		
			
				
					
					                default_initializer = fluid . initializer . Constant ( 1 ) ) 
 
			
		
	
		
		
			
				
					
					            y  =  x  *  x 
 
			
		
	
		
		
			
				
					
					            dx1 ,  =  fluid . gradients ( y ,  x ) 
 
			
		
	
		
		
			
				
					
					            z  =  dx1  *  dx1  +  y  *  y 
 
			
		
	
		
		
			
				
					
					            dx2 ,  =  fluid . gradients ( z ,  x ) 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					        place  =  fluid . CPUPlace ( ) 
 
			
		
	
		
		
			
				
					
					        exe  =  fluid . Executor ( place ) 
 
			
		
	
		
		
			
				
					
					        exe . run ( startup ) 
 
			
		
	
		
		
			
				
					
					        out ,  =  exe . run ( main ,  fetch_list = [ dx2 ] ) 
 
			
		
	
		
		
			
				
					
					        self . assertEqual ( 12 ,  out [ 0 ] ) 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					if  __name__  ==  " __main__ " : if  __name__  ==  " __main__ " :