reb
Class REB_TrapShapeLinksCurve

Object
  extended by common:Generic
      extended by common:TrapShape
          extended by reb:REB_TrapShapeLinksCurve

class 
TrapShape:REB_TrapShapeLinksCurve

This shape uses the links curve function.

This variant of the function involves taking a square root so there are two solutions. A signed and absolute value version of the distance is also available. The transformed value is the complex return value of the function.


Ultra Fractal Source

Toggle UF Source Code Display

 class REB_TrapShapeLinksCurve(common.ulb:TrapShape) {
  ; This shape uses the links curve function.<br>
  ; <p>
  ; This variant of the function involves taking a square root
  ; so there are two solutions. A signed and absolute value version of
  ; the distance is also available. The transformed value is the
  ; complex return value of the function.
  public:
    import "common.ulb"
 
 ; Constructor
    func REB_TrapShapeLinksCurve(Generic pparent)
      TrapShape.TrapShape(pparent)
    endfunc
    
   ; Call this for each iteration being trapped.
    float func Iterate(complex pz)
     TrapShape.Iterate(pz)
      float d =  0
     int sgn = 1
     if @sgn
       sgn = -1
     endif
     float cx = real(pz)
     float qa = 1
     float qb = 2*cx^2-6*cx
     float qc = cx^4-2*cx^3+cx^2
     if @negroot
       qy = ((-qb - (qb^2 - 4*qa*qc)^0.5)/(2*qa))^0.5
     else
       qy = ((-qb + (qb^2 - 4*qa*qc)^0.5)/(2*qa))^0.5
     endif
     if @absval
       d = abs(cabs(pz) - cabs(@a*(cx + sgn*flip(qy))))
     else
       d = cabs(pz - @a*(cx + sgn*flip(qy)))
     endif
     m_LastZ = @a*(cx + sgn*flip(qy))
     return d
    endfunc
    
  default:
    title = "Links Curve"
   int param v_trapshapelinkscurve
     caption = "Version (Trap Shape Links Curve)"
     default = 101
     hint = "This version parameter is used to detect when a change has been made to the formula that is incompatible with the previous version. When that happens, this field will reflect the old version number to alert you to the fact that an alternate rendering is being used."
     visible = @v_trapshapelinkscurve < 101
   endparam
    
    float param a
      caption = "Polar parameter"
      default = 0.2
      hint = "Affects spread and scale of trap"
    endparam
    bool param sgn
      caption = "Conjugate transform"
      default = false
    endparam
    param absval
      caption = "Absolute Value"
      default = false
    endparam
    param negroot
      caption = "Quad Neg Root"
      default = true
    endparam
  }
 


Constructor Summary
REB_TrapShapeLinksCurve()
           
REB_TrapShapeLinksCurve(Generic pparent)
          Constructor
 
Method Summary
 float Iterate(complex pz)
          Call this for each iteration being trapped.
 
Methods inherited from class common:TrapShape
GetColorChannel, GetTextureValue, GetTransformedPoint, Init, IterateSilent, SetThreshold
 
Methods inherited from class common:Generic
GetParent
 
Methods inherited from class Object
 

Constructor Detail

REB_TrapShapeLinksCurve

public REB_TrapShapeLinksCurve(Generic pparent)
Constructor


REB_TrapShapeLinksCurve

public REB_TrapShapeLinksCurve()
Method Detail

Iterate

public float Iterate(complex pz)
Call this for each iteration being trapped.

Overrides:
Iterate in class TrapShape