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




- ComplexVectorPlot is also known as field plot and direction plot.
- ComplexVectorPlot displays a vector field by drawing arrows. By default, the direction of the vector is indicated by the direction of the arrow, and the magnitude is indicated by its color.
- ComplexVectorPlot omits any arrows for which f does not evaluate to a complex number.
- ComplexVectorPlot[f,{z,n}] is equivalent to ComplexVectorPlot[f,{z,-n-n I,n+n I}].
- ComplexVectorPlot treats the variable z as local, effectively using Block.
- ComplexVectorPlot has attribute HoldAll and evaluates f only after assigning specific numerical values to z. In some cases, it may be more efficient to use Evaluate to evaluate f symbolically first.
- ComplexVectorPlot has the same options as Graphics, with the following additions and changes: [List of all options]
-
AspectRatio 1 ratio of height to width ClippingStyle Automatic how to display arrows outside the vector range 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 RegionFunction (True&) determine what region to include RegionBoundaryStyle Automatic how to style plot region boundaries RegionFillingStyle Automatic how to style plot region interiors VectorAspectRatio Automatic width to length ratio for arrows VectorColorFunction Automatic how to color arrows VectorColorFunctionScaling True whether to scale the argument to VectorColorFunction VectorMarkers Automatic shape to use for arrows VectorPoints Automatic the number or placement of arrows VectorRange Automatic range of vector lengths to show VectorScaling None how to scale the sizes of arrows VectorSizes Automatic sizes of displayed arrows VectorStyle Automatic how to style arrows WorkingPrecision MachinePrecision precision to use in internal computations - The individual arrows are scaled to fit inside bounding circles around each point.
- VectorPoints{c1,c2,…} uses the complex numbers c1, c2, etc.… as the points at which to draw the arrows.
- VectorScaling scales the magnitudes of the vectors into the range of arrow sizes smin to smax given by VectorSizes.
- VectorScaling->Automatic will scale the arrow lengths depending on the vector magnitudes:
- The arrow markers given by VectorMarkers are drawn inside a box whose width and length are in the proportion
specified by VectorAspectRatio.
- Common 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 - VectorColorFunction->None will draw the arrows with the style specified by VectorStyle.
- The arguments supplied to functions in RegionFunction and VectorColorFunction are z and 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 ClippingStyle Automatic how to display arrows outside the vector range 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 Ticks Automatic axes ticks TicksStyle {} style specifications for axes ticks VectorAspectRatio Automatic width to length ratio for arrows VectorColorFunction Automatic how to color arrows VectorColorFunctionScaling True whether to scale the argument to VectorColorFunction VectorMarkers Automatic shape to use for arrows VectorPoints Automatic the number or placement of arrows VectorRange Automatic range of vector lengths to show VectorScaling None how to scale the sizes of arrows VectorSizes Automatic sizes of displayed arrows VectorStyle Automatic how to style arrows WorkingPrecision MachinePrecision precision to use in internal computations



List of all options




Examples
open allclose allBasic Examples (3)Summary of the most common use cases
Plot the vector field for with color indicating the vector magnitude:

https://wolfram.com/xid/0n4i0sam2ea-6cxjl

Include a legend for the vector magnitudes:

https://wolfram.com/xid/0n4i0sam2ea-sgxlon

Use a drop-shaped marker to represent the vectors:

https://wolfram.com/xid/0n4i0sam2ea-62np7l

Scope (19)Survey of the scope of standard use cases
Sampling (7)
Plot a vector field with vectors placed with specified densities:

https://wolfram.com/xid/0n4i0sam2ea-bnkdo9

Sample the vector field on a regular grid of points:

https://wolfram.com/xid/0n4i0sam2ea-jnswso

Sample the vector field on an irregular mesh:

https://wolfram.com/xid/0n4i0sam2ea-gm12d0

Specify how many vector points to use in each direction:

https://wolfram.com/xid/0n4i0sam2ea-6tjb00

Plot the vectors that go through a set of seed points:

https://wolfram.com/xid/0n4i0sam2ea-bpn1i8

https://wolfram.com/xid/0n4i0sam2ea-howfal

Plot vectors over a specified region:

https://wolfram.com/xid/0n4i0sam2ea-lvahe5

Plot the fields for a function and its conjugate:

https://wolfram.com/xid/0n4i0sam2ea-zc12x

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

https://wolfram.com/xid/0n4i0sam2ea-dzznsr

Presentation (12)
Plot a vector field with automatically scaled arrows:

https://wolfram.com/xid/0n4i0sam2ea-bs9khg

Plot a vector field with arrows of specified size:

https://wolfram.com/xid/0n4i0sam2ea-3obw1y

Draw the arrows starting from the sample points:

https://wolfram.com/xid/0n4i0sam2ea-y0g4bu

https://wolfram.com/xid/0n4i0sam2ea-2zlizz

Draw the arrows without the arrowheads:

https://wolfram.com/xid/0n4i0sam2ea-fzve6t

Use drop-like shapes instead of arrows:

https://wolfram.com/xid/0n4i0sam2ea-1zp5de

Change the overall shape of the markers:

https://wolfram.com/xid/0n4i0sam2ea-oc0qdy

Change the default color function:

https://wolfram.com/xid/0n4i0sam2ea-v6aid7


https://wolfram.com/xid/0n4i0sam2ea-2kyz35

Vary the arrow sizes instead of the colors:

https://wolfram.com/xid/0n4i0sam2ea-cvzhyi

Set the style for multiple vector fields:

https://wolfram.com/xid/0n4i0sam2ea-n89e4w


https://wolfram.com/xid/0n4i0sam2ea-pblujj

Set the style for multiple vector fields:

https://wolfram.com/xid/0n4i0sam2ea-om0hcz

Use a theme with simple ticks and grid lines:

https://wolfram.com/xid/0n4i0sam2ea-fboha9

Options (65)Common values & functionality for each option
Background (1)
ClippingStyle (4)
By default, extremely short and extremely long vectors are displayed:

https://wolfram.com/xid/0n4i0sam2ea-dxfsnw

Use ClippingStyleNone to remove extreme vectors from the plot:

https://wolfram.com/xid/0n4i0sam2ea-f7s8c3


https://wolfram.com/xid/0n4i0sam2ea-edm9pg

Style the short and long clipped vectors differently:

https://wolfram.com/xid/0n4i0sam2ea-b6iwnl

EvaluationMonitor (2)
PlotLegends (5)
Include a legend for the vector norms:

https://wolfram.com/xid/0n4i0sam2ea-js95u9

Use the expressions in the legend for multiple vector functions:

https://wolfram.com/xid/0n4i0sam2ea-ba8k3h

Specify the legend labels for multiple functions:

https://wolfram.com/xid/0n4i0sam2ea-n2fvi5

Control the placement of the legend:

https://wolfram.com/xid/0n4i0sam2ea-cvx3dl

Use a legend with placeholders:

https://wolfram.com/xid/0n4i0sam2ea-m36w5m

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

https://wolfram.com/xid/0n4i0sam2ea-g6xoyw

Specify an explicit limit for both real and imaginary ranges:

https://wolfram.com/xid/0n4i0sam2ea-5on0y

Specify an explicit real range:

https://wolfram.com/xid/0n4i0sam2ea-i4n6y8

Specify an explicit imaginary range:

https://wolfram.com/xid/0n4i0sam2ea-xat4r

Specify different real and imaginary ranges:

https://wolfram.com/xid/0n4i0sam2ea-f1lr1g

PlotTheme (2)
RegionBoundaryStyle (5)
Show the region defined by a region function:

https://wolfram.com/xid/0n4i0sam2ea-d6s6um

The boundaries of full rectangular regions are not shown:

https://wolfram.com/xid/0n4i0sam2ea-7wf5ba

Use None to not show the boundary:

https://wolfram.com/xid/0n4i0sam2ea-d87zny

Omit the interior filling as well:

https://wolfram.com/xid/0n4i0sam2ea-gr12m6

Specify a style for the boundary:

https://wolfram.com/xid/0n4i0sam2ea-dd19je

Specify a style for full rectangular regions:

https://wolfram.com/xid/0n4i0sam2ea-ozzhd4

RegionFillingStyle (5)
Show the region defined by a region function:

https://wolfram.com/xid/0n4i0sam2ea-b1r4jl

The interiors of full rectangular regions are not shown:

https://wolfram.com/xid/0n4i0sam2ea-cxnsd5

Use None to not show the interior filling:

https://wolfram.com/xid/0n4i0sam2ea-clzxe7

Omit the boundary curve as well:

https://wolfram.com/xid/0n4i0sam2ea-f27m9u

Specify a style for the interior filling:

https://wolfram.com/xid/0n4i0sam2ea-uquau7

Specify a style for full rectangular region:

https://wolfram.com/xid/0n4i0sam2ea-f0shd2

RegionFunction (2)
VectorAspectRatio (2)
VectorColorFunction (5)
Vectors are colored according to their norms by default:

https://wolfram.com/xid/0n4i0sam2ea-b7adpr

Choose the color scheme for coloring vectors by their norms:

https://wolfram.com/xid/0n4i0sam2ea-cdiw5o

Use any named color gradient from ColorData:

https://wolfram.com/xid/0n4i0sam2ea-dsi8pl

Color the vectors according to the real part of its location:

https://wolfram.com/xid/0n4i0sam2ea-bw7lma

Color the vectors according to the real part of the function:

https://wolfram.com/xid/0n4i0sam2ea-lf15n

VectorColorFunctionScaling (2)
By default, scaled values are used:

https://wolfram.com/xid/0n4i0sam2ea-c7h4ae

Use VectorColorFunctionScalingFalse to get unscaled values:

https://wolfram.com/xid/0n4i0sam2ea-drzoi2

VectorMarkers (4)
Vectors are drawn as arrows by default:

https://wolfram.com/xid/0n4i0sam2ea-d31ee2

Use a named appearance to draw the vectors:

https://wolfram.com/xid/0n4i0sam2ea-kk973g

https://wolfram.com/xid/0n4i0sam2ea-et2q04

Use different markers for different vector fields:

https://wolfram.com/xid/0n4i0sam2ea-i7fp68

By default, markers are centered on vector points:

https://wolfram.com/xid/0n4i0sam2ea-dfllwr

https://wolfram.com/xid/0n4i0sam2ea-lfxai2

Start the vectors at the points:

https://wolfram.com/xid/0n4i0sam2ea-opwap5

End the vectors at the points:

https://wolfram.com/xid/0n4i0sam2ea-iweszu

VectorPoints (5)
Use automatically determined vector points:

https://wolfram.com/xid/0n4i0sam2ea-bkxnrk

Use symbolic names to specify the set of field vectors:

https://wolfram.com/xid/0n4i0sam2ea-dhad3u

Create a hexagonal grid of field vectors with the same number of arrows in the real and imaginary directions:

https://wolfram.com/xid/0n4i0sam2ea-lp1zg

Create a hexagonal grid of field vectors with a different number of arrows in the real and imaginary directions:

https://wolfram.com/xid/0n4i0sam2ea-e0q7cn

Specify a list of points for showing field vectors:

https://wolfram.com/xid/0n4i0sam2ea-fkgaai

VectorRange (6)
By default, vector ranges are determined automatically:

https://wolfram.com/xid/0n4i0sam2ea-fdojbp

Plot vectors with magnitudes between 0.2 and 2:

https://wolfram.com/xid/0n4i0sam2ea-m4l3r

Plot vectors with magnitudes between 0.2 and 2 with scaled arrow lengths:

https://wolfram.com/xid/0n4i0sam2ea-gthzzm


https://wolfram.com/xid/0n4i0sam2ea-y3wfh

Plot scaled vectors with all lengths:

https://wolfram.com/xid/0n4i0sam2ea-g9h1vr

Increase the lengths of the smaller vectors:

https://wolfram.com/xid/0n4i0sam2ea-fljz8c

VectorScaling (2)
By default, VectorScaling is None:

https://wolfram.com/xid/0n4i0sam2ea-ml02wa

Use automatic scaling to scale the length of vectors:

https://wolfram.com/xid/0n4i0sam2ea-84w8x5

VectorSizes (2)
Vector markers have automatically scaled lengths to prevent any vectors from being too small and to keep them from overlapping:

https://wolfram.com/xid/0n4i0sam2ea-c77jdr

Specify a minimum and maximum scaled vector size:

https://wolfram.com/xid/0n4i0sam2ea-c6wdj4

VectorStyle (6)
Set the style for the displayed vectors:

https://wolfram.com/xid/0n4i0sam2ea-hnrejz

Set the style for multiple functions:

https://wolfram.com/xid/0n4i0sam2ea-fqpqa1

Use Arrowheads to specify an explicit style of the arrowheads:

https://wolfram.com/xid/0n4i0sam2ea-bjd7u

Specify both arrow tail and head:

https://wolfram.com/xid/0n4i0sam2ea-f4aho

Graphics primitives without Arrowheads are scaled based on the vector scale:

https://wolfram.com/xid/0n4i0sam2ea-dmphsg

Change the scaling using the VectorScaling option:

https://wolfram.com/xid/0n4i0sam2ea-i0vjuu

Applications (7)Sample problems that can be solved with this function
For a complex function f, plot {Re[f],Im[f]}:

https://wolfram.com/xid/0n4i0sam2ea-de7yae

The vector length increases with Abs[f] and the orientation is determined by Arg[f]:

https://wolfram.com/xid/0n4i0sam2ea-c2tmq2

Identify poles and zeros. Poles are visible at and
:

https://wolfram.com/xid/0n4i0sam2ea-lm37cf

The zeros at and
are more readily visible if the vectors are scaled:

https://wolfram.com/xid/0n4i0sam2ea-bftb2b

Vectors in the field rotate twice along the unit circle surrounding the zero of the function at the origin, which implies that
has a double zero at the origin:

https://wolfram.com/xid/0n4i0sam2ea-gqfooa


https://wolfram.com/xid/0n4i0sam2ea-lftmd9

https://wolfram.com/xid/0n4i0sam2ea-dz4b1

The function has a pole of order 2 at
since
has a double zero:

https://wolfram.com/xid/0n4i0sam2ea-fb86wg

https://wolfram.com/xid/0n4i0sam2ea-g66tey

Specify a direction field and several solutions for the complex initial value problem ,
:

https://wolfram.com/xid/0n4i0sam2ea-fhs1yu

The Pólya field of an analytic function is both divergence and curl free:

https://wolfram.com/xid/0n4i0sam2ea-t15cu


https://wolfram.com/xid/0n4i0sam2ea-7ibeo



Examine partial sums of an infinite series:

https://wolfram.com/xid/0n4i0sam2ea-f2wpwi

https://wolfram.com/xid/0n4i0sam2ea-f0vzlx

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

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

ComplexStreamPlot plots complex numbers as streamlines:

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

ComplexStreamPlot is a special case of StreamPlot:

https://wolfram.com/xid/0n4i0sam2ea-c53rr6

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

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

Use VectorPlot3D and StreamPlot3D to visualize 3D vector fields:

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

ComplexContourPlot plots curves over the complexes:

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

ComplexRegionPlot plots regions over the complexes:

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

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

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

Use ComplexPlot3D to use the axis for the magnitude:

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

Use ComplexArrayPlot for arrays of complex numbers:

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

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

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


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

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

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

Use ListVectorPlot for plotting data:

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

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

Use ListStreamPlot to plot streams instead of vectors:

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

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

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

Use StreamDensityPlot to use streams instead of vectors:

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

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

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

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

Use ListStreamDensityPlot to plot streams instead of vectors:

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

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

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

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