Hi Yvan,
Thanks for your feedback. I've made some revisions to the heat sink term code. Please find the latest version attached. The code works but the results are wrong. 
I use the following two lines (line 30-31) to get the temperature at the current time step and the previous time step. 
    const cs_real_t *cvar_temp = CS_F_(t)->val;
    const cs_real_t *cvara_temp = CS_F_(t)->val_pre;
And I use lines 64-68 to get the sum of the parallel ranks:
   if (cs_glob_rank_id >= 0) {
    	cs_parall_sum(1, CS_REAL_TYPE, &total_volume);
    	cs_parall_sum(1, CS_REAL_TYPE, &total_enthalpy);
        cs_parall_sum(1, CS_REAL_TYPE, &total_enthalpy_prev);
    }
However, I'm encountering incorrect output results. When I print the values of total_enthalpy (current time step), total_enthalpy_prev (previous time step), and feedback_term (heat sink term) at each iteration, the results are not as expected. The feedback_term consistently equal to 0, and total_enthalpy remains equal to total_enthalpy_prev. I have attached the run_solver.log file for your review.
If I exclude lines 64-68, which are for parallel sum computation, all three variables (total_enthalpy, total_enthalpy_prev, and feedback_term) output as 0.  (For the actual simulation, I use 2048 processors).
I use code_saturne v7.0. And I haven't find any errors in my code currently. It would be very appreciate if you could provide some insights or suggestions when you are available based on the wrong outputs.
Best regards,
Ximeng
			
							streamwise periodicity
					Forum rules
Please read the forum usage recommendations before posting.
	Please read the forum usage recommendations before posting.
Re: streamwise periodicity
- Attachments
- 
			
		
		
				- run_solver.log
- (2.78 MiB) Downloaded 10854 times
 
- 
			
		
		
				- cs_user_sink_term_revised3.c
- (3.85 KiB) Downloaded 10679 times
 
- 
				Yvan Fournier
- Posts: 4271
- Joined: Mon Feb 20, 2012 3:25 pm
Re: streamwise periodicity
Hello,
If you exclude the parallel sum, the values you print are those of MPI rank 0. So if none of the cells assigned to rank 0 (depending on the automatic partitioning) are in the selected region, it is normal to have 0.
When you add the parallel sums, do you obtain expected values at least for the total volume ?
There could be an issue with the selection if the mesh is shifted/not at the expected coordinates.
Otherwise, is the enthalpy or temperature > 0 ? If not, the test line 73 will avoid the feedback term computation.
And are you solving with enthalpy or temperature ? If you are solving for temperature, you may want to rename references to enthalpy. If you are solving for Enthalpy, then temperature is a property, not asolved variable, so source terms should apply to enthalpy instead.
Regards,
Yvan
			
			
									
									
						If you exclude the parallel sum, the values you print are those of MPI rank 0. So if none of the cells assigned to rank 0 (depending on the automatic partitioning) are in the selected region, it is normal to have 0.
When you add the parallel sums, do you obtain expected values at least for the total volume ?
There could be an issue with the selection if the mesh is shifted/not at the expected coordinates.
Otherwise, is the enthalpy or temperature > 0 ? If not, the test line 73 will avoid the feedback term computation.
And are you solving with enthalpy or temperature ? If you are solving for temperature, you may want to rename references to enthalpy. If you are solving for Enthalpy, then temperature is a property, not asolved variable, so source terms should apply to enthalpy instead.
Regards,
Yvan
Re: streamwise periodicity
Hi Yvan,
Thanks for your prompt feedback!
When I add the parallel sums, I obtain expected values for the total volume as shown in the run_solver.log.
"feedback_term: 0.000000e+00 total_enthalpy: 1.529331e+02 total_enthalpy_prev: 1.529331e+02 total_volume: 5.237434e-01"
The total volume 5.237434e-01 is right, corresponding to my selected area volume (1*0.75*0.7=0.525).
The total enthalpy is 1.529331e+02 (> 0), approximately 0.525*292K (the total volume*the reference air temperature). It seems to be reasonable but it doesn't change. It just keep the same value with time step increasing, and equal to the previous time step total enthalpy.
For the final point, I think I solve for the temperature since I choose Thermal model-Thermal scalar-Temperature(Kelvin) as shown in the picture and setup.xml. And What you mean "If you are solving for temperature, you may want to rename references to enthalpy." I think in my code, I use temperature* volume to get the enthalpy, and then use feedback_term=delta_enthalpy/total_volume to get the feedback_term. So the feedback_term is acctually for temperature. It should be right I think. Is this what you mean? Thanks!
Best regards,
Ximeng
			
							Thanks for your prompt feedback!
When I add the parallel sums, I obtain expected values for the total volume as shown in the run_solver.log.
"feedback_term: 0.000000e+00 total_enthalpy: 1.529331e+02 total_enthalpy_prev: 1.529331e+02 total_volume: 5.237434e-01"
The total volume 5.237434e-01 is right, corresponding to my selected area volume (1*0.75*0.7=0.525).
The total enthalpy is 1.529331e+02 (> 0), approximately 0.525*292K (the total volume*the reference air temperature). It seems to be reasonable but it doesn't change. It just keep the same value with time step increasing, and equal to the previous time step total enthalpy.
For the final point, I think I solve for the temperature since I choose Thermal model-Thermal scalar-Temperature(Kelvin) as shown in the picture and setup.xml. And What you mean "If you are solving for temperature, you may want to rename references to enthalpy." I think in my code, I use temperature* volume to get the enthalpy, and then use feedback_term=delta_enthalpy/total_volume to get the feedback_term. So the feedback_term is acctually for temperature. It should be right I think. Is this what you mean? Thanks!
Best regards,
Ximeng
- Attachments
- 
			
		
		
				- setup_Ri-0.19_XYperiodic_symmTop.xml
- (170.92 KiB) Downloaded 10739 times
 
- 
			
		
		
				- run_solver (2).log
- (3.14 MiB) Downloaded 10913 times
 
- 
				Yvan Fournier
- Posts: 4271
- Joined: Mon Feb 20, 2012 3:25 pm
Re: streamwise periodicity
Hello,
Yes, you seem to be using the standard temperature resolution.
Do not forget that for enthalpy, you also need to multiply by density and CP. If this is missing your sink term might simply be too small ?
What are the other factors (boundary and initial conditions) influencing enthalpy here ?
Best regards,
Yvan
			
			
									
									
						Yes, you seem to be using the standard temperature resolution.
Do not forget that for enthalpy, you also need to multiply by density and CP. If this is missing your sink term might simply be too small ?
What are the other factors (boundary and initial conditions) influencing enthalpy here ?
Best regards,
Yvan
Re: streamwise periodicity
Hi Yvan,
Thanks for your reply.
One point is that It might not related to the code now. The delta enthalpy might be actually really small (might be 0) between two consecutive time steps (since the temperature condition is just two different constant values for ground and air, no heat emission). So I plan to calculate the delta enthalpy between maybe 10 time steps or 100 time steps. So now the problem is that I just know that we could get the field in the last time step use "const cs_real_t *cvara_temp = CS_F_(t)->val_pre;". But how can we get the field in last 10 or 100 time step? Could you provide any examples or guidance on this matter? Thanks!
Best regards,
Ximeng
			
			
									
									
						Thanks for your reply.
One point is that It might not related to the code now. The delta enthalpy might be actually really small (might be 0) between two consecutive time steps (since the temperature condition is just two different constant values for ground and air, no heat emission). So I plan to calculate the delta enthalpy between maybe 10 time steps or 100 time steps. So now the problem is that I just know that we could get the field in the last time step use "const cs_real_t *cvara_temp = CS_F_(t)->val_pre;". But how can we get the field in last 10 or 100 time step? Could you provide any examples or guidance on this matter? Thanks!
Best regards,
Ximeng
Re: streamwise periodicity
Hi Yvan,
Sorry for the bothering. But there are something wrong in my last post. I have confirmed that the actual delta enthalpy is not 0 between two consecutive time steps. The following are two consecutive time steps outputs in the run_solver.log:
time step 1: feedback_term: 0.000000 total_enthalpy: 211.720959 total_enthalpy_prev: 211.720959 total_volume: 0.725000
time step 2: feedback_term: 0.000000 total_enthalpy: 211.720987 total_enthalpy_prev: 211.720987 total_volume: 0.725000
It is obvious that 211.720959 is not equal to 211.720987, but the extracted total enthalpy equal to the total_enthalpy_pre through the cs_user_sink_term.c code. Therefore, the problem is that the code didn't get the correct previous time step temperature through " const cs_real_t *cvara_temp = CS_F_(t)->val_pre;" (it returns the same value as the current time step temperature). The val_pre is based on the general documentation: https://www.code-saturne.org/documentat ... 75076f0a29
Are there any examples available for retrieving field variables(such as temperature or others) from the last or previous several time steps?
Best regards,
Ximeng
			
							Sorry for the bothering. But there are something wrong in my last post. I have confirmed that the actual delta enthalpy is not 0 between two consecutive time steps. The following are two consecutive time steps outputs in the run_solver.log:
time step 1: feedback_term: 0.000000 total_enthalpy: 211.720959 total_enthalpy_prev: 211.720959 total_volume: 0.725000
time step 2: feedback_term: 0.000000 total_enthalpy: 211.720987 total_enthalpy_prev: 211.720987 total_volume: 0.725000
It is obvious that 211.720959 is not equal to 211.720987, but the extracted total enthalpy equal to the total_enthalpy_pre through the cs_user_sink_term.c code. Therefore, the problem is that the code didn't get the correct previous time step temperature through " const cs_real_t *cvara_temp = CS_F_(t)->val_pre;" (it returns the same value as the current time step temperature). The val_pre is based on the general documentation: https://www.code-saturne.org/documentat ... 75076f0a29
Are there any examples available for retrieving field variables(such as temperature or others) from the last or previous several time steps?
Best regards,
Ximeng
- Attachments
- 
			
		
		
				- run_solver.log
- (3.79 MiB) Downloaded 10931 times
 
- 
				Yvan Fournier
- Posts: 4271
- Joined: Mon Feb 20, 2012 3:25 pm
Re: streamwise periodicity
Hello,
There are some user examples in.the documentation but they may not be sufficient.
When.the code starts a new time step, the current value is copied into val_pre and the new value is computed.
What I suspect is happening in your case is that when the source term user-defined function is called, since we are in the process of computing the new temperature value, val_pre has already been overwritten but the new value not yet updated, so they are identical..
There are 2 possible workarounds for this:
- Add a user postprocessing field in the GUI, and in cs_user_extra_operations, copy the previous temperature value to that field'val array the use that val array instead of the température's val_pre.
- In cs_user_parameters, call cs_field_set_n_time_vals to assign 3 time values instead of 2 for the temperature. In your test you can the use temperature->vals[2][cell_id] instead of temperature->val_pre[cell_id].
Answering this post from my phone, so sorry if there are typos and less detail..
Best regards,
Yvan
			
			
									
									
						There are some user examples in.the documentation but they may not be sufficient.
When.the code starts a new time step, the current value is copied into val_pre and the new value is computed.
What I suspect is happening in your case is that when the source term user-defined function is called, since we are in the process of computing the new temperature value, val_pre has already been overwritten but the new value not yet updated, so they are identical..
There are 2 possible workarounds for this:
- Add a user postprocessing field in the GUI, and in cs_user_extra_operations, copy the previous temperature value to that field'val array the use that val array instead of the température's val_pre.
- In cs_user_parameters, call cs_field_set_n_time_vals to assign 3 time values instead of 2 for the temperature. In your test you can the use temperature->vals[2][cell_id] instead of temperature->val_pre[cell_id].
Answering this post from my phone, so sorry if there are typos and less detail..
Best regards,
Yvan
Re: streamwise periodicity
Hi Yvan,
Thanks for your suggestions. The code worked at the time, but for my new case, I’d like to take a more theoretical approach. Specifically, I aim to derive an analytical solution for the source term, based on Page 213 of
Franck Mastrippolito's thesis. (https://theses.fr/2018LYSEC043?domaine=theses).
I’ve also attached my code, but the simulation keeps crashing. The details are in the file 'Problem about the heat source term.pdf'. Could you please take a look and let me know if you have any insights on how to resolve this issue? I’d really appreciate it.
Best regards,
			
							Thanks for your suggestions. The code worked at the time, but for my new case, I’d like to take a more theoretical approach. Specifically, I aim to derive an analytical solution for the source term, based on Page 213 of
Franck Mastrippolito's thesis. (https://theses.fr/2018LYSEC043?domaine=theses).
I’ve also attached my code, but the simulation keeps crashing. The details are in the file 'Problem about the heat source term.pdf'. Could you please take a look and let me know if you have any insights on how to resolve this issue? I’d really appreciate it.
Best regards,
- Attachments
- 
			
		
		
				- Problem about the heat source term.pdf
- (757.7 KiB) Downloaded 10431 times
 
- 
			
		
		
				- run_solver.log
- (55.27 KiB) Downloaded 10281 times
 
- 
			
		
		
				- cs_user_heatsourceterm_0305.c
- (5.65 KiB) Downloaded 10324 times
 
- 
				Yvan Fournier
- Posts: 4271
- Joined: Mon Feb 20, 2012 3:25 pm
Re: streamwise periodicity
Hello,
It seems your source terms leads to temperature increasing very rapidly, and then velocity increasing very fast probably as a consequence.
You might try adding the source term progresively, so as to avoid a high energy input that is not convected. I also recommend visualizing the source term to make sure you have the expected values. Be careful (check examples) to see which terms should be multiplied by the cell volume (I did not check this in your code).
Also, it may be interesting to check the effect of increasing or decreasing the time step. The automatic computation using a Fourier criterion can produce too small the steps due to an inadapted turbulent diffusivity in zones with near zero velocity, so if that is active, you may want to change the settings (again, I did not fully check your setup yet, just looked at the main log).
Best regards
Yvan
			
			
									
									
						It seems your source terms leads to temperature increasing very rapidly, and then velocity increasing very fast probably as a consequence.
You might try adding the source term progresively, so as to avoid a high energy input that is not convected. I also recommend visualizing the source term to make sure you have the expected values. Be careful (check examples) to see which terms should be multiplied by the cell volume (I did not check this in your code).
Also, it may be interesting to check the effect of increasing or decreasing the time step. The automatic computation using a Fourier criterion can produce too small the steps due to an inadapted turbulent diffusivity in zones with near zero velocity, so if that is active, you may want to change the settings (again, I did not fully check your setup yet, just looked at the main log).
Best regards
Yvan
Re: streamwise periodicity
Hi Yvan,
Thank you for your suggestions. Applying a relaxation factor to progressively add the source term seems to help, but I still observe a slow temperature increase throughout the domain.
Since the previous implementation used a non-conservative form—which can introduce numerical bias—I’d like to switch to a conservative formulation, as suggested in the reference:
crvexp(1, iel) = −divmass(ṁ·cp·a_T·x)
I’m wondering how this expression can be implemented in C. Could you advise on how to reproduce the effect of divmass in a .c file?
Best regards,
Ximeng
			
			
									
									
						Thank you for your suggestions. Applying a relaxation factor to progressively add the source term seems to help, but I still observe a slow temperature increase throughout the domain.
Since the previous implementation used a non-conservative form—which can introduce numerical bias—I’d like to switch to a conservative formulation, as suggested in the reference:
crvexp(1, iel) = −divmass(ṁ·cp·a_T·x)
I’m wondering how this expression can be implemented in C. Could you advise on how to reproduce the effect of divmass in a .c file?
Best regards,
Ximeng