Coverage for pySDC/projects/GPU/heat.py: 0%

6 statements  

« prev     ^ index     » next       coverage.py v7.6.1, created at 2024-09-20 17:10 +0000

1from pySDC.implementations.problem_classes.HeatEquation_ND_FD import heatNd_forced as heat_cpu 

2from pySDC.implementations.problem_classes.HeatEquation_ND_FD_CuPy import heatNd_forced as heat_gpu 

3from pySDC.core.collocation import CollBase as Collocation 

4from pySDC.implementations.sweeper_classes.imex_1st_order import imex_1st_order 

5from pySDC.implementations.controller_classes.controller_nonMPI import controller_nonMPI 

6from pySDC.helpers.stats_helper import filter_stats, sort_stats 

7 

8 

9def set_parameter(): # pragma: no cover 

10 # initialize problem parameters 

11 problem_params = dict() 

12 problem_params['nu'] = 1 

13 problem_params['freq'] = (4, 4, 4) 

14 problem_params['order'] = 2 

15 problem_params['lintol'] = 1e-10 

16 problem_params['liniter'] = 99 

17 problem_params['solver_type'] = 'CG' 

18 problem_params['nvars'] = (32, 32, 32) 

19 problem_params['bc'] = 'periodic' 

20 

21 # initialize level parameters 

22 level_params = dict() 

23 level_params['restol'] = 1e-07 

24 level_params['dt'] = 1e-07 

25 level_params['nsweeps'] = 1 

26 

27 # initialize sweeper parameters 

28 sweeper_params = dict() 

29 sweeper_params['collocation_class'] = Collocation 

30 sweeper_params['node_type'] = 'LEGENDRE' 

31 sweeper_params['quad_type'] = 'RADAU-RIGHT' 

32 sweeper_params['QI'] = ['LU'] 

33 sweeper_params['QE'] = ['PIC'] 

34 sweeper_params['num_nodes'] = 3 

35 sweeper_params['initial_guess'] = 'spread' 

36 

37 # initialize step parameters 

38 step_params = dict() 

39 step_params['maxiter'] = 50 

40 

41 # setup parameters "in time" 

42 t0 = 0 

43 schritte = 8 

44 Tend = schritte * level_params['dt'] 

45 

46 # initialize controller parameters 

47 controller_params = dict() 

48 controller_params['logger_level'] = 30 

49 

50 # fill description dictionary for easy step instantiation cpu 

51 description = dict() 

52 description['problem_params'] = problem_params # pass problem parameters 

53 description['sweeper_class'] = imex_1st_order # pass sweeper 

54 description['sweeper_params'] = sweeper_params # pass sweeper parameters 

55 description['level_params'] = level_params # pass level parameters 

56 description['step_params'] = step_params # pass step parameters 

57 

58 return controller_params, description, t0, Tend 

59 

60 

61def main(): # pragma: no cover 

62 controller_params, description, t0, Tend = set_parameter() 

63 

64 # fill description dictionary with CPU problem 

65 description['problem_class'] = heat_cpu 

66 

67 # instantiate controller cpu 

68 controller = controller_nonMPI(num_procs=1, controller_params=controller_params, description=description) 

69 

70 # get initial values on finest level cpu 

71 P = controller.MS[0].levels[0].prob 

72 uinit = P.u_exact(t0) 

73 

74 # call main function to get things done on cpu... 

75 uend_cpu, stats_cpu = controller.run(u0=uinit, t0=t0, Tend=Tend) 

76 timing_cpu = sort_stats(filter_stats(stats_cpu, type='timing_run'), sortby='time') 

77 print('Runtime CPU:', timing_cpu[0][1]) 

78 

79 # change description dictionary for GPU problem 

80 description['problem_class'] = heat_gpu 

81 

82 # instantiate controller cpu 

83 controller = controller_nonMPI(num_procs=1, controller_params=controller_params, description=description) 

84 

85 # get initial values on finest level cpu 

86 P = controller.MS[0].levels[0].prob 

87 uinit = P.u_exact(t0) 

88 

89 # call main function to get things done on cpu... 

90 uend_gpu, stats_gpu = controller.run(u0=uinit, t0=t0, Tend=Tend) 

91 timing_gpu = sort_stats(filter_stats(stats_gpu, type='timing_run'), sortby='time') 

92 print('Runtime GPU:', timing_gpu[0][1]) 

93 

94 assert abs(uend_gpu.get() - uend_cpu) < 1e-13, abs(uend_gpu.get() - uend_cpu) 

95 

96 

97if __name__ == '__main__': 

98 main()