
    rh                       S SK Jr  S SKrS SKrS SKrS SKJr  S SKJr  S SKJr  S SKJ	r	  S SKJ
r
  S SKJr  S S	KJr  \
R                  \
R                   \
R"                  \
R$                  \
R&                  S
.r " S S5      r " S S\R,                  5      r " S S\R0                  5      r\S:X  a  S SKr\R6                  " \5        gg)    )annotationsN)exceptions21)note)pitch)key)scale)notation)convertToPitch)majorminordorianphrygianhypophrygianc                  \    \ rS rSr% SrSSS.rS\S'   SS jrSS
 jrSS jr	SS jr
S rSrg	)FiguredBassScale!   a  
Acts as a wrapper for :class:`~music21.scale.Scale`. Used to represent the
concept of a figured bass scale, with a scale value and mode.


Accepted scale types: major, minor, dorian, phrygian, and hypophrygian.
A FiguredBassScaleException is raised if an invalid scale type is provided.

>>> from music21.figuredBass import realizerScale
>>> fbScale = realizerScale.FiguredBassScale()
>>> fbScale.realizerScale
<music21.scale.MajorScale C major>
>>> fbScale.keySig
<music21.key.KeySignature of no sharps or flats>

>>> fbScale = realizerScale.FiguredBassScale('d', 'minor')
>>> fbScale.realizerScale
<music21.scale.MinorScale D minor>
>>> fbScale.keySig
<music21.key.KeySignature of 1 flat>
zj
            A :class:`~music21.scale.Scale` based on the
            desired value and mode.
            zu
            A :class:`~music21.key.KeySignature` corresponding to
            the scale value and mode.
            )realizerScalekeySigzdict[str, str]	_DOC_ATTRc                     [         U   nU" U5      U l        [        R                  " [        R                  " X5      5      U l        g ! [         a    [        SU-   5      ef = f)NzUnsupported scale type-> )
scaleModesr   r   KeySignaturepitchToSharpsr   KeyErrorFiguredBassScaleException)self
scaleValue	scaleMode
scaleClasss       [/home/james-whalen/.local/lib/python3.13/site-packages/music21/figuredBass/realizerScale.py__init__FiguredBassScale.__init__B   s^    	U#I.J!+J!7D**3+<+<Z+STDK 	U+,G),STT	Us   AA A!Nc                   [        U5      nU R                  R                  U5      n[        R                  " U5      nUc  [
        R                  " U5      n[        R                  " U5      nU R                  R                  UR                  R                  5      UR                  R                  :w  a>  U R                  R                  UR                  R                  5      UR                  l        U R                  R                  UR                  5      n/ n[        [        UR                   5      5       Hn  nX4R                   U   -   S-
  S-  n	U R                  R#                  U	5      n
UR$                  U   R'                  U
R(                  5      nUR+                  U5        Mp     UR+                  UR(                  5        UR-                  5         U$ )a  
Takes a bassPitch and notationString and returns a list of corresponding
pitch names based on the scale value and mode above and inclusive of the
bassPitch name.

>>> from music21.figuredBass import realizerScale
>>> fbScale = realizerScale.FiguredBassScale()
>>> fbScale.getPitchNames('D3', '6')
['D', 'F', 'B']
>>> fbScale.getPitchNames('G3')
['G', 'B', 'D']
>>> fbScale.getPitchNames('B3', '6,#5')
['B', 'D', 'F#', 'G']
>>> fbScale.getPitchNames('C#3', '-7')  # Fully diminished seventh chord
['C#', 'E', 'G', 'B-']
      )r
   r   getScaleDegreeFromPitchr	   Notationcopydeepcopyr   Noter   accidentalByStepr   step
accidentalrangelennumberspitchFromDegree	modifiersmodifyPitchNamenameappendreverse)r   	bassPitchnotationStringbassSDntbassPitchCopybassNote
pitchNamesipitchSDsamplePitch	pitchNames               r    getPitchNamesFiguredBassScale.getPitchNamesJ   s`   " #9-	##;;IF~.> MM)4Myy/H,,X^^-@-@A~~001,0KK,H,HI\I\,])''??OF
s2::'A

1-1Q6G,,<<WEKQ778H8HIIi(	 ( 	)..)    c                b    [        U5      nUR                  S5      nU R                  XU5      nU$ )a$  
Returns all pitches for a bassPitch and notationString within
an octave of the bassPitch, inclusive of the bassPitch but
exclusive at the upper bound. In other words, this method
returns the most compact complete chord implied by the bassPitch
and its figures.

>>> from music21.figuredBass import realizerScale
>>> fbScale = realizerScale.FiguredBassScale()

>>> fbScale.getSamplePitches('D3', '6')  # First inversion triad
[<music21.pitch.Pitch D3>, <music21.pitch.Pitch F3>, <music21.pitch.Pitch B3>]

Root position triad

>>> [str(p) for p in fbScale.getSamplePitches('G3') ]
['G3', 'B3', 'D4']

First inversion seventh chord

>>> [str(p) for p in fbScale.getSamplePitches('B3', '6,5') ]
['B3', 'D4', 'F4', 'G4']

Neapolitan chord

>>> [str(p) for p in fbScale.getSamplePitches('F3', '-6,-') ]
['F3', 'A-3', 'D-4']

Second inversion seventh chord

>>> [str(p) for p in fbScale.getSamplePitches('C5', '4,3') ]
['C5', 'E5', 'F5', 'A5']

Fully diminished seventh chord

>>> [str(p) for p in fbScale.getSamplePitches('C#3', '-7') ]
['C#3', 'E3', 'G3', 'B-3']
d8)r
   	transpose
getPitches)r   r7   r8   maxPitchsamplePitchess        r    getSamplePitches!FiguredBassScale.getSamplePitchesr   s5    N #9-	&&t,	8LrD   c                  ^^ Tc  [         R                  " S5      m[        T5      m[        T5      mU R                  TU5      n[        R
                  " U[        TR                  S-   5      5      n[        S U5      n[        R                  " U4S jU5      n[        R                  " U4S jU5      n[        U5      n	U	R                  5         U	$ )a  
Takes in a bassPitch, a notationString, and a maxPitch representing the highest
possible pitch that can be returned. Returns a sorted list of pitches which
correspond to the pitches of each specific pitch name found through getPitchNames
that fall between the bassPitch and the maxPitch, inclusive of both.

if maxPitch is None, then B5 s used instead.

>>> from music21.figuredBass import realizerScale
>>> fbScale = realizerScale.FiguredBassScale()

Root position triad

>>> [str(p) for p in fbScale.getPitches('C3') ]
['C3', 'E3', 'G3', 'C4', 'E4', 'G4', 'C5', 'E5', 'G5']

First inversion triad

>>> [str(p) for p in fbScale.getPitches('D3', '6') ]
['D3', 'F3', 'B3', 'D4', 'F4', 'B4', 'D5', 'F5', 'B5']

Root position seventh chord, showing MaxPitch

>>> fbScale.getPitches(pitch.Pitch('G3'), '7', 'F4')
[<music21.pitch.Pitch G3>, <music21.pitch.Pitch B3>,
 <music21.pitch.Pitch D4>, <music21.pitch.Pitch F4>]
B5r$   c                R    [         R                  " U S   [        U S   5      -   5      $ )Nr   r$   )r   Pitchstr)xs    r    <lambda>-FiguredBassScale.getPitches.<locals>.<lambda>   s    ekk!A$QqT*:;rD   c                   > TU :  $ N )r@   r7   s    r    rS   rT      s
    )k:QrD   c                   > U T:  $ rV   rW   )r@   rI   s    r    rS   rT      s
    +:PrD   )r   rP   r
   rB   	itertoolsproductr.   octavemapfilterfalselistsort)
r   r7   r8   rI   r=   iter1iter2iter3iter4
allPitchess
    ` `      r    rH   FiguredBassScale.getPitches   s    8 {{4(H"9-	!(+''	>B
!!*eHOOa4G.HI;UC%%&QSXY%%&PRWX%[
rD   c                    U R                   < $ rV   )r   )r   s    r    _reprInternalFiguredBassScale._reprInternal   s    $$'(rD   )r   r   )Cr   rV   )NN)__name__
__module____qualname____firstlineno____doc__r   __annotations__r!   rB   rK   rH   rg   __static_attributes__rW   rD   r    r   r   !   s<    ,	!I~ 	U&P+Z(T)rD   r   c                      \ rS rSrSrg)r      rW   Nrj   rk   rl   rm   rp   rW   rD   r    r   r          rD   r   c                      \ rS rSrSrg)Test   rW   Nrs   rW   rD   r    rv   rv      rt   rD   rv   __main__)
__future__r   r(   rY   unittestmusic21r   r   r   r   r   music21.figuredBassr	   music21.figuredBass.notationr
   
MajorScale
MinorScaleDorianScalePhrygianScaleHypophrygianScaler   r   Music21Exceptionr   TestCaserv   rj   mainTestrW   rD   r    <module>r      s    #          ( 7''''))--#55	7
i) i)X	 = = 		8 	 zT rD   