
    hhYP                     R    d dl mZmZ d dlmZ ddlmZ ddlmZ dgZ	 G d d      Z
y)	   )Vector_check_vector)_check_frame    )warn)
filldedentPointc                   t    e Zd ZdZd Zd ZeZd Zd Zd Z	d Z
d Zd	 Zd
 Zd Zd Zd Zd Zd Zd Zd Zy)r	   ad  This object represents a point in a dynamic system.

    It stores the: position, velocity, and acceleration of a point.
    The position is a vector defined as the vector distance from a parent
    point to this point.

    Parameters
    ==========

    name : string
        The display name of the Point

    Examples
    ========

    >>> from sympy.physics.vector import Point, ReferenceFrame, dynamicsymbols
    >>> from sympy.physics.vector import init_vprinting
    >>> init_vprinting(pretty_print=False)
    >>> N = ReferenceFrame('N')
    >>> O = Point('O')
    >>> P = Point('P')
    >>> u1, u2, u3 = dynamicsymbols('u1 u2 u3')
    >>> O.set_vel(N, u1 * N.x + u2 * N.y + u3 * N.z)
    >>> O.acc(N)
    u1'*N.x + u2'*N.y + u3'*N.z

    ``symbols()`` can be used to create multiple Points in a single step, for
    example:

    >>> from sympy.physics.vector import Point, ReferenceFrame, dynamicsymbols
    >>> from sympy.physics.vector import init_vprinting
    >>> init_vprinting(pretty_print=False)
    >>> from sympy import symbols
    >>> N = ReferenceFrame('N')
    >>> u1, u2 = dynamicsymbols('u1 u2')
    >>> A, B = symbols('A B', cls=Point)
    >>> type(A)
    <class 'sympy.physics.vector.point.Point'>
    >>> A.set_vel(N, u1 * N.x + u2 * N.y)
    >>> B.set_vel(N, u2 * N.x + u1 * N.y)
    >>> A.acc(N) - B.acc(N)
    (u1' - u2')*N.x + (-u1' + u2')*N.y

    c                     || _         i | _        i | _        i | _        | j                  | j                  | j                  g| _        y)z"Initialization of a Point object. N)name	_pos_dict	_vel_dict	_acc_dict_pdlist)selfr   s     X/var/www/html/dev/engine/venv/lib/python3.12/site-packages/sympy/physics/vector/point.py__init__zPoint.__init__7   s8    	G    c                     | j                   S )N)r   )r   s    r   __str__zPoint.__str__?   s    yyr   c                 :    t        |t              st        d      y )NzA Point must be supplied)
isinstancer	   	TypeError)r   others     r   _check_pointzPoint._check_pointD   s    %'677 (r   c                    | gg}g g}||k7  r|j                         }|D ]d  }|d   j                  |   j                         }|D ]=  }|j                  |      r||gz   }|j                  |      r-|j	                  |       ? f ||k7  r|D ]  }|d   |k7  s|j                  |        |j                  t               t        |      dk7  r|d   S t        d|j                  z   dz   | j                  z         )aM  Returns a list of points that gives the shortest path with respect
        to position, velocity, or acceleration from this point to the provided
        point.

        Parameters
        ==========
        other : Point
            A point that may be related to this point by position, velocity, or
            acceleration.
        num : integer
            0 for searching the position tree, 1 for searching the velocity
            tree, and 2 for searching the acceleration tree.

        Returns
        =======
        list of Points
            A sequence of points from self to other.

        Notes
        =====

        It is not clear if num = 1 or num = 2 actually works because the keys
        to ``_vel_dict`` and ``_acc_dict`` are :class:`ReferenceFrame` objects
        which do not have the ``_pdlist`` attribute.

        )keyr   z!No Connecting Path found between z and )
copyr   keys__contains__appendremovesortlen
ValueErrorr   )	r   r   numoutlistoldlistvtemplistv2littletemplists	            r   _pdict_listzPoint._pdict_listH   s   6 6($ llnG ;R5==-224" ;B>>"-)*bT&33NC#NN>:	;;    	"Au~q!	" 	w<11:<uzzI !#'99- . 	.r   c           	         t        |       t        |       | j                  |       | j                  |      }| j                  |      }|j	                  |      }| j	                  |      }|j                  |      }|j                  |      }	| j                  ||d|j                  |      z  z   |z   |	j                  |      z   |j                  |j                  |            z          | j	                  |      S )a  Sets the acceleration of this point with the 1-point theory.

        The 1-point theory for point acceleration looks like this:

        ^N a^P = ^B a^P + ^N a^O + ^N alpha^B x r^OP + ^N omega^B x (^N omega^B
        x r^OP) + 2 ^N omega^B x ^B v^P

        where O is a point fixed in B, P is a point moving in B, and B is
        rotating in frame N.

        Parameters
        ==========

        otherpoint : Point
            The first point of the 1-point theory (O)
        outframe : ReferenceFrame
            The frame we want this point's acceleration defined in (N)
        fixedframe : ReferenceFrame
            The intermediate frame in this calculation (B)

        Examples
        ========

        >>> from sympy.physics.vector import Point, ReferenceFrame
        >>> from sympy.physics.vector import dynamicsymbols
        >>> from sympy.physics.vector import init_vprinting
        >>> init_vprinting(pretty_print=False)
        >>> q = dynamicsymbols('q')
        >>> q2 = dynamicsymbols('q2')
        >>> qd = dynamicsymbols('q', 1)
        >>> q2d = dynamicsymbols('q2', 1)
        >>> N = ReferenceFrame('N')
        >>> B = ReferenceFrame('B')
        >>> B.set_ang_vel(N, 5 * B.y)
        >>> O = Point('O')
        >>> P = O.locatenew('P', q * B.x + q2 * B.y)
        >>> P.set_vel(B, qd * B.x + q2d * B.y)
        >>> O.set_vel(N, 0)
        >>> P.a1pt_theory(O, N, B)
        (-25*q + q'')*B.x + q2''*B.y - 10*q'*B.z

           )	r   r   pos_fromvelacc
ang_vel_in
ang_acc_inset_acccross)
r   
otherpointoutframe
interframedistr*   a1a2omegaalphas
             r   a1pt_theoryzPoint.a1pt_theoryw   s    X 	XZ *%}}Z(HHZ ^^H%XXj!%%h/%%h/XrAQ$882=kk$' ),1KKD8I,J L 	Mxx!!r   c           	         t        |       t        |       | j                  |       | j                  |      }|j                  |      }|j	                  |      }|j                  |      }| j                  |||j                  |      z   |j                  |j                  |            z          | j                  |      S )a  Sets the acceleration of this point with the 2-point theory.

        The 2-point theory for point acceleration looks like this:

        ^N a^P = ^N a^O + ^N alpha^B x r^OP + ^N omega^B x (^N omega^B x r^OP)

        where O and P are both points fixed in frame B, which is rotating in
        frame N.

        Parameters
        ==========

        otherpoint : Point
            The first point of the 2-point theory (O)
        outframe : ReferenceFrame
            The frame we want this point's acceleration defined in (N)
        fixedframe : ReferenceFrame
            The frame in which both points are fixed (B)

        Examples
        ========

        >>> from sympy.physics.vector import Point, ReferenceFrame, dynamicsymbols
        >>> from sympy.physics.vector import init_vprinting
        >>> init_vprinting(pretty_print=False)
        >>> q = dynamicsymbols('q')
        >>> qd = dynamicsymbols('q', 1)
        >>> N = ReferenceFrame('N')
        >>> B = N.orientnew('B', 'Axis', [q, N.z])
        >>> O = Point('O')
        >>> P = O.locatenew('P', 10 * B.x)
        >>> O.set_vel(N, 5 * N.x)
        >>> P.a2pt_theory(O, N, B)
        - 10*q'**2*B.x + 10*q''*B.y

        )r   r   r1   r3   r4   r5   r6   r7   )r   r8   r9   
fixedframer;   ar>   r?   s           r   a2pt_theoryzPoint.a2pt_theory   s    L 	XZ *%}}Z(NN8$%%h/%%h/XqEKK$56kk%++d"34 6 	7xx!!r   c                     t        |       || j                  vr=| j                  |      dk7  r| j                  |   j	                  |      S t        d      S | j                  |   S )a  The acceleration Vector of this Point in a ReferenceFrame.

        Parameters
        ==========

        frame : ReferenceFrame
            The frame in which the returned acceleration vector will be defined
            in.

        Examples
        ========

        >>> from sympy.physics.vector import Point, ReferenceFrame
        >>> N = ReferenceFrame('N')
        >>> p1 = Point('p1')
        >>> p1.set_acc(N, 10 * N.x)
        >>> p1.acc(N)
        10*N.x

        r   )r   r   r2   r   dtr   )r   frames     r   r3   z	Point.acc   s[    , 	U'xx!#u-11%88ay ~~e$$r   c                     t        |t              st        d      |dk(  rt        d      }t	        |      }t        |      }|j                  | |       | j                  ||        |S )a  Creates a new point with a position defined from this point.

        Parameters
        ==========

        name : str
            The name for the new point
        value : Vector
            The position of the new point relative to this point

        Examples
        ========

        >>> from sympy.physics.vector import ReferenceFrame, Point
        >>> N = ReferenceFrame('N')
        >>> P1 = Point('P1')
        >>> P2 = P1.locatenew('P2', 10 * N.x)

        zMust supply a valid namer   )r   strr   r   r   r	   set_pos)r   r   valueps       r   	locatenewzPoint.locatenew   s`    * $$677A:1IEe$$K			$Qr   c                     t        d      }| j                  |d      }t        t        |      dz
        D ]  }|||   j                  ||dz         z  } |S )a  Returns a Vector distance between this Point and the other Point.

        Parameters
        ==========

        otherpoint : Point
            The otherpoint we are locating this one relative to

        Examples
        ========

        >>> from sympy.physics.vector import Point, ReferenceFrame
        >>> N = ReferenceFrame('N')
        >>> p1 = Point('p1')
        >>> p2 = Point('p2')
        >>> p1.set_pos(p2, 10 * N.x)
        >>> p1.pos_from(p2)
        10*N.x

        r   r   )r   r.   ranger%   r   )r   r8   outvecplistis        r   r1   zPoint.pos_from  sa    ,   Q/s5zA~& 	7AeAh((q1u66F	7r   c                     |dk(  rt        d      }t        |      }t        |       | j                  j	                  ||i       y)a#  Used to set the acceleration of this Point in a ReferenceFrame.

        Parameters
        ==========

        frame : ReferenceFrame
            The frame in which this point's acceleration is defined
        value : Vector
            The vector value of this point's acceleration in the frame

        Examples
        ========

        >>> from sympy.physics.vector import Point, ReferenceFrame
        >>> N = ReferenceFrame('N')
        >>> p1 = Point('p1')
        >>> p1.set_acc(N, 10 * N.x)
        >>> p1.acc(N)
        10*N.x

        r   N)r   r   r   r   updater   rG   rK   s      r   r6   zPoint.set_acc:  <    . A:1IEe$Uuen-r   c                     |dk(  rt        d      }t        |      }| j                  |       | j                  j	                  ||i       |j                  j	                  | | i       y)aD  Used to set the position of this point w.r.t. another point.

        Parameters
        ==========

        otherpoint : Point
            The other point which this point's location is defined relative to
        value : Vector
            The vector which defines the location of this point

        Examples
        ========

        >>> from sympy.physics.vector import Point, ReferenceFrame
        >>> N = ReferenceFrame('N')
        >>> p1 = Point('p1')
        >>> p2 = Point('p2')
        >>> p1.set_pos(p2, 10 * N.x)
        >>> p1.pos_from(p2)
        10*N.x

        r   N)r   r   r   r   rT   )r   r8   rK   s      r   rJ   zPoint.set_posW  s]    0 A:1IEe$*%z512##TE6N3r   c                     |dk(  rt        d      }t        |      }t        |       | j                  j	                  ||i       y)a  Sets the velocity Vector of this Point in a ReferenceFrame.

        Parameters
        ==========

        frame : ReferenceFrame
            The frame in which this point's velocity is defined
        value : Vector
            The vector value of this point's velocity in the frame

        Examples
        ========

        >>> from sympy.physics.vector import Point, ReferenceFrame
        >>> N = ReferenceFrame('N')
        >>> p1 = Point('p1')
        >>> p1.set_vel(N, 10 * N.x)
        >>> p1.vel(N)
        10*N.x

        r   N)r   r   r   r   rT   rU   s      r   set_velzPoint.set_velv  rV   r   c                 H   t        |       t        |       | j                  |       | j                  |      }| j                  |      }|j                  |      }|j	                  |      }| j                  |||z   |j                  |      z          | j                  |      S )aV  Sets the velocity of this point with the 1-point theory.

        The 1-point theory for point velocity looks like this:

        ^N v^P = ^B v^P + ^N v^O + ^N omega^B x r^OP

        where O is a point fixed in B, P is a point moving in B, and B is
        rotating in frame N.

        Parameters
        ==========

        otherpoint : Point
            The first point of the 1-point theory (O)
        outframe : ReferenceFrame
            The frame we want this point's velocity defined in (N)
        interframe : ReferenceFrame
            The intermediate frame in this calculation (B)

        Examples
        ========

        >>> from sympy.physics.vector import Point, ReferenceFrame
        >>> from sympy.physics.vector import dynamicsymbols
        >>> from sympy.physics.vector import init_vprinting
        >>> init_vprinting(pretty_print=False)
        >>> q = dynamicsymbols('q')
        >>> q2 = dynamicsymbols('q2')
        >>> qd = dynamicsymbols('q', 1)
        >>> q2d = dynamicsymbols('q2', 1)
        >>> N = ReferenceFrame('N')
        >>> B = ReferenceFrame('B')
        >>> B.set_ang_vel(N, 5 * B.y)
        >>> O = Point('O')
        >>> P = O.locatenew('P', q * B.x + q2 * B.y)
        >>> P.set_vel(B, qd * B.x + q2d * B.y)
        >>> O.set_vel(N, 0)
        >>> P.v1pt_theory(O, N, B)
        q'*B.x + q2'*B.y - 5*q*B.z

        r   r   r1   r2   r4   rY   r7   )r   r8   r9   r:   r;   v1r,   r>   s           r   v1pt_theoryzPoint.v1pt_theory  s    V 	XZ *%}}Z(XXj!^^H%%%h/XrBw%++d*;<=xx!!r   c                     t        |       t        |       | j                  |       | j                  |      }|j                  |      }|j	                  |      }| j                  |||j                  |      z          | j                  |      S )as  Sets the velocity of this point with the 2-point theory.

        The 2-point theory for point velocity looks like this:

        ^N v^P = ^N v^O + ^N omega^B x r^OP

        where O and P are both points fixed in frame B, which is rotating in
        frame N.

        Parameters
        ==========

        otherpoint : Point
            The first point of the 2-point theory (O)
        outframe : ReferenceFrame
            The frame we want this point's velocity defined in (N)
        fixedframe : ReferenceFrame
            The frame in which both points are fixed (B)

        Examples
        ========

        >>> from sympy.physics.vector import Point, ReferenceFrame, dynamicsymbols
        >>> from sympy.physics.vector import init_vprinting
        >>> init_vprinting(pretty_print=False)
        >>> q = dynamicsymbols('q')
        >>> qd = dynamicsymbols('q', 1)
        >>> N = ReferenceFrame('N')
        >>> B = N.orientnew('B', 'Axis', [q, N.z])
        >>> O = Point('O')
        >>> P = O.locatenew('P', 10 * B.x)
        >>> O.set_vel(N, 5 * N.x)
        >>> P.v2pt_theory(O, N, B)
        5*N.x + 10*q'*B.y

        r[   )r   r8   r9   rB   r;   r*   r>   s          r   v2pt_theoryzPoint.v2pt_theory  sz    L 	XZ *%}}Z(NN8$%%h/XqEKK$567xx!!r   c                    t        |       || j                  vrsd}d}g }| g}g }|r|j                  d      }||vr|j                  |       |j                  j                         D ]{  \  }}	||v r	 |	j                  |       ||v rd}	 |j                  |   }
|j                  |       |rG| j                  || j                  |      j                  |      |
z          d}} |r|rt        t        d             t        |      dkD  rAt        t        d| j                   d|d   j                   dt!        |dd	        d
             |r| j                  |   S t        t        d| j                   d|j                   d            | j                  |   S # t        $ r Y Aw xY w# t        $ r |j                  |       Y bw xY w)a  The velocity Vector of this Point in the ReferenceFrame.

        Parameters
        ==========

        frame : ReferenceFrame
            The frame in which the returned velocity vector will be defined in

        Examples
        ========

        >>> from sympy.physics.vector import Point, ReferenceFrame, dynamicsymbols
        >>> N = ReferenceFrame('N')
        >>> p1 = Point('p1')
        >>> p1.set_vel(N, 10 * N.x)
        >>> p1.vel(N)
        10*N.x

        Velocities will be automatically calculated if possible, otherwise a
        ``ValueError`` will be returned. If it is possible to calculate
        multiple different velocities from the relative points, the points
        defined most directly relative to this point will be used. In the case
        of inconsistent relative positions of points, incorrect velocities may
        be returned. It is up to the user to define prior relative positions
        and velocities of points in a self-consistent way.

        >>> p = Point('p')
        >>> q = dynamicsymbols('q')
        >>> p.set_vel(N, 10 * N.x)
        >>> p2 = Point('p2')
        >>> p2.set_pos(p, q*N.x)
        >>> p2.vel(N)
        (Derivative(q(t), t) + 10)*N.x

        Fr   Tz
                Kinematic loops are defined among the positions of points. This
                is likely not desired and may cause errors in your calculations.
                r   z
                Velocity of z9 automatically calculated based on point
                z9 but it is also possible from
                points(s): Nz. Velocities from these
                points are not necessarily the same. This may cause errors in
                your calculations.z#
                Velocity of point z8 has not been defined in
                ReferenceFrame .)r   r   popr"   r   itemsexpressr&   KeyErrorrY   r1   rF   r   r   r%   r   rI   )r   rG   valid_neighbor_found	is_cyclicvisitedqueuecandidate_neighbornodeneighborneighbor_posneighbor_velocitys              r   r2   z	Point.vel  s   J 	U'#( IGFE!#yy|w&NN4(26..2F2F2H 8.,#w.$%(007 $u,(,I%080B0B50I- +11(;3 LLh0G0J0J50QTe0ef370'8	 0 Z !   %&*Z %!YYK (#A&++, - 212 678 9#!& ' ( $~~e,,  1##'99+ .  %

|1-0 "1 2 2 ~~e$$C  * %$%  ( %!LL2$%s$   4FF-	F*)F*-G
Gc                     ddl m} | j                  |      } ||g||      d   }t        |      dk(  r|d   S t	        |      S )a  Returns the partial velocities of the linear velocity vector of this
        point in the given frame with respect to one or more provided
        generalized speeds.

        Parameters
        ==========
        frame : ReferenceFrame
            The frame with which the velocity is defined in.
        gen_speeds : functions of time
            The generalized speeds.

        Returns
        =======
        partial_velocities : tuple of Vector
            The partial velocity vectors corresponding to the provided
            generalized speeds.

        Examples
        ========

        >>> from sympy.physics.vector import ReferenceFrame, Point
        >>> from sympy.physics.vector import dynamicsymbols
        >>> N = ReferenceFrame('N')
        >>> A = ReferenceFrame('A')
        >>> p = Point('p')
        >>> u1, u2 = dynamicsymbols('u1, u2')
        >>> p.set_vel(N, u1 * N.x + u2 * A.y)
        >>> p.partial_velocity(N, u1)
        N.x
        >>> p.partial_velocity(N, u1, u2)
        (N.x, A.y)

        r   )partial_velocityr   )sympy.physics.vector.functionsrp   r2   r%   tuple)r   rG   
gen_speedsrp   r2   partialss         r   rp   zPoint.partial_velocityP  sK    F 	Dhhuo#SE:u=a@x=AA;?"r   N)__name__
__module____qualname____doc__r   r   __repr__r   r.   r@   rD   r3   rM   r1   r6   rJ   rY   r]   r_   r2   rp    r   r   r	   r	   	   sg    +ZH H8-.^7"r/"b%<>8.:4>.:3"j-"^W%r+#r   N)vectorr   r   rG   r   warningsr   sympy.utilities.miscr   __all__r	   rz   r   r   <module>r      s$    )   +)r	# r	#r   