ComplexStreamPlot
✖
ComplexStreamPlot
generates a streamline plot of the vector field {Re[f],Im[f]} over the complex rectangle with corners zmin and zmax.
Details and Options




- ComplexStreamPlot plots streamlines that show the local direction of the complex vector field at each point, effectively solving the differential equation
and then plotting
.
- ComplexStreamPlot by default shows enough streamlines to achieve a roughly uniform density throughout the plot and shows no background scalar field.
- No streamlines are shown at any positions for which f etc. do not evaluate to a complex number.
- ComplexStreamPlot[f,{z,n}] is equivalent to ComplexStreamPlot[f,{z,-n-n I,n+n I}].
- ComplexStreamPlot has attribute HoldAll and evaluates f etc. only after assigning specific numerical values to z. In some cases, it may be more efficient to use Evaluate to evaluate f symbolically first.
- ComplexStreamPlot has the same options as Graphics, with the following additions and changes: [List of all options]
-
AspectRatio 1 ratio of height to width EvaluationMonitor None expression to evaluate at every function evaluation Frame True whether to draw a frame around the plot FrameTicks Automatic frame tick marks Method Automatic methods to use for the plot PerformanceGoal $PerformanceGoal aspects of performance to try to optimize PlotLegends None legends to include PlotRange {Full,Full} range of x, y values to include PlotRangePadding Automatic how much to pad the range of values PlotTheme $PlotTheme overall theme for the plot RegionBoundaryStyle Automatic how to style plot region boundaries RegionFillingStyle Automatic how to style plot region interiors RegionFunction (True&) determine what region to include StreamColorFunction Automatic how to color streamlines StreamColorFunctionScaling True whether to scale the argument to StreamColorFunction StreamMarkers Automatic shape to use for streams StreamPoints Automatic determine number, placement and closeness of streamlines StreamScale Automatic determine sizes and segmenting of individual streamlines StreamStyle Automatic how to draw streamlines WorkingPrecision MachinePrecision precision to use in internal computations - Common stream markers include:
-
"Segment" line segment aligned in the field direction "PinDart" pin dart aligned along the field "Dart" dart-shaped marker "Drop" drop-shaped marker - The arguments supplied to functions in RegionFunction are
,
. Functions in ColorFunction are by default supplied with scaled versions of Re[z], Im[z], Abs[z], Arg[z], Re[f], Im[f], Abs[f], Arg[f].
-
AlignmentPoint Center the default point in the graphic to align with AspectRatio 1 ratio of height to width Axes False whether to draw axes AxesLabel None axes labels AxesOrigin Automatic where axes should cross AxesStyle {} style specifications for the axes Background None background color for the plot BaselinePosition Automatic how to align with a surrounding text baseline BaseStyle {} base style specifications for the graphic ContentSelectable Automatic whether to allow contents to be selected CoordinatesToolOptions Automatic detailed behavior of the coordinates tool Epilog {} primitives rendered after the main plot EvaluationMonitor None expression to evaluate at every function evaluation FormatType TraditionalForm the default format type for text Frame True whether to draw a frame around the plot FrameLabel None frame labels FrameStyle {} style specifications for the frame FrameTicks Automatic frame tick marks FrameTicksStyle {} style specifications for frame ticks GridLines None grid lines to draw GridLinesStyle {} style specifications for grid lines ImageMargins 0. the margins to leave around the graphic ImagePadding All what extra padding to allow for labels etc. ImageSize Automatic the absolute size at which to render the graphic LabelStyle {} style specifications for labels Method Automatic methods to use for the plot PerformanceGoal $PerformanceGoal aspects of performance to try to optimize PlotLabel None an overall label for the plot PlotLegends None legends to include PlotRange {Full,Full} range of x, y values to include PlotRangeClipping False whether to clip at the plot range PlotRangePadding Automatic how much to pad the range of values PlotRegion Automatic the final display region to be filled PlotTheme $PlotTheme overall theme for the plot PreserveImageOptions Automatic whether to preserve image options when displaying new versions of the same graphic Prolog {} primitives rendered before the main plot RegionBoundaryStyle Automatic how to style plot region boundaries RegionFillingStyle Automatic how to style plot region interiors RegionFunction (True&) determine what region to include RotateLabel True whether to rotate y labels on the frame StreamColorFunction Automatic how to color streamlines StreamColorFunctionScaling True whether to scale the argument to StreamColorFunction StreamMarkers Automatic shape to use for streams StreamPoints Automatic determine number, placement and closeness of streamlines StreamScale Automatic determine sizes and segmenting of individual streamlines StreamStyle Automatic how to draw streamlines Ticks Automatic axes ticks TicksStyle {} style specifications for axes ticks WorkingPrecision MachinePrecision precision to use in internal computations

List of all options




Examples
open allclose allBasic Examples (1)Summary of the most common use cases
Scope (22)Survey of the scope of standard use cases
Sampling (8)
Plot a complex functions with streamlines placed with specified densities:

https://wolfram.com/xid/0btm879l391u-gippoq

Plot the streamlines that go through a set of complex seed points:

https://wolfram.com/xid/0btm879l391u-s28qu

Use both automatic and explicit seeding with styles for explicitly seeded streamlines:

https://wolfram.com/xid/0btm879l391u-1pnaf

Plot streamlines over a specified complex region:

https://wolfram.com/xid/0btm879l391u-riyn


https://wolfram.com/xid/0btm879l391u-e6xxik

Use a specific number of mesh lines:

https://wolfram.com/xid/0btm879l391u-h4qmst


https://wolfram.com/xid/0btm879l391u-vya6w

Use Evaluate to evaluate the vector field symbolically before numeric assignment:

https://wolfram.com/xid/0btm879l391u-cvqgvo

Presentation (14)
Specify different dashings and arrowheads by setting to StreamScale:

https://wolfram.com/xid/0btm879l391u-c01iov

Plot the streamlines with arrows colored according to the modulus of the function:

https://wolfram.com/xid/0btm879l391u-bzn8rj

Apply a variety of streamline markers:

https://wolfram.com/xid/0btm879l391u-gdgoy

Use a theme with axes and a different default color:

https://wolfram.com/xid/0btm879l391u-mgbu25

Override the style from the theme:

https://wolfram.com/xid/0btm879l391u-hoo7c


https://wolfram.com/xid/0btm879l391u-bzvzw

Specify a uniform color for the streamlines:

https://wolfram.com/xid/0btm879l391u-fhtc9z

Specify mesh lines with different styles:

https://wolfram.com/xid/0btm879l391u-dxq1g5

Specify global mesh line styles:

https://wolfram.com/xid/0btm879l391u-gk2sq

Shade mesh regions cyclically:

https://wolfram.com/xid/0btm879l391u-byci9c

Apply a variety of styles to region boundaries:

https://wolfram.com/xid/0btm879l391u-djvun8

https://wolfram.com/xid/0btm879l391u-cc1fhx

Add a legend indicating the modulus of the function:

https://wolfram.com/xid/0btm879l391u-boss17

Use the functions as legend labels:

https://wolfram.com/xid/0btm879l391u-bvfjp0

Use explicit labels for each vector field:

https://wolfram.com/xid/0btm879l391u-dnwich

Options (60)Common values & functionality for each option
Background (1)
EvaluationMonitor (2)
PerformanceGoal (2)
PlotLegends (7)
No legends are included, by default:

https://wolfram.com/xid/0btm879l391u-ftw0rz

Include a legend that indicates the modulus of the function:

https://wolfram.com/xid/0btm879l391u-gp202b

Include a legend to distinguish two functions:

https://wolfram.com/xid/0btm879l391u-cffxj2

Control the placement of the legend:

https://wolfram.com/xid/0btm879l391u-i5lqro

Use the functions as the legend text:

https://wolfram.com/xid/0btm879l391u-bt1wv


https://wolfram.com/xid/0btm879l391u-batrg5

Change the appearance of the legend:

https://wolfram.com/xid/0btm879l391u-ffkr3r

PlotRange (5)
The full plot range is used by default:

https://wolfram.com/xid/0btm879l391u-g1svk

Specify an explicit limit for both the and
ranges:

https://wolfram.com/xid/0btm879l391u-qpoa0l


https://wolfram.com/xid/0btm879l391u-h2oin6


https://wolfram.com/xid/0btm879l391u-ele5ao


https://wolfram.com/xid/0btm879l391u-bxawdt

PlotTheme (3)
RegionBoundaryStyle (1)
RegionFillingStyle (1)
RegionFunction (3)
Plot streamlines only over a disk:

https://wolfram.com/xid/0btm879l391u-kvuz

Plot streamlines only over regions where the modulus of the function exceeds a given threshold:

https://wolfram.com/xid/0btm879l391u-d94fll

Use a logical combination of conditions:

https://wolfram.com/xid/0btm879l391u-iqjzfa

StreamColorFunction (5)
Color streamlines according to the modulus of the function:

https://wolfram.com/xid/0btm879l391u-e4sh6h

Use any named color gradient from ColorData:

https://wolfram.com/xid/0btm879l391u-f801ty

Use ColorData for predefined color gradients:

https://wolfram.com/xid/0btm879l391u-idv8ij

Specify a color function that blends two colors by :

https://wolfram.com/xid/0btm879l391u-bs1k5d

Use StreamColorFunctionScalingFalse to get unscaled values:

https://wolfram.com/xid/0btm879l391u-c9impu

StreamColorFunctionScaling (3)
By default, scaled values are used:

https://wolfram.com/xid/0btm879l391u-iq62i

Use StreamColorFunctionScalingFalse to get unscaled values:

https://wolfram.com/xid/0btm879l391u-bgie6d

Explicitly specify the scaling for each color function argument:

https://wolfram.com/xid/0btm879l391u-sgjmk

StreamMarkers (8)
Streamlines are drawn as arrows by default:

https://wolfram.com/xid/0btm879l391u-b017eg

Use a named appearance to draw the streamlines:

https://wolfram.com/xid/0btm879l391u-bok3we

Use different markers for different vector fields:

https://wolfram.com/xid/0btm879l391u-ftomyx


https://wolfram.com/xid/0btm879l391u-jyfou


https://wolfram.com/xid/0btm879l391u-23ibf


https://wolfram.com/xid/0btm879l391u-g4h74a


https://wolfram.com/xid/0btm879l391u-vtl4r


https://wolfram.com/xid/0btm879l391u-gejl3s

StreamPoints (5)
Specify a specific maximum number of streamlines:

https://wolfram.com/xid/0btm879l391u-c5c0oi

Use symbolic names to specify the number of streamlines:

https://wolfram.com/xid/0btm879l391u-geue3

Use both automatic and explicit seeding with styles for explicitly seeded streamlines:

https://wolfram.com/xid/0btm879l391u-ep70lt

Specify the minimum distance between streamlines:

https://wolfram.com/xid/0btm879l391u-cjde0e

Specify the minimum distance between streamlines at the start and end of a streamline:

https://wolfram.com/xid/0btm879l391u-wct5n

StreamScale (9)
Create full streamlines without segmentation:

https://wolfram.com/xid/0btm879l391u-j161w7


https://wolfram.com/xid/0btm879l391u-eh4k4s

Use symbolic names to control the lengths of streamlines:

https://wolfram.com/xid/0btm879l391u-svqvf


https://wolfram.com/xid/0btm879l391u-e383cb

Specify an explicit dashing pattern for streamlines:

https://wolfram.com/xid/0btm879l391u-mac8w

Specify the number of points rendered on each streamline segment:

https://wolfram.com/xid/0btm879l391u-m3a973

Specify absolute aspect ratios relative to the longest line segment:

https://wolfram.com/xid/0btm879l391u-faumyt

Specify relative aspect ratios relative to each line segment:

https://wolfram.com/xid/0btm879l391u-dnmioy

Scale the length of the arrows by the :

https://wolfram.com/xid/0btm879l391u-fc8mb2

StreamStyle (5)
StreamColorFunction has precedence over StreamStyle for colors:

https://wolfram.com/xid/0btm879l391u-n4lsfw

Use StreamColorFunctionNone to specify colors with StreamStyle:

https://wolfram.com/xid/0btm879l391u-ba0idw

Apply a variety of styles to the streamlines:

https://wolfram.com/xid/0btm879l391u-eor2ph


https://wolfram.com/xid/0btm879l391u-vxtmo

Set the style for multiple functions:

https://wolfram.com/xid/0btm879l391u-b5akfh

Applications (10)Sample problems that can be solved with this function
Basic Applications (1)
Plot a function with a simple zero:

https://wolfram.com/xid/0btm879l391u-el66hl

Shift the function to the left by 1:

https://wolfram.com/xid/0btm879l391u-7vmnvd

Plot a function with a double zero:

https://wolfram.com/xid/0btm879l391u-o4wugl


https://wolfram.com/xid/0btm879l391u-3n0123

Plot a trigonometric function:

https://wolfram.com/xid/0btm879l391u-bqslq6

Plot a transcendental function:

https://wolfram.com/xid/0btm879l391u-ugvqo5

Plot a function with a simple pole:

https://wolfram.com/xid/0btm879l391u-9pflmy

Plot a function with a double pole:

https://wolfram.com/xid/0btm879l391u-g24tk7

Other Applications (9)
Streamlines that diverge from a point indicate a simple zero:

https://wolfram.com/xid/0btm879l391u-kqo55

Streamlines can also converge at a simple zero:

https://wolfram.com/xid/0btm879l391u-b1q3fe

With , the real vector field corresponding to the complex function
is
, and the trajectories that follow the field satisfy the differential equation
. The implicit solution is
for real
, which corresponds to a family of circles that are tangent to the real axis at the origin:

https://wolfram.com/xid/0btm879l391u-cuf3wr

In polar coordinates, the trajectories are for any real
:

https://wolfram.com/xid/0btm879l391u-cn4dq3

More generally, for where
is an integer, the streamlines follow
for constant
:

https://wolfram.com/xid/0btm879l391u-bwzc6v

https://wolfram.com/xid/0btm879l391u-emmuex


https://wolfram.com/xid/0btm879l391u-ot23l8

https://wolfram.com/xid/0btm879l391u-nszfte

Near a zero of order , the streamlines form loops that start and end at the zero in
directions:

https://wolfram.com/xid/0btm879l391u-fmojk3

https://wolfram.com/xid/0btm879l391u-67pivn

Near a pole of order , the streamlines converge to the pole from
directions and diverge from the pole from
directions:

https://wolfram.com/xid/0btm879l391u-l4anzv

https://wolfram.com/xid/0btm879l391u-wsq97d

The function has simple zeros at
and
, poles of order 1 at
, and a pole of order 2 at
:

https://wolfram.com/xid/0btm879l391u-gnwiie

Near an essential singularity, the streamlines vary wildly:

https://wolfram.com/xid/0btm879l391u-cm9kfm

Plot a function and its derivatives:

https://wolfram.com/xid/0btm879l391u-evzfai


https://wolfram.com/xid/0btm879l391u-psnks

Let be a complex potential for an ideal fluid flow. Then
is the velocity potential,
is the stream function, and the fluid velocity field is
. By the Cauchy–Riemann equations,
, so you can generate a stream plot with the conjugate of
. Show streamlines for flow around a cylinder with circulation:

https://wolfram.com/xid/0btm879l391u-k4956t

https://wolfram.com/xid/0btm879l391u-ecsfa0

Show streamlines for flow external to a corner:

https://wolfram.com/xid/0btm879l391u-u45qv

https://wolfram.com/xid/0btm879l391u-f9hfqx

Properties & Relations (15)Properties of the function, and connections to other functions
ComplexStreamPlot is a special case of StreamPlot:

https://wolfram.com/xid/0btm879l391u-cb87oq

ComplexVectorPlot plots complex numbers as vectors:

https://wolfram.com/xid/0btm879l391u-7studa

ComplexVectorPlot is a special case of VectorPlot:

https://wolfram.com/xid/0btm879l391u-cpan6o

Use VectorDisplacementPlot to visualize the effect of a complex function on a specified region:

https://wolfram.com/xid/0btm879l391u-kx8huh

Use VectorPlot3D and StreamPlot3D to visualize 3D vector fields:

https://wolfram.com/xid/0btm879l391u-h3ykri

ComplexContourPlot plots curves over the complexes:

https://wolfram.com/xid/0btm879l391u-pesif0

ComplexRegionPlot plots regions over the complexes:

https://wolfram.com/xid/0btm879l391u-ko83ut

ComplexPlot shows the argument and magnitude of a function using color:

https://wolfram.com/xid/0btm879l391u-e28611

Use ComplexPlot3D to use the axis for the magnitude:

https://wolfram.com/xid/0btm879l391u-vgce1e

Use ComplexArrayPlot for arrays of complex numbers:

https://wolfram.com/xid/0btm879l391u-p6xumo

Use ReImPlot and AbsArgPlot to plot complex values over the real numbers:

https://wolfram.com/xid/0btm879l391u-0vi62l


https://wolfram.com/xid/0btm879l391u-mqa938

Use ComplexListPlot to show the location of complex numbers in the plane:

https://wolfram.com/xid/0btm879l391u-wyd4bn

Use ListVectorPlot for plotting data:

https://wolfram.com/xid/0btm879l391u-czc8d0

https://wolfram.com/xid/0btm879l391u-bzenb8

Use ListStreamPlot to plot streams instead of vectors:

https://wolfram.com/xid/0btm879l391u-efbl3z

Use VectorDensityPlot to add a density plot of a scalar field:

https://wolfram.com/xid/0btm879l391u-gljrl7

Use StreamDensityPlot to use streams instead of vectors:

https://wolfram.com/xid/0btm879l391u-kxyms1

Use ListVectorDensityPlot to generate a density plot of a scalar field based on data:

https://wolfram.com/xid/0btm879l391u-2fsjy

https://wolfram.com/xid/0btm879l391u-b5me24

Use ListStreamDensityPlot to plot streams instead of vectors:

https://wolfram.com/xid/0btm879l391u-eootc

Use LineIntegralConvolutionPlot to plot the line integral convolution of a vector field:

https://wolfram.com/xid/0btm879l391u-c9d537

Wolfram Research (2020), ComplexStreamPlot, Wolfram Language function, https://reference.wolfram.com/language/ref/ComplexStreamPlot.html (updated 2020).
Text
Wolfram Research (2020), ComplexStreamPlot, Wolfram Language function, https://reference.wolfram.com/language/ref/ComplexStreamPlot.html (updated 2020).
Wolfram Research (2020), ComplexStreamPlot, Wolfram Language function, https://reference.wolfram.com/language/ref/ComplexStreamPlot.html (updated 2020).
CMS
Wolfram Language. 2020. "ComplexStreamPlot." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2020. https://reference.wolfram.com/language/ref/ComplexStreamPlot.html.
Wolfram Language. 2020. "ComplexStreamPlot." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2020. https://reference.wolfram.com/language/ref/ComplexStreamPlot.html.
APA
Wolfram Language. (2020). ComplexStreamPlot. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/ComplexStreamPlot.html
Wolfram Language. (2020). ComplexStreamPlot. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/ComplexStreamPlot.html
BibTeX
@misc{reference.wolfram_2025_complexstreamplot, author="Wolfram Research", title="{ComplexStreamPlot}", year="2020", howpublished="\url{https://reference.wolfram.com/language/ref/ComplexStreamPlot.html}", note=[Accessed: 04-April-2025
]}
BibLaTeX
@online{reference.wolfram_2025_complexstreamplot, organization={Wolfram Research}, title={ComplexStreamPlot}, year={2020}, url={https://reference.wolfram.com/language/ref/ComplexStreamPlot.html}, note=[Accessed: 04-April-2025
]}