Main Content

Binary Weighted DAC

N-bit DAC based on R-2R weighted resistor architecture

  • Library:
  • Mixed-Signal Blockset / DAC / Architectures

  • Binary Weighted DAC block

Description

The R-2R DAC is one of the most common types of Binary-Weighted DACs. It consists of a parallel binary-weighted resistor bank. Each digital level is converted to an equivalent analog signal by the resistor bank.

The input/output transfer curve of the binary weighted DAC can be nonmonotonic, which means that the transfer curve can reverse its direction.

The R-2R DAC architecture is low resolution and consumes more power due to the large number of resistors required to implement the architecture.

Ports

Input

expand all

Digital input signal to DAC, specified as an integer.

If theInput polarityparameter is set toBipolar, the allowed range of the signal is [−2NBits-1, 2NBits1]。

If theInput polarityparameter is set toUnipolar, the allowed range of the signal is [0, 2NBits-1].

Data Types:single|double|int8|int16|int32|uint8|uint16|uint32|fixed point

External clock to start conversion, specified as a scalar. The digital-to-analog conversion process starts at the rising edge of the signal at thestartport.

Dependencies

To enable this port, selectUse external start clockin theGeneraltab.

Data Types:double

Output

expand all

Converted analog output signal, returned as a scalar.

Data Types:double

Indicates whether the digital-to-analog conversion is complete, returned as a scalar.

Dependencies

To enable this port, selectShow ready portin theGeneraltab.

Data Types:double

Parameters

expand all

General

Number of bits in the input word, specified as a unitless positive real integer.Number of bitsdetermines the resolution of the DAC.

Programmatic Use

Block parameter:NBits
Type:character vector
Values:positive real integer
Default:5

Data Types:double

Polarity of the input signal to the DAC.

Programmatic Use

Block parameter:Polarity
Type:character vector
Values:Bipolar|Unipolar
Default:Bipolar

Select to connect to an external start conversion clock. By default, this option is selected. If you deselect this option, aSampling Clock Sourceblock inside the Segmented DAC is used to generate the start conversion clock

Frequency of the internal start conversion clock, specified as a real scalar in Hz. TheConversion start frequency参数确定圣的转化率art of conversion.

Dependencies

To enable this parameter, deselectUse external start clock.

Programmatic Use

Block parameter:StartFreq
Type:character vector
Values:positive real scalar
Default:1e6

Data Types:double

Reference voltage of the DAC, specified as a real scalar in volts.Reference (V)helps determine the output from the input digital code,Number of bits, andBias (V)using the equation:

DAC output = ( ( Digital input code 2 Number of bits ) Reference ) + Bias .

Programmatic Use

Block parameter:Ref
Type:character vector
Values:real scalar
Default:2

Data Types:double

Bias voltage added to the output of the DAC, specified as a real scalar in volts.Bias (V)helps determine the output from the input digital code,Number of bits, andReference (V)using the equation:

DAC output = ( ( Digital input code 2 Number of bits ) Reference ) + Bias .

Programmatic Use

Block parameter:Bias
Type:character vector
Values:real scalar
Default:0

Data Types:double

Select to enable thereadyport on the block. This option is deselected by default.

Impairments

Select to enable impairments such as offset error and gain error in DAC simulation. This parameter is selected. by default.

Shifts quantization steps by a specific value, specified as a scalar in %FS (percentage full scale), FS (full scale), or LSB (least significant bit).

Offset erroris applied beforeReference (V)andBias (V).

Dependencies

To enable this parameter, selectEnable linearity impairmentsin theImpairmentstab.

Programmatic Use

Block parameter:OffsetError
Type:character vector
Values:real scalar
Default:0 LSB

Data Types:double

Error in the slope of the straight line interpolating the DAC transfer curve, specified as a real scalar in %FS (percentage full scale), FS (full scale), or LSB (least significant bit).

Gain erroris applied beforeReference (V)andBias (V).

Dependencies

To enable this parameter, selectEnable linearity impairmentsin theImpairmentstab.

Programmatic Use

Block parameter:GainError
Type:character vector
Values:real scalar
Default:0 LSB

Data Types:double

Select to enable timing impairments such as settling time or slew rate in DAC simulation. This parameter is selected. by default.

Specify whether the Binary Weighted DAC calculates switch timing using the settling time parameters or the slew rate parameters.

Dependencies

To enable this parameter, selectEnable timing impairmentsin theImpairmentstab.

The time required for the output of the DAC to settle to within some fraction of its final value, specified as a nonnegative real scalar in seconds.

Dependencies

To enable this parameter, selectEnable timing impairmentsand setSpecify switch timing usingtoSettling timein theImpairmentstab.

Programmatic Use

Block parameter:SettlingTime
Type:character vector
Values:real scalar
Default:2e-7

Data Types:double

The tolerance allowed for calculating settling time, specified as a positive real scalar in LSB. The output of the DAC must settle within theSettling time tolerance (LSB)bySettling time (s).

Dependencies

To enable this parameter, selectEnable timing impairmentsand setSpecify switch timing usingtoSettling timein theImpairmentstab.

Programmatic Use

Block parameter:SettlingTimeTolerance
Type:character vector
Values:positive real scalar
Default:0.5

Data Types:double

Switch the rising slew rate for the DAC, specified as a positive real scalar or vector. IfRising slew rateis scalar, it specifies the same slew rate for all the switches. IfRising slew rateis a vector of lengthNbits, it specifies the slew rate for each individual switch.

Dependencies

To enable this parameter, selectEnable timing impairmentsand setSpecify switch timing usingtoSlew ratein theImpairmentstab.

Programmatic Use

Block parameter:RisingSlewRate
Type:character vector
Values:positive real scalar | positive real vector
Default:5015625

Switch the falling slew rate for the DAC, specified as a positive real scalar or vector. IfFalling slew rateis scalar, it specifies the same slew rate for all the switches. IfFalling slew rateis a vector of lengthNbits, it specifies the slew rate for each individual switch.

Dependencies

To enable this parameter, selectEnable timing impairmentsand setSpecify switch timing usingtoSlew ratein theImpairmentstab.

Programmatic Use

Block parameter:FallingSlewRate
Type:character vector
Values:negative real scalar | negative real vector
Default:-5015625

Version History

Introduced in R2020a