Skip to content

Commit

Permalink
Merge branch 'master' into FM-fix
Browse files Browse the repository at this point in the history
  • Loading branch information
andrewning authored Feb 14, 2024
2 parents a148461 + 5f6fefe commit 4ad425c
Showing 1 changed file with 30 additions and 19 deletions.
49 changes: 30 additions & 19 deletions src/CCBlade.jl
Original file line number Diff line number Diff line change
Expand Up @@ -300,7 +300,6 @@ function residual_and_outputs(phi, x, p) #rotor, section, op)
R = sin(phi)/(1 + a) - Vx/Vy*cos(phi)/(1 - ap)
end


# ------- loads ---------
W = sqrt((Vx + u)^2 + (Vy - v)^2)
Np = cn*0.5*rho*W^2*chord
Expand Down Expand Up @@ -367,22 +366,23 @@ end


"""
solve(rotor, section, op)
solve(rotor, section, op; npts=10, forcebackwardsearch=false, epsilon_everywhere=false)
Solve the BEM equations for given rotor geometry and operating point.
**Arguments**
- `rotor::Rotor`: rotor properties
- `section::Section`: section properties
- `op::OperatingPoint`: operating point
**Keyword Arguments**
- `implicitad_option=true`: if true, uses ImplicitAD to solve the residual when Duals are passed through; if false, bypasses the ImplicitAD solve
- `npts::Int = 10`: number of discretization points for `phi` state variable, used to find bracket for residual solve
- `forcebackwardsearch::Bool = false`: if true, force bracket search from high `phi` values to low, otherwise let `solve` decide
- `epsilon_everywhere::Bool = false`: if true, don't evaluate at intersections of `phi` quadrants (`pi/2`, `-pi/2`, etc.)
- `implicitad_option=true`: if true, uses ImplicitAD to compute derivatives around solver when using AD; if false, bypasses ImplicitAD
**Returns**
- `outputs::Outputs`: BEM output data including loads, induction factors, etc.
"""
function solve(rotor, section, op; implicitad_option=true)
function solve(rotor, section, op; npts=10, forcebackwardsearch=false, epsilon_everywhere=false, implicitad_option=true)

# error handling
if typeof(section) <: AbstractVector
Expand All @@ -395,7 +395,7 @@ function solve(rotor, section, op; implicitad_option=true)
end

# parameters
npts = 10 # number of discretization points to find bracket in residual solve
# npts = 10 # number of discretization points to find bracket in residual solve

# unpack
Vx = op.Vx
Expand All @@ -408,10 +408,17 @@ function solve(rotor, section, op; implicitad_option=true)

# quadrants
epsilon = 1e-6
q1 = [epsilon, pi/2]
q2 = [-pi/2, -epsilon]
q3 = [pi/2, pi-epsilon]
q4 = [-pi+epsilon, -pi/2]
if epsilon_everywhere
q1 = [epsilon, pi/2-epsilon]
q2 = [-pi/2+epsilon, -epsilon]
q3 = [pi/2+epsilon, pi-epsilon]
q4 = [-pi+epsilon, -pi/2-epsilon]
else
q1 = [epsilon, pi/2]
q2 = [-pi/2, -epsilon]
q3 = [pi/2, pi-epsilon]
q4 = [-pi+epsilon, -pi/2]
end

if Vx_is_zero && Vy_is_zero
return Outputs()
Expand Down Expand Up @@ -472,15 +479,19 @@ function solve(rotor, section, op; implicitad_option=true)
for j = 1:length(order) # quadrant orders. In most cases it should find root in first quadrant searched.
phimin, phimax = order[j]

# check to see if it would be faster to reverse the bracket search direction
backwardsearch = false
if !startfrom90
if phimin == -pi/2 || phimax == -pi/2 # q2 or q4
backwardsearch = true
end
if forcebackwardsearch
backwardsearch = true
else
if phimax == pi/2 # q1
backwardsearch = true
# check to see if it would be faster to reverse the bracket search direction
backwardsearch = false
if !startfrom90
if phimin == -pi/2 || phimax == -pi/2 # q2 or q4
backwardsearch = true
end
else
if phimax == pi/2 # q1
backwardsearch = true
end
end
end

Expand Down

0 comments on commit 4ad425c

Please sign in to comment.