- 23,708
- 5,922
No. The k correlation.casualguitar said:But yes, what did you mean by 'our mass transfer parameterization' if not this equation: ##M_i'' = \frac{k_i(Py_i - P(T_I))}{RT}##
No. The k correlation.casualguitar said:But yes, what did you mean by 'our mass transfer parameterization' if not this equation: ##M_i'' = \frac{k_i(Py_i - P(T_I))}{RT}##
Uncertain about the units for ##k_i## and ##D_{ab}## (mass diffusion coefficient) -Chestermiller said:No. The k correlation.
You keep flip-flopping between k having units of m/s and having units of moles/m^2.sec. If you are using m/s, leave out the ##\rho_m\ (=\frac{P}{RT_I})## in the above equation. Otherwise, keep it. I also think there should be a factor of ##(1-\epsilon)## in the above equation. Your equation for molar flux seems to use k is in m/s. Is that your understanding?casualguitar said:Uncertain about the units for ##k_i## and ##D_{ab}## (mass diffusion coefficient) -
So the correlation I've currently got for ##k_i## is:
$$k_i = (2.19Re^{1/3} + 0.78Re^{0.619})Sc^{1/3}D_{ab}\rho_m/d_p$$
You need to get the units issue resolved.casualguitar said:The the units of ##D_{ab}## are ##m^2/s## from the correlation above. BSL provides these ##D_{ab}## values in ##m^2/s## also. The units of ##k_i## are therefore ##mol/m^2.s## then. There is probably some unit issue here somewhere because the molar deposition rate is also mol/m2.s. Can the units of ##k_i## be the same as the units of ##M_i''##?
That is my understanding yes. I had some issues getting the non constant ##k_i## model to converge however it does converge now. The output below is for n=5. Adding in non constant ##k_i## seems to increase the runtime of the model by quite a bit for some reason. So I'll run n=30 in a bit (currently on the way home) and see how long it takes. Anyway here's the n=5 output:Chestermiller said:You keep flip-flopping between k having units of m/s and having units of moles/m^2.sec. If you are using m/s, leave out the ##\rho_m\ (=\frac{P}{RT_I})## in the above equation. Otherwise, keep it. I also think there should be a factor of ##(1-\epsilon)## in the above equation. Your equation for molar flux seems to use k is in m/s. Is that your understanding?
You need to get the units issue resolved.
n = 10 with non-constant ##k_i##:casualguitar said:That is my understanding yes. I had some issues getting the non constant ##k_i## model to converge however it does converge now. The output below is for n=5. Adding in non constant ##k_i## seems to increase the runtime of the model by quite a bit for some reason. So I'll run n=30 in a bit (currently on the way home) and see how long it takes. Anyway here's the n=5 output:
View attachment 312935
View attachment 312936
I don't like how the MCO2 plot looks (the peaks should increase in size over time), so I'll look into that. But yes first I'll run n=30
What implicit integrator are you using? What is the structure of the Jacobian matrix, and do you take advantage of this in the matrix inversion chosen option>casualguitar said:n = 10 with non-constant ##k_i##:View attachment 312987
View attachment 312988
No such luck getting n=30 to converge. It seems to get stuck around 180K. I'm not sure what extra difficulty would be caused be n=30 that is not present in n=10 besides maybe some convergence issues. Looking into it. I'm leaving the simulation running just on the off chance it does actually converge after long times
The LSODA integrator (from the solve_ivp package). I have seen mentions of the Jacobian matrix in the documentation so I'll take a look at thisChestermiller said:What implicit integrator are you using? What is the structure of the Jacobian matrix, and do you take advantage of this in the matrix inversion chosen option>
Hi Chet, I looked into the Jacobian matrix question and if I understand the question the structure of the Jacobian matrix is just a rectangle of shape [n,6], where n is the number of spatial positions and 6 is the number of ODEs we have. Does this answer the question?casualguitar said:The LSODA integrator (from the solve_ivp package). I have seen mentions of the Jacobian matrix in the documentation so I'll take a look at this
Hi Chet,Chestermiller said:What implicit integrator are you using? What is the structure of the Jacobian matrix, and do you take advantage of this in the matrix inversion chosen option>
This looks like a major improvement. Is the only difference the equation used to calculate the Re? It doesn't seem possible.casualguitar said:Hi Chet,
As mentioned, here is the model output for the new Reynolds Number formulation:
We're now getting a clear constant temperature zone around the sublimation point of CO2, similar to the Tuinier model:
View attachment 313411
The mass buildup looks odd here in that the maximum buildup amount at a position seems to be constant, and also the value (approx 100) is about double the Tuinier value. Looking into this
View attachment 313412
Yep you're right its not possible. I was mistakenly using the inlet molar flow to calculate the non-boundary position Reynolds Numbers. In switching to your new Re formulation I noticed that mistakeChestermiller said:This looks like a major improvement. Is the only difference the equation used to calculate the Re? It doesn't seem possible.
No. See their Fig. 3.casualguitar said:Yep you're right its not possible. I was mistakenly using the inlet molar flow to calculate the non-boundary position Reynolds Numbers. In switching to your new Re formulation I noticed that mistake
The CO2 mass buildup trend is correct in that the plug of CO2 increases in 'width' over time. Is that actually an issue that it seems to stay at a constant 100kg/m3?
That is the equation for ##a_s##, the particle surface per unit volume of column. ##A_s## is the particle surface per tank. $$A_s=A_c\Delta z a_s=\frac{6}{d_p}(1-\epsilon)A_c\Delta z$$casualguitar said:In checking the area values I've got one point of confusion. What is the difference between ##A_s## and ##a_s##? ##A_s## seems to be the particle surface area per unit volume: $$A_s = \frac{6}{d_p}(1-\epsilon)$$
Correct.casualguitar said:In regards to where each are used, it seems that ##A_s## will be used everywhere here, so we don't seem to have a need for ##a_s##?
Ah whoops yes I agree with the above, and I am using the correct ##A_s## value. Typo by me. Ok then its possibly time to add in the last few small bits (non constant heat capacity, non constant viscosity, etc)? I have the functions written for all of those. I don't think it will change the output much though. A reasonable next (final?) step?Chestermiller said:No. See their Fig. 3.
That is the equation for ##a_s##, the particle surface per unit volume of column. ##A_s## is the particle surface per tank. $$A_s=A_c\Delta z a_s=\frac{6}{d_p}(1-\epsilon)A_c\Delta z$$
GreatChestermiller said:Correct.
You need to again confirm that the overall CO2 mass balance is satisfied. I'm also wondering why we get a peak of 100, and they get a peak of 60. Try 15 tanks to see whether the added axial dispersion spreads the deposited CO2 out over a broader region.casualguitar said:Ah whoops yes I agree with the above, and I am using the correct ##A_s## value. Typo by me. Ok then its possibly time to add in the last few small bits (non constant heat capacity, non constant viscosity, etc)? I have the functions written for all of those. I don't think it will change the output much though. A reasonable next (final?) step?
Great
EDIT: Oh and I'll make that change you mentioned about including the mass flow rate derivative as an integrated variable
So now that the model is effectively ready to be used (you might disagree with that), I think it would be useful to run a number of simulations to show how some performance parameters vary with initial and boundary conditions (ICs/BCs), such as separation efficiency or CO2 captured per unit of refrigeration. Do you think it is worthwhile to do this kind of 'factorial analysis'?
Seems to fail at around 330K. There isn't any phase change happening around there so I'm not sure why that happens. Looking into itChestermiller said:Try 15 tanks to see whether the added axial dispersion spreads the deposited CO2 out over a broader region.
Hi Chet! I've returned to the CO2 model and was hoping to discuss it with someone. You're the person that I've had the most discussion with on this so I was hoping I could continue this for a short while if thats ok with you! The simulation has progressed since our last discussion but there are some parts that I am unsure about. I just have some questions I'd like to discuss with someone. If this is ok with you, I can bring you up to speed on thisChestermiller said:15 tanks should run more easily than 30 tanks. Sounds like a variable dimensioning/storage issue.
I'll do my best to answer your questions, but my memory of this work is fading.casualguitar said:Hi Chet! I've returned to the CO2 model and was hoping to discuss it with someone. You're the person that I've had the most discussion with on this so I was hoping I could continue this for a short while if thats ok with you! The simulation has progressed since our last discussion but there are some parts that I am unsure about. I just have some questions I'd like to discuss with someone. If this is ok with you, I can bring you up to speed on this
 
			
		
		 
			
		
		 
			
		
		 
			
		
		 
			
		
		 
			
		
		 
			
		
		 
			
		
		 
			
		
		 
			
		
		What do the results look like if you run the model with the mass transfer coefficient set to zero?casualguitar said:The output looks like this -
The output looks like this, for n = 200:
View attachment 326119
View attachment 326120
View attachment 326121
I wanted to incude this last plot showing every position (all 200) and how they behave over time. Clearly the CO2 mole fraction output isnt right. The other plots dont actually look too bad though.
View attachment 326116
In regards to the position vs temperature plots higher up, there doesnt seem to be any constant temperature zone which is present in Tuinier et al.
I apologise for the information dump but yes I would just like to open up dialogue here again as I found it hugely beneficial last time to have someone to have a back and forth with.
Is the above information sufficient or should I provide further info on this?
EDIT: One point I forgot to mention - in the gas/bed temperature vs position plots, I have printed time values. You can see that the temperature profile acually stops changing after a while and this is before the entirety of the bed has reached the inlet gas temperature
Hi Chet, setting ki_CO2 = 0 and letting n=200 results in these plots:Chestermiller said:What do the results look like if you run the model with the mass transfer coefficient set to zero?
Why does the CO2 mole fraction rise so rapidly? What is the gas residence time in the bed?casualguitar said:Hi Chet, setting ki_CO2 = 0 and letting n=200 results in these plots:
View attachment 326147
View attachment 326148
View attachment 326149
View attachment 326150
The co2 mole fraction rises to 0.2 which is the inlet mole fraction, so this looks ok. There is no CO2 buildup on the bed as expected. The temperature profiles also generally look ok although there is no constant temeprature zone.
For reference, the h_desublimation_CO2 is set to 26,000 J/mol currently. Just now I tried setting it to 0 and 200,000, neither of which changed the temperature profiles appreciably
I think due to the high flow. The inlet total molar flow for that plot was 0.002mol/s.Chestermiller said:Why does the CO2 mole fraction rise so rapidly? What is the gas residence time in the bed?
No it doesn't allow for it. Right now the value can go below zero and does. Originally I had a conditional statement in the integrator that said "if the amount of CO2 in the bed goes below zero, set it to zero". Then I moved this statement to post-processing, so now I'm just plotting the CO2 deposition values that are above zero, but the solution from the integrator does contain negative values. Are either of these approaches ok, or should we somehow allow for it directly in the mass balance equation?Chestermiller said:There's something wrong with how the release of the CO2 from the bed is handled. If there is a driving force for removal but there is no CO2 left on the bed, the flow of CO2 from the bed to the gas has to be zero. That means that the mass balance equation for the CO2 in the gas has to allow for this. Is it?
Yes. Here is the output when this is imposed:Chestermiller said:Is ##A_s## the bed surface area (m^2) per tank and ##M_I## the moles of CO2 deposited per tank? If so, pleases try to impose the following: If ##M_i<0.1 A_s## and ##M_{i}^"\leq 0##, reset ##M_i^"## to zero. This applies to the realistic flow rates.
Where ##A_s =A_c\Delta z a_s=\frac{6}{d_p}(1-\epsilon)A_c\Delta z = 0.0032m^2##, the molar flow is 0.002mol/s and k_i = 5 * 10 ** -4 mol/m2.s:##M_i<0.1 A_s## and ##M_{i}^"\leq 0##, reset ##M_i^"## to zero
Yes. Do you think 0.1 is too large. Why didn't you run the calculation for a realistic molar flow rate?casualguitar said:Yes. Here is the output when this is imposed:
Where ##A_s =A_c\Delta z a_s=\frac{6}{d_p}(1-\epsilon)A_c\Delta z = 0.0032m^2##, the molar flow is 0.002mol/s and k_i = 5 * 10 ** -4 mol/m2.s:
View attachment 326285
View attachment 326286
View attachment 326287
View attachment 326289
View attachment 326290
Is the reason for the ##0.1A_s## constraint so that we dont run into any case where ##M_i## <0? In a case where ##M_i''## is large this may occur
No I think 0.1 is ok. Ah I was using a molar flow rate that fit the mass transfer coefficient. These two values affect the output quite a lot so if I change the molar flow I also need to adjust the mass transfer coefficient to get reasonable looking output.Chestermiller said:Yes. Do you think 0.1 is too large. Why didn't you run the calculation for a realistic molar flow rate?
What are your thoughts on whether the new plots were closer to your expectations?
I think there should be an ##\epsilon## in the term of Eqn.1 and no ##\epsilon## in the term of Eqn.4. That assumes that Ac is the cross sectional area of the empty column.casualguitar said:Hi Chet,
Unfortunately the molar flow error didnt fix the output, although it did change it somewhat.
The molar flow out of a tank should have been defined as the below. It was previously this so I must have changed it somewhere along the way:
\begin{equation}
\dot{m}_j = \dot{m}_{j-1} + \frac{\rho_m \Delta z A_c}{T_g}\frac{dT}{dt} - (M_{CO_2}''*A_s)
\end{equation}
Further up in the code ##m_j## is defined as:
\begin{equation}
m_j = \frac{P}{RT_g}\epsilon A_C\Delta z
\end{equation}
So I now have:
\begin{equation}
\dot{m}_j = \dot{m}_{j-1} + \frac{\rho_m \Delta z A_c}{T_g}\frac{dT}{dt} - (M_{CO_2}''*A_s)
\end{equation}
which I've implemented as:
\begin{equation}
\dot{m}_j = \dot{m}_{j-1} + \frac{m_j \epsilon}{T_g}\frac{dT}{dt} - (M_{CO_2}''*A_s)
\end{equation}
Just posting this here in case I've done anything crazy there
No. You should be using the actual curve, although there is melting at the triple point (along with a latent heat effect) and, above the triple point, you should more properly be using the liquid vapor pressure.casualguitar said:Hi Chet, looking further into the CO2 desublimation rate function, these are plots of temperature versus sublimation pressure (the gas-solid curve), and then temperature versus desublimation rate for a range of ##k_i## values, and ##y_{CO2}## = 0.2 (as it is in Tuinier et al).
Note that for the sublimation pressure curve, for temperature values above the triple point temperature (216K), i've used the liquid-vapour curve. Is there an alternative here? We could possibly say: if T is less than the triple point temperature, use the sublimation pressure curve, if T is greater than the triple point temeprature, let sublimation pressure = some large number?
View attachment 326637
casualguitar said:View attachment 326638
Edit: just noting the simulation breaks if I let psubco2 = 1000000 for T > triple point temerpature
What happened to evaporation of the deposits? I assume these values are in each tank?casualguitar said:My apologies for the long-winded posts (my head is a bit fried!). The first plot below is completely at odds with the second one is it not? These plots are from the same simulation
View attachment 326649
View attachment 326650
What the fudge factor does is prevent M from going negative. The amount of CO2 on the bed should always be positive.casualguitar said:Hi Chet,
Output is looking better now. Only issue really is that we're producing a lot more solid CO2. The profiles look ok though.
I reverted back to an older approach we had, where we used something like their "fudge factor". I also put in the previous correlation for ##k_{CO2}##.
The fudge factor looks like this and only applies for sublimation (not desublimation):
if ##P*y_{CO2}## < ##P_{sub,CO2}##:
##M_{CO2}''## = ##M_{CO2}''##*##(\frac{M_{CO2}}{M_{CO2}+0.1})##
Tuinier uses 0.1 as their fudge factor. I'm using 0.1 also currently. We previously also discussed converting this 0.1 to a value suitable for us (different units), like this:
factor = 0.1*1000*A_C*dz/mW_CO2
As we're now calculating ##k_{CO2}##, we can no longer use this as a tuning parameter, unless I'm wrong. I'm wondering if we can instead use this fudge factor to tune the amount of CO2 produced?
Here's the output from the above. Note the output is a bit rough looking because I have used n=15. The the simulation takes a lot longer to run now so I'll increase this again once we're happy with the output:
Gas temperature profile shows the constant temperature zone:
View attachment 326677
The amount of CO2 on the bed in kg/m3. Tuinier et al had values closer to 50kg/m3 for 50s and 150s:
View attachment 326678
Lastly, ##y_{CO2}## for each position. Each position does level out at 0.2 which is the inlet concentration. There is a bit of fluctuation but this is possibly down to the sublimation process (I'll check this):
View attachment 326679
If this looks ok to you, do you think it is reasonable to use the "factor" to tune the amount of CO2 on the bed to Tuinier et al?
EDIT: If I take out the fudge factor and run it, the output looks like it did before (incorrect). I didn't think the fudge factor would have such an impact!
If you're asking if the first plot there is for each tank then yes that's correctChestermiller said:What happened to evaporation of the deposits? I assume these values are in each tank?
##k_{CO2}## seems to be the main variable impacting the max amount of CO2 desposited on the bed. My thought is that maybe my ##K_{CO2}## calculation is incorrectChestermiller said:I'm concerned about those much higher depositions of CO2 per unit area than the comparison calculation.
casualguitar said:Hi Chet, my apologies for the late response. Here's the vapour-solid (sublimation) curve, where for temperatures above the triple point temperature I've used the vapour-liquid curve. At the triple point temperature, the vapour pressure is 5 bar. Standard scale and log scale:
Standard scale:
View attachment 326837
Log scale:
View attachment 326838If you're asking if the first plot there is for each tank then yes that's correct##k_{CO2}## seems to be the main variable impacting the max amount of CO2 desposited on the bed. My thought is that maybe my ##K_{CO2}## calculation is incorrect
Printing the Reynolds number and the ##K_{CO2}## numbers for the simulation, the Reynolds number seems to be pretty constant at around 2500. ##K_{CO2}## ranges from abour 0.2 to 0.3 which I think is in agreement with the plot below:
View attachment 326839
Here is the equation I'm using to calculate ##k_{CO2}##:
##k_{CO2}= (2.19Re^{1/3} + 0.78*Re^{0.619})*Sc^{1/3} * D_{CO2,N2}*(1-\epsilon)/d_p##
Where:
##Sc_{CO2} = \frac{\mu_{CO2}}{\rho_{CO2}*D_{CO2,N2}}##
Where ##\mu## is in ##Pa.s##, ##\rho## is ##\frac{kg}{m3}##, ##d_p## is in ##m##
and ##D_{CO2,N2}## = ##0.144*10^4## ##m^2/s##
The units clearly don't match up here. I know we previously had a molar density term in here. Let me go through this ##k_i## derivation from the start tomorrow
Thats correct. I checked the ##k_{CO2}## units and it seems to be fine. I also printed out all of the solution data to csv/excel to see if there was anything unusual happening in the data that isn't being plotted and there wasn't.Chestermiller said:Shouldn't the units of k be m/s?
Nevertheless when I put 0.7 into the model I get similar output to what they got (the max values are similar, the trends are similar, and the width of the CO2 plugs are similar)
Just in addition - in order to credibly use this model, I suppose I would need to add the ##H_2O## ODEs back in and tune the model with these included? Then remove them after tuningChestermiller said:Shouldn't the units of k be m/s?