Flocculator Design Solution
Be sure to run all imports before viewing the code
In this design challenge you will design a vertical flow hydraulic flocculator. You will use the flow rate of flow_plant = 20 L/s
as your default design value.
Although we don’t require that you use the nomenclature from the AguaClara variable naming guide, it provides a reasonable basis for organizing your variable names. We use the convention that the first part of the variable name describes the type of variable and always has a unique dimension. The subsequent parts of the variable name start from the big picture and slowly add more and more detail to arrive at the precise component that you are describing. Thus space_floc_baffle is the spacing between baffles in the flocculator and n_floc_channel_baffle should be the number of baffles in a flocculator channel. width_floc_channel_port should be the width of the port connecting two flocculator channels.
In this design challenge we will use functions to calculate each step of the design. Whenever we need to access a previously calculated result we will use the function call to access that value. Using this method of nested function calls will make the entire design be only a function of a few input parameters. This makes it possible to have flexible design code and ease the creation of new plant designs.
The minimum input parameters to define a flocculator are (flow_plant, headloss_floc_BOD, Gt_BOD, T_BOD). We could have included a longer list of input parameters (height_floc_end, width_PC_sheet, K_e, etc.) to make our functions even more general. But to keep our code more concise we will focus on only 4 of the input parameters. This will make it possible to easily change the input parameters to obtain new designs. We will use this capability to plot the results of varying the design flow rate.
Hydraulic Vertical flow flocculator Design
This challenge is design a hydraulic flocculator using the core concepts of the AguaClara design methodology.
Colab worksheet with the inputs for the design. BOD stands for Basis Of Design.
Design Algorithm Steps
Calculate the total volume of flocculator given head loss and collision potential
Calculate the number of channels by taking the total width and dividing by the maximum channel width
Calculate the channel width (total width over number of channels)
Calculate the minimum number of obstacles and spacing between obstacles by assuming a maximum H/S ratio
Use the actual H/S ratio based on obstacle spacing to calculate the spacing between baffles
Calculate the obstacle width to obtain the same jet expansion conditions as produced by the 180 degree bend.
This algorithm does not yet handle the integer number of baffles in a channel or the thickness of the baffles
For this assignment create functions for each question and then use those function calls whenever that calculation result is required in a subsequent step. Include flow_plant, headloss_floc_BOD, Gt_BOD and T_BOD as the inputs that can be varied for each function.
Whenever you reference a previously calculated value in a function, use the function call for that value so that dependency is not broken.
That way you will be able to easily vary any of the three main input parameters (flow, Gt, head loss) to see their effect on the design.
1) Estimate the average velocity gradient of a flocculator given head loss and collision potential. I’m going to solve this problem for you so you see how to use function calls.
See Colab worksheet with the flocculator design solution
The average velocity gradient of flocculator is 93.24 / second
2) Estimate the residence time of flocculator given the target head loss and collision potential. (Note that this ignores the decrease in water depth caused by head loss. We hope to improve this design process further in the near future.)
Colab worksheet residence time calculation
print (‘The residence time of flocculator is’, t_floc_est(headloss_floc_BOD, Gt_BOD, T_BOD))
The residence time of flocculator is 396.8 second
3) Plot :math:`Gtheta` as a function of the operating temperature given the head loss and residence time for this design. In this step you are assuming that you have built this hydraulic flocculator and you want to see how the collision potential, \(G\theta\), varies with temperature of operation. Vary the temperature from 0°C to 30°C. The following equation makes it clear that the velocity gradient originates from head loss that creates fluid deformation that is limited by viscosity.
See the code to generate the plot
4) The Equation (177) creates the link between \(\bar G \theta\) and flocculator performance. What does the floc model and Fig. 134 tell you about flocculator performance and flocculator design? Explain why performance varies with temperature. Explain how temperature influences collisions between particles. What temperature should be used to design flocculators?
Flocculator performance improves with warmer temperatures because the fluid deforms more given the same input energy. The fluid deforms more because it is less viscous at higher temperatures. Flocculators should be designed to perform well based on the coldest operating temperature that they will encounter.
5) Calculate the volume of flocculator. Note that this volume does not take into account the extra volume that flocculator will have due to the changing water level caused by the head loss. Simply estimate the volume based on the residence time and the flow rate.
The volume of flocculator is 7.936 meter ** 3
6) Calculate the actual length of the flocculator channels. This must meet two constraints. First, it must be less than or equal to the maximum channel length. Second, the channel length is limited by the flocculator volume, height, minimum number of channels, and minimum width of the channels. This second constraint is important for low flow rates so that the flocculator has the correct target volume. Make sure to use this floc channel length in subsequent calculations.
The maximum channel length is 3.719 meters.
7) Calculate the combined total width of the flocculator channels (not including walls) based on the given length and depth.
The total width of the flocculator channels is is 1.067 meters.
8) Calculate the minimum channel width required to achieve H/S>3. The channel can be wider than this, but this is the absolute minimum width for a channel. The minimum width occurs when there is only one expansion per baffle and thus the distance between expansions is the same as the depth of water at the end of the flocculator.
\({W_{min}} = \frac{{\Pi _{HS}}Q}{H_e}{\left( {\frac{K_e}{2{H_e}\nu {\bar G}^2}} \right)^{\frac{1}{3}}}\)
The minimum channel width is 11.64 centimeters.
9) What is the minimum channel width given the additional constraint that must be built by humans? Use the max function to find the true minimum channel width given both constraints.
Calculate the practical minimum width
The minimum channel width is 0.5335 meter.
10) Calculate the number of channels by taking the total flocculator width (see step 7) and dividing by the minimum channel width (round down). Include the requirement that the number of channels must be even (Use the numpy floor function - look it up!). To make this function robust, make sure that it can’t ever return zero channels (the max function might be useful here)! You can convert the float to an integer with the int() function.
Calculate the number of channels
There are 2 channels.
11) Calculate the actual channel width based on the number of channels and the total flocculator width.
The actual flocculator channel width is 53.35 centimeter
12) Calculate the maximum distance between expansions. This occurs for the largest allowable H/S ratio. Note that this isn’t accounting for the integer requirement for the number of baffle spaces per channel yet.
The maximum distance between expansions 1.074 meters.
13) Calculate the minimum number of expansions per baffle space.
Find the minimum number of expansions
The number of expansions is 2.
14) Calculate the actual distance between expansions given the integer requirement for the number of expansions per flocculator depth.
The actual distance between expansions is 1 meter.
15) Calculate the spacing between baffles based on the target velocity gradient using (205).
The spacing between baffles is 0.1832 meter.
16) How many baffle spaces would fit in the channel(s) given the length of the flocculator and the baffle spacing? Round to the nearest integer.
Find the number of baffle spaces
The number of baffle spaces that would fit in the channels is 41
17) How many baffle spaces are needed to create the required collision potential? Note that this isn’t necessarily the same number as found in Problem 16. Calculating the collision potential per baffle space is the advised first step.
Calculate the number of baffles needed
The collision potential (Gt) per baffle space is 944 dimensionless. The minimum number of baffles required is 41
18) Do the two estimates of the number of baffle spaces agree?
Yes.
19) Calculate the average velocity of the water in the flocculator. This is the velocity after the flow has expanded through each baffle/obstacle.
The average velocity of the water in the flocculator is 0.2046 meter / second
20) Calculate the depth of water at the beginning of the flocculator based on the design head loss.
The depth of the water at the beginning of the flocculator is 2.4 meter
21) Estimate the residence time in the hydraulic flocculator taking head loss into account. It is okay if your estimate doesn’t capture all of the details of the flocculator. You don’t need to account for the volume of the baffles. Simply account for the added water due to head loss. You can approximate the extra depth as a triangle.
The residence time in the hydraulic flocculator is 7.275 minutes.
22) Create plots showing number of channels, number of expansions per water depth, total number of baffles, and channel width for a flow range from 10-100 L/s. Note that the functions that we created in this design challenge are not able to handle arrays as inputs. Use for
loops to create the numpy arrays of y data needed for these graphs. Use 100 points to define each plot. Remember to initialize the numpy arrays before
Colab worksheet creating plots
23) Read from the graphs to determine:
At what flow rate is it no longer necessary to add extra obstacles in the flocculator?
At what flow rate does the flocculator switch from 2 channels to 4 channels?
Why did the flocculator switch from 2 to 4 channels?
No obstacles are needed for flows greater than about 65 L/s.
The flocculator switches from 2 to 4 channels at 65 L/s.
The channels had reached their maximum width at that flow rate.
24) Change Gt_BOD to 20,000 and run the code again. Identify at least 3 changes in the design.
The number of channels would be 2 for all of the flows explored here.
The value of G increased.
The spacing between baffles decreased.
The flow expansions became closer together (because the spacing between baffles decreased).
The number of baffles decreased.