## Design Guide: TIDM-02000 **Peak Current Mode Controlled PSFB Converter Reference Design Using C2000™ Real-time MCU**

# TEXAS INSTRUMENTS

## Description

This design implements a digitally peak current mode controlled (PCMC) phase shifted full bridge (PSFB) DC-DC converter that converts a 400-V DC input to a regulated 12-V DC output. Novel PCMC waveform generation based on type-4 PWM and internal slope compensation, and simple PCMC implementation are the highlights of this design. A TMS320F280049C MCU from the C2000 real-time microcontroller family is used in this design.

## Resources

| TIDM-02000                         |
|------------------------------------|
| TMS320F280049, SN74LVC2G74, TPS730 |
| ISO7242C, ISO7240C, ISO1050        |
| UCC27524, OPA345, DCH010505S       |
| C2000WARE-DIGITALPOWER-SDK         |

Design Folder Product Folder Product Folder Product Folder Tool Folder



Ask our TI E2E<sup>™</sup> support experts





## Features

- Peak current mode control (PCMC) with no external support circuitry for PCMC function
- Zero-voltage switching (ZVS) or low-voltage switching (LVS)
- Multiple synchronous rectification (SR) switching schemes

#### Applications

- Merchant Network and Server PSU
- Merchant Telecom Rectifiers
- Automotive

1



# 1 General Texas Instruments High Voltage Evaluation (TI HV EVM) User Safety Guidelines



Always follow TI's setup and application instructions, including use of all interface components within their recommended electrical rated voltage and power limits. Always use electrical safety precautions to help ensure your personal safety and those working around you. Contact TI's Product Information Center http:// support/ti./com for further information.

#### Save all warnings and instructions for future reference.

#### WARNING

Failure to follow warnings and instructions may result in personal injury, property damage or death due to electrical shock and burn hazards.

The term TI HV EVM refers to an electronic device typically provided as an open framed, unenclosed printed circuit board assembly. It is *intended strictly for use in development laboratory environments, solely for qualified professional users having training, expertise and knowledge of electrical safety risks in development and application of high voltage electrical circuits. Any other use and/or application are strictly prohibited by Texas Instruments.* If you are not suitable qualified, you should immediately stop from further use of the HV EVM.

- 1. Work Area Safety
  - a. Keep work area clean and orderly.
  - b. Qualified observer(s) must be present anytime circuits are energized.
  - c. Effective barriers and signage must be present in the area where the TI HV EVM and its interface electronics are energized, indicating operation of accessible high voltages may be present, for the purpose of protecting inadvertent access.
  - d. All interface circuits, power supplies, evaluation modules, instruments, meters, scopes and other related apparatus used in a development environment exceeding 50Vrms/75VDC must be electrically located within a protected Emergency Power Off EPO protected power strip.
  - e. Use stable and nonconductive work surface.
  - f. Use adequately insulated clamps and wires to attach measurement probes and instruments. No freehand testing whenever possible.
- 2. Electrical Safety

As a precautionary measure, it is always a good engineering practice to assume that the entire EVM may have fully accessible and active high voltages.

- a. De-energize the TI HV EVM and all its inputs, outputs and electrical loads before performing any electrical or other diagnostic measurements. Revalidate that TI HV EVM power has been safely de-energized.
- b. With the EVM confirmed de-energized, proceed with required electrical circuit configurations, wiring, measurement equipment connection, and other application needs, while still assuming the EVM circuit and measuring instruments are electrically live.
- c. After EVM readiness is complete, energize the EVM as intended.

#### WARNING

While the EVM is energized, never touch the EVM or its electrical circuits, as they could be at high voltages capable of causing electrical shock hazard.

- 3. Personal Safety
  - a. Wear personal protective equipment (for example, latex gloves or safety glasses with side shields) or protect EVM in an adequate lucent plastic box with interlocks to protect from accidental touch.

#### Limitation for safe use:

EVMs are not to be used as all or part of a production unit.



## **2 System Description**

Phase-shifted full bridge (PSFB) DC-DC converters are used frequently to step down high DC bus voltages and provide isolation in medium- to high-power applications like server power supplies, telecom rectifiers, battery charging systems, and renewable energy systems. Traditionally, microcontrollers have been restricted to only performing supervisory or communications tasks in these systems. With the availability of high-performing microcontroller devices, it is now possible to use microcontrollers for closing control loops in these systems, in addition to handling the traditional microcontroller functions. The transition to digital power control means that functions that were previously implemented in hardware are now implemented in software. In addition to the flexibility this adds to the system, this simplifies the system considerably. These systems can implement advanced control strategies to optimally control the power stage under different conditions and also provide system-level intelligence.

A PSFB converter consists of four power electronic switches (like MOSFETs or IGBTs) that form a full-bridge on the primary side of the isolation transformer and diode rectifiers, or MOSFET switches for synchronous rectification (SR) on the secondary side. This topology allows all the switching devices to switch with zero voltage switching (ZVS), resulting in lower switching losses and an efficient converter. In this reference design, ZVS for switches in the one leg of the full bridge, and zero or low-voltage switching for switches in the other leg, is achieved.

For such an isolated topology, signal rectification is required on the secondary side. For systems with low output voltage or high output current ratings, implementing synchronous rectification instead of diode rectification achieves the best possible performance by avoiding diode rectification losses. In this design, current doubler synchronous rectification is implemented on the secondary side with different switching schemes to achieve optimum performance under varying load conditions.

A DC-DC converter system can be controlled in various modes, like voltage mode control (VMC), average current mode control (ACMC), or peak current mode control (PCMC). PCMC is a highly desired control scheme for power converters because of its inherent voltage feed forward, automatic cycle-by-cycle current limiting, flux balancing, and other advantages.

Implementing PCMC for a PSFB system requires complex PWM waveform generation with precise timing control. A new approach to this waveform generation is presented using TMS320F28004x (Texas Instruments Piccolo<sup>™</sup> series) microcontrollers without requiring any additional support circuitry. Unique programmable onchip slope compensation hardware is used to provide appropriate slope compensation that ensures open-loop stability and eliminates/limits subharmonic oscillations at the output. The delayed trip function in type-4 PWM helps implement the dead band with PCMC easily without occupying much CPU resources. This is explained in detail in this reference design guide. This design uses the same hardware (TIDM-BIDIR-400-12) with some modification as described in the next chapters.

3



## 2.1 Key System Specifications

#### Table 2-1. Key System Specifications

| PARAMETER               | SPECIFICATION       |  |
|-------------------------|---------------------|--|
| INPUT CONDITIONS        |                     |  |
| Input voltage           | 200 V DC - 400 V DC |  |
| Input current           | 0.75A - 1.5A        |  |
| OUTPUT CONDITIONS       |                     |  |
| Output voltage          | 12 V                |  |
| Output current          | 25A                 |  |
| Power rating            | 300W                |  |
| SYSTEM CHARACTERISTICS  |                     |  |
| Efficiency              | 91.5% (peak)        |  |
| PWM switching frequency | 100kHz              |  |



**3 System Overview** 

## 3.1 Block Diagram



Figure 3-1. TIDM-02000 Block Diagram

## 3.2 Design Considerations

#### 3.2.1 Basic Operation

A PSFB converter consists of four-power electronic switches (like MOSFETs or IGBTs) that form a full-bridge on the primary side of the isolation transformer and diode rectifiers or MOSFET switches for synchronous rectification (SR) on the secondary side. This topology allows the switching devices to switch with zero voltage switching (ZVS) resulting in lower switching losses and an efficient converter.

For such an isolated topology, signal rectification is required on the secondary side. For systems with low output voltage and/or high output current ratings, implementing synchronous rectification instead of diode rectification achieves the best possible performance by avoiding diode rectification losses. In this work, synchronous rectification is implemented on the secondary side.

5



Figure 3-2. A Phase-Shifted Full Bridge Circuit

Figure 3-2 shows a simplified circuit of a phase shifted full-bridge. MOSFET switches  $Q_1$ ,  $Q_4$ ,  $Q_2$  and  $Q_3$  form the full-bridge on the primary side of the transformer T1.  $Q_1$  and  $Q_4$  are switched at 50 % duty and 180 degree out of phase with each other. Similarly,  $Q_2$  and  $Q_3$  are switched at 50 % duty and 180 degree out of phase with each other. The PWM switching signals for leg  $Q_2 - Q_3$  of the full-bridge are phase shifted with respect to those for leg  $Q_1 - Q_4$ . Amount of this phase shift decides the amount of overlap between diagonal switches, which in turn decides the amount of energy transferred.  $D_5$ ,  $D_6$  provide diode rectification on the secondary(MOSFETs used in our design for SR), while  $L_0$  and  $C_0$  form the output filter. Shim inductor  $L_R$  provides assistance to the transformer leakage inductance for resonance operation with MOSFET capacitance and facilitates Zero Voltage Switching (ZVS). The switching waveforms for the system are shown in Figure 3-3.



Figure 3-3. PSFB PWM Waveforms

## 3.2.2 PCMC PSFB using C2000

6

In the system, there are four MOSFET switches (Q1-Q4) that form a full-bridge on the HV side of the isolation transformer and two MOSFET switches (Q5-Q6) on the center-tapped LV side that work as synchronous rectifiers.

Phase shift between PWM signals driving the two legs of the full bridge determines the amount of energy transferred to the load. Controlling such a system in PCMC mode requires generating complex PWM drive waveforms along with fast and efficient control loop calculations. This is made possible on C2000 microcontrollers by advanced on-chip control peripherals like PWM modules, analog comparators with DAC and slope compensation hardware and 12-bit high speed ADCs coupled with an efficient 32-bit CPU. A detailed description of the software algorithm is provided in the following chapters.



## 3.3 System Design Theory

#### 3.3.1 Peak Current Mode Control (PCMC) Implementation

Implementing PCMC for a PSFB system requires complex PWM waveform generation with precise timing control. The Piccolo family of devices from Texas Instruments feature advanced on-chip control peripherals that make this implementation possible without any external support circuitry for this purpose. These peripherals include on-chip analog comparators, digital-to-analog converters (DAC), advanced PWM resources and unique programmable on-chip slope compensation hardware. Figure 3-4 shows the PCMC implementation. Transformer primary current is compared with the peak current reference calculated by the voltage loop using the on-chip comparator.

In every half of the switching cycle when the transformer primary current reaches the commanded peak reference value, one of the PWM waveforms driving the switches (Q2/Q3) is *Reset* immediately ending the power transfer phase. The PWM waveform driving the other switch in the same leg is *Set* after a programmable dead-time (dead-band) window. Appropriate slope compensation is also applied that adds a ramp with a programmable negative slope to the peak reference current signal.

The *Resetting* and *Setting* action of the PWMs in one leg results in a phase shift between PWM signals driving the two legs. The amount of this phase shift, and thereby the overlap between diagonal switches, is dependent on the amount of peak reference current. Higher the peak reference current, longer the overlap between diagonal switches, and thereby, more the energy transferred to the secondary. The controller regulates the output by controlling this energy transfer by way of controlling the peak reference current value. Thus this peak reference current is the controlled parameter.

An important feature of this implementation is that the same peak reference current command is used for both halves of the switching cycle under all operating conditions. This provides optimal flux balance for the transformer primary reducing any chances of saturation.

7







The EPWM1A and EPWM1B outputs are complimentary and 50% duty cycle are maintained based on the action qualifier and deadband settings. The EPWM2A/B\_AQ (action qualifier output) is set to 1 when T1U(T1 with counter counting up) event occurs and when counter reaches PRD. The EPWM2A AQ is set to 0 when T1D (T1 with counter counting down) event occurs and when counter reaches ZERO. The T1D and T1U events are triggered by DCAEVT2.

Texas

With type-4 PWM, the deadband can be directly added to T1U and T1D events without adding extra code configurations. The rising edge delay is inserted for EPWM2A. And falling edge delay is inserted for EPWM2B together with inversion accordingly.

To achieve the quickest response, the trip zone modules are utilized to setup the falling edge for EPWM2A (with TZAD event) and EPWM2B (with TZBU event) output. The cycle by cycle trip is implemented and is required to be cleared on ZERO and PRD event.

## 3.3.2 Zero Voltage Switching (ZVS) or Low Voltage Switching (LVS)

PSFB DC-DC converters make use of parasitic elements in the circuit to ensure zero voltage across the MOSFET switches before turning them ON, providing soft switching. This considerably reduces the amount of switching losses associated with hard switching.

For the system discussed here, switching transitions for switches in the Q2- Q3 leg end the power transfer interval. Therefore this leg is called the *Active to Passive* leg. When transitions occur for switches in this leg, current in the primary winding is close to its maximum magnitude for that half PWM switching cycle. The reflected load current aids the circulating energy in the primary circuit during this time, which makes it possible for voltage across switches in this leg to approach zero volts. It is possible to achieve ZVS for switches in this Q2-Q3 leg across the complete load range. It should be noted that as the load decreases the amount of dead-time needs to be increased to achieve/approach ZVS.

Switching transitions for switches in the Q1- Q4 leg start the power transfer interval. Therefore this leg is called the *Passive to Active* leg. During these switching transitions, primary current decreases. It crosses zero current value and changes direction. This results in lower available energy for ZVS. In fact for operations under low load conditions, voltage across these switches may not go to zero before turning them on. Switching losses can be kept to a minimum by turning these switches ON at a time when the voltage across them is at a minimum. This is called Low Voltage Switching or low voltage switching (LVS). As the load changes the time at which the switch should be turned on to achieve LVS changes, requiring dead-time adjustment similar to the Q2-Q3 leg switches.

## 3.3.3 Synchronous Rectification



## Figure 3-5. Synchronous Rectification mode

Synchronous rectifiers can work in one of the following three modes at any given time:

1. **Mode 0:** This is the classical diode current doubler mode achieved by keeping synchronous rectifiers turned OFF. It is useful for very low load operations where synchronous rectifier switching losses are greater than the power savings obtained by synchronous rectification.

9



- 2. **Mode 1:** In this mode the synchronous rectifier switches behave like ideal diodes. This mode is useful when operating at very low to low loads, typically when burst mode is being used. In this mode, synchronous rectifier MOSFETs are ON only when the corresponding diagonal bridge drive signals overlap.
- 3. **Mode 2:** Useful for all other load conditions. In this mode, synchronous rectifier MOSFETs are OFF only when the corresponding opposite diagonal bridge drive signals overlap.

Figure 3-5 depict waveforms generated for driving the synchronous rectifier switches in these modes. It is important to implement mode transitions seamlessly without any glitches or anomalies on the PWM outputs even during large load transients or sudden phase shift change commands to ensure safe operation of the system.

#### 3.3.4 Slope Compensation

The peak current reference command is written to the RAMPMAXREFS which is the starting value of the RAMP used for slope compensation. The slope is decided by RAMPDACVALS. The ramp generator produces a falling-ramp input for the high reference 12-bit DAC when selected. Note that in this mode, the reference 12-bit DAC uses the most significant 12 bits of the RAMPSTS countdown register as its input. The low 4 bits of the RAMPSTS countdown register effectively act as a prescale for the falling-ramp rate configurable with RAMPDECVALA.

In this reference design, The slope is chosen based on two factors: stability and transient response. The empirical value used in the design should make the system stable and also does not sacrifice the transient response. If the slope is too large, it will limit the duty cycle available and will decreases the transient response. If the slope is too small, it will trigger the sub-harmonics oscillation which creates unstable conditions.

## 3.4 Highlighted Products

### 3.4.1 C2000™ MCU F28004x

C2000 MCUs are part of an optimized MCU family for real-time control application. Fast and high-quality analog-to-digital controller enables accurate measurement of the current and voltage signals, and an integrated comparator subsystem (CMPSS) provides protection for overcurrent and overvoltage without use of any external devices. The optimized CPU core enables fast execution of control loop. Trigonometric operations are accelerated using the on-chip trigonometric math unit (TMU). The solution also provides an option to use the control law accelerator (CLA) on the F28004x. The CLA is a co-processor that can be used to alleviate CPU burden and enable faster-running loops or more functions on the C2000 MCU.



## 4 Hardware, Software, Testing Requirements, and Test Results

## 4.1 Required Hardware and Software

## 4.1.1 Hardware

Figure 4-1 shows key hardware components. This hardware uses the kit of Bidirectional 400-V/12-V DC/DC Converter Reference Design as the base board and with some modification for peak current mode control.



Low voltage side

High voltage side

Figure 4-1. TIDM-02000 hardware

The key signal connections between the controlCARD and the base board are listed in the Table 4-1

| SIGNAL NAME | DESCRIPTOIN                                               | CONNECTION TO<br>CONTROLCARD |
|-------------|-----------------------------------------------------------|------------------------------|
| ePWM-1A     | PWM drive for full-bridge switch Q2                       | GPIO-00                      |
| ePWM-1B     | PWM drive for full-bridge switch Q3                       | GPIO-01                      |
| ePWM-2A     | PWM drive for full-bridge switch Q1                       | GPIO-02                      |
| ePWM-2B     | PWM drive for full-bridge switch Q4                       | GPIO-03                      |
| ePWM-4A     | PWM drive for sync rectifier/push-pull switch Q6          | GPIO-07                      |
| ePWM-4B     | PWM drive for sync-rectifier/push-pull switch Q5          | GPIO-06                      |
| VLV-FB      | Low voltage bus – voltage feedback                        | ADC-A0                       |
| ILV-FB      | Low voltage current feedback (Jumper J2 populated)        | ADC-B3/COMP2A                |
| ILV-FILT    | Heavily filtered low voltage current feedback             | ADC-B2                       |
| VHV-FB      | High voltage bus – voltage feedback                       | ADC-B1                       |
| IHV-FB      | Transformer high voltage winding current                  | ADC-A2/COMP1A                |
| IHV-FILT    | Heavily filtered transformer high voltage winding current | ADC-A1                       |

### Table 4-1. Key Signal Connections

This board provides a lot of jumper options for experimentation but there are some jumpers that must be populated for proper operation of the board. These jumpers that must be populated are listed below:



C:JPG1, E:JPG1, J2, J5, J6, J7, J8, J10, J11, J12, J13, J15, J16, and J19.

Some hardware modifications are required by the customer before running the reference code in this board.



Figure 4-2. Peak Current Sensing Circuit

1. Remove resistor R50 in Figure 4-2. The heavily filtered winding current of the CT on the secondary side is used for average current mode control. For peak current mode control, a relatively low cutoff frequency filter is needed. Existence of R50 can introduce distortion to the current waveform.

Notes: Some magnetic components in the original board are replaced for peak current mode control as shown in Table 4-2.

|                         | CURRENT     | ORIGINAL       |
|-------------------------|-------------|----------------|
| Main transformer        | MPS P6524_A | VITEC AF5551R  |
| Secondary side inductor | VITEC 6193R | VITEC AF5666BR |
| Shim inductor           | VITEC 6194R | VITEC AF5667BR |

#### Table 4-2. Current and Original magnetic Components

#### ControlCARD settings:

Certain settings on the device control card are required to communicate over JTAG and use the isolated UART port. The user must also provide a correct ADC reference voltage. The following settings are required for revision A of the TMS320F280049C control card (refer to the info sheet located at \c2000ware\boards\controlCARDs\TMDSCNCD280049C.

- Set both ends of S1:A on the control card to ON (up) position to enable JTAG connection to the device and UART connection for SFRA GUI. If this switch is OFF (down), the user cannot use the isolated JTAG built in on the control card, nor can the SFRA GUI communicate with the device.
- 2. Connect the USB cable to J1:A to communicate with the device from a host PC on which CCS runs.
- 3. For the control loop, use the internal reference of the TMS320F28004x and move the S8 switch to the left (that is, pointing to VREFHI).
- 4. For best performance of this reference design, remove the capacitor connected between the isolated grounds on the control card, C26:A.



#### 4.1.2 Software

4.1.2.1 Software Control Flow



Figure 4-3. Project Structure Overview

Solution specific and device independent files are <solution>.c/h. Board-specific and device-specific files are <solution>\_hal.c/h. The main.c file of the project consists of the main function of the C project as well as ISR framework and calls routines in other files. <solution>\_settings.h and <solution>\_user\_settings.h consist of all the settings required for the solution.

<solution>\_user\_settings.h For this design, <solution> is psfbpcmc.

<solution>\_clatask.cla file include the CLA Task definitions.

The powerSUITE page can be opened by clicking the main.syscfg file, listed below the project explorer.

The powerSUITE page generates the <solution>\_settings.h file. This file is the only file used in the compile of the project that is generated by the powerSUITE page. The user must not modify this file manually, as the changes will be overwritten by powerSUITE each time the project is rebuilt. The changes will only happen after rebuilding the entire project TheKit.json and solution.js files are used internally by the powerSUITE and must also not be modified by the user. Any changes to these files will result in the project not functioning properly.





Figure 4-4. PCMC Software Flow

In Figure 4-4, the project consists of an interrupt service routine, which is called every PWM cycle, called ISR1(), where the control algorithm is executed. In addition to this, there are background tasks, which are called in a polling fashion and can be used to run slow tasks for which absolute timing accuracy is not required.

The system is controlled by two feedback loops; an outer voltage loop, implemented using software control block, and an inner peak current loop, implemented using the on-chip analog comparator, DAC and PWM hardware resources. The voltage loop controller is executed at a rate of 100 kHz (same as the PWM frequency).



#### 4.1.2.2 Incremental Builds

This project is divided into two incremental builds. This makes it easier to learn and get familiar with the board and the software. This approach is also good for debugging/testing boards.

The build options are shown in Table 4-3. To select a particular build option, open the main.syscfg and select the INCR\_BUILD to the corresponding build selection as shown below. Once the build option is selected in powerSUITE page and save button is clicked, compile the complete project by selecting rebuild-all compiler option. Next chapter provides more details to run each of the build options.

| Table 4-3. Incremental Build Options |                                                                                                                        |  |
|--------------------------------------|------------------------------------------------------------------------------------------------------------------------|--|
| Incremental Build Options            |                                                                                                                        |  |
| INCR_BUILD = 1                       | Peak current loop check with constant I command and open voltage<br>loop (Check PWM drive circuit and sensing circuit) |  |
| INCR_BUILD = 2                       | Closed current and voltage loop (Full PSFB)                                                                            |  |

#### 4.1.2.3 Procedure for running the incremental builds - PCMC

#### CAUTION

There are high voltages present on the board. It should only be handled by experienced power supply professionals in a lab environment. To safely evaluate this board an appropriate isolated high voltage DC source should be used. Before DC power is applied to the board a voltmeter and an appropriate resistive or electronic load must be attached to the output. The unit should never be handled when the power is applied to it.

#### 4.1.2.3.1 Build 1: Peak Current Loop Check with Open Voltage Loop

#### 4.1.2.3.1.1 Objective

The objective of this build is to evaluate the peak current mode operation of the system, verify the DAC and ADC driver modules, verify the MOSFET driver circuit and sensing circuit on the board and become familiar with the operation of Code Composer Studio (CCS). Since this system is running open-loop, the ADC measured values are only used for instrumentation purposes in this build. Steps required to build and run a project will be explored.

#### 4.1.2.3.1.2 Overview

The software in Build1 has been configured so that the user can quickly evaluate the DAC driver module by viewing various waveforms on an oscilloscope and observing the effect of change in peak current reference command on the output voltage by interactively adjusting this command from CCS. Additionally, the user can evaluate the ADC driver module by viewing the ADC sampled data in the watch view.

The on-chip analog comparator compares the transformer primary current with the slope compensated peak current reference. Comparator output is connected to the trip zone logic of the PWM modules. ePWM1 module acts as the master time-base for the system. It operates in up-down count mode. ePWM1A and ePWM1B drive Q1 and Q4 full-bridge switches, while ePWM2A and ePWM2B drive Q2 and Q3 full-bridge switches. ePWM4A and ePWM4B drive Q5 and Q6 synchronous rectifier switches. Whenever the comparator output goes high in a PWM half cycle, the ePWM2 module output (ePWM2A or ePWM2B) which was high at that instant is immediately pulled low while the other PWM2 module output is pulled high after an appropriate dead-band window (dbAtoP). ePWM4A and ePWM4B outputs are driven in a similar way.

It should be noted that this slope compensation ramp generation, comparator action and PWM waveform generation are all hardware generated without any software involvement as shown in Figure 4-5. Some register reconfigurations for SR are done inside the ISR.





#### Figure 4-5. Build 1 Software Blocks

The output voltage sensing circuit is made up of simple voltage dividers. A current transformer, and a sense resistor are used to sense the full-bridge transformer primary current.



#### 4.1.2.3.1.3 Procedure

#### 4.1.2.3.1.3.1 Start CCS and Open a Project

To quickly execute this build, follow the following steps:

- 1. Make sure that all jumpers on the board are correctly installed or removed as listed in the Hardware section.
- Hardware Set-up: Insert the F28004x controlCARD in the 100-pin DIMM connector. Connect a 12 V DC bench power supply between TP10 and TP11 with correct polarity. Connect an isolated 400V programmable DC power source to the 400 V input connector and 12 V electronic load to the 12 V connector (make sure that this load does not exceed the board ratings). Connect a USB cable between the PC and controlCARD. Do not turn ON any of the power supplies at this time.
- 3. Open Code Composer Studio. Maximize Code Composer Studio to fill your screen. Close the welcome screen if it opens up.
- 4. locate the solution package downloaded and import the project in CCS
- 5. In the project window on the left, click the plus sign (+) to the left of Project. Your project window will look like the following:



#### Figure 4-6. Project Window



#### 4.1.2.3.1.3.2 Build and Load the Project

- 1. Open the main.syscfg and select *Open Loop* in INCR\_BUILD. Click Save.
- 2. Right click the project name *PCMC\_PSFB\_F28004x* and click *rebuild project*. Open the psfbpcmc\_settings.h as shown in Figure 4-7. You should see the setting is #define INCR\_BUILD 1. This enables the build 1 solution.
- 3. Also set #define PSFB\_PCMC 1 in the psfbpcmc\_user\_settings.h. For build 1, this will disable the *phase shift debug mode*.

#### Note

To enable the *phase shift debug mode* under build 1, set #define PSFB\_PCMC 0. *phase shift debug mode* is an optional and suggested debug mode to test whether the power stage is working normally before build 1. It can directly set up the phase shift between EPWM1 and EPWM2 through *PSFB\_PhaseShift* in the expression window. After PSFB\_enable is set to 1 and the project is running, user can change the *PSFB\_PhaseShift* to set up different phase shift (for example: 100). Gradually increase the DC input to 400 V. If all PWMs, voltage across the transformer and output voltage are as expected, it means the power stage is fine.

- 4. Turn ON the 12 V DC bench power supply. Click on the Debug button. The build 1 code should compile and load.
- 5. Notice the CCS Debug icon in the upper right corner indicating that we are now in the Debug Perspective view. The program should be stopped at the start of *main()*



Figure 4-7. Project Window

#### 4.1.2.3.1.3.3 Debug Environment Windows

Populate the expressions window entries by clicking *scripting console* on the menu bar and then opening the *setupdebugenv\_allbuilds.js* file from the project workspace directory (PCMC\_PSFB\_F28004x\setupdebugenv\_allbuilds.js) using the scripting console *Open File* () command. Please note that some of the variables have not been initialized at this point in the main code and may contain some garbage values.



#### 4.1.2.3.1.3.4 Using Real-Time Emulation

Real-time emulation is a special emulation feature that allows the windows within Code Composer Studio to be updated at up to a 10 Hz rate while the MCU is running. This not only allows graphs and watch views to update, but also allows the user to change values in watch or memory windows, and have those changes affect the MCU behavior. This is very useful when tuning control law parameters on-the-fly, for example.

1. Enable real-time mode by hovering your mouse on the buttons on the horizontal toolbar and clicking
Enable Silicon Real-time Mode (service critical interrupts when halted, allow)

debugger accesses while running) button

- 2. A message box may appear. If so, select YES to enable debug events. This will set bit 1 (DGBM bit) of status register 1 (ST1) to a "0". The DGBM is the debug enable mask bit. When the DGBM bit is set to "0", memory and register values can be passed to the host processor for updating the debugger windows.
- 3. Now click Plant Polite Real-time Mode button on the same horizontal toolbar.
- 4. When a large number of windows are open, as bandwidth over the emulation link is limited, updating too many windows and variables in continuous refresh can cause the refresh frequency to bog down. Right

click on the button in the watch view and select "Customize Continuous Refresh Interval..". You can slow down the refresh rate for the watch view variables by changing the Continuous refresh interval (milliseconds) value. A rate of 4000 ms is usually enough for these exercises.

5. Click on Continuous Refresh button <sup>997</sup> for the watch view.

#### 4.1.2.3.1.3.5 Run the Code

| (x)= Variables                    | 8 Registers              |              | 🗶 👧 🖂 🕂 💥 💥 🚱 📑 🖻 🍫 👘 🗖 |
|-----------------------------------|--------------------------|--------------|-------------------------|
| Expression                        | Туре                     | Value        | Address                 |
| (x)= PSFB_gui_icommand_Set_Amps   | ; float                  | 0.5          | 0x0000801E@Data         |
| (x)= PSFB_icommand_Set_pu         | float                    | 0.0737463087 | 0x0000801C@Data         |
| (x)= Cmpss1Regs.RAMPMAXREFS.RA    | AN <16-bit unsigned>     | 0x0970       | bit 0-15                |
| (x)= PSFB_gui_ocpThreshold_Amps   | float                    | 4.0          | 0x00008034@Data         |
| (x)= PSFB_gui_ovpThreshold_Volts  | float                    | 14.0         | 0x00008036@Data         |
| (x)= PSFB_closeGiLoop             | int                      | 0            | 0x00008004@Data         |
| (x)= PSFB_closeGvLoop             | int                      | 0            | 0x00008005@Data         |
| (x)= PSFB_guilHV_Amps             | float                    | 0.230083019  | 0x0000802A@Data         |
| (x)= PSFB_guiLVbus_Volts          | float                    | 0.559641123  | 0x00008026@Data         |
| (x)= PSFB_ovp_Fault               | int                      | 0            | 0x0000800C@Data         |
| (x)= PSFB_ocp_Fault               | int                      | 0            | 0x0000800D@Data         |
| (x)= Cmpss1Regs.COMPDACCTL.RAM    | vl <16-bit unsigned> : 4 | 0x2          | bit 1-4                 |
| (x)= PSFB_slope                   | unsigned int             | 30           | 0x00008066@Data         |
| (x)= PSFB_guivLVBus_Set_Volts     | float                    | 2.0          | 0x0000802E@Data         |
| (x)= PSFB_guivLVBus_SlewedSet_Vol | It: float                | 0.0          | 0x00008030@Data         |
| (x)= PSFB_start_flag              | int                      | 0            | 0x0000800A@Data         |
| (x)= PSFB_enable                  | int                      | 1            | 0x00008008@Data         |
| (x)= EPwm1Regs.DBRED.DBRED        | <16-bit unsigned> : 14   | 0x028        | bit 0-13                |
| (x)= EPwm 1Regs.DBFED.DBFED       | <16-bit unsigned> : 14   | 0x02C        | bit 0-13                |
| (x)= EPwm2Regs.DBRED.DBRED        | <16-bit unsigned> : 14   | 0x028        | bit 0-13                |
| (x)= EPwm2Regs.DBFED.DBFED        | <16-bit unsigned> : 14   | 0x02C        | bit 0-13                |
| (x)= EPwm4Regs.DBRED.DBRED        | <16-bit unsigned> : 14   | 0x01C        | bit 0-13                |
| (x)= EPwm4Regs.DBFED.DBFED        | <16-bit unsigned> : 14   | 0x01C        | bit 0-13                |
| (x)= PSFB_cntlMax                 | float                    | 0.300000012  | 0x00008010@Data         |
| (x)= PSFB_cntlMin                 | float                    | -0.050000007 | 0x00008012@Data         |

#### Figure 4-8. Build 1 Expression Window

- 1. Run the code by using the <F8> key, or using the Run button on the toolbar.
- 2. Apply an appropriate resistive load to the PSFB system at the DC output. A load that draws around 3A 6A current at 12 V output is a good starting point.
- 3. Set PSFB\_gui\_icommand\_Set\_Amps to be 0.5.
- 4. Set PSFB\_enable to be 1. This enables PWM output. The expression window is similar to Figure 4-8.
- 5. Power the input at J1, J2 with 390 V DC. The output will be around 1.6 V (5A constant current load).
- 6. Slowly increase PSFB\_gui\_icommand\_Set\_Amps to be 2.35 in increments of 0.05. Carefully observe the output voltage(PSFB\_guiLVbus\_Volts), the voltage should gradually increase to 12 V. This should not be allowed to exceed the capabilities of the board. Different waveforms, like the PWM gate drive signals, input voltage and current and output voltage may also be probed using an oscilloscope. Appropriate safety precautions should be taken and appropriate grounding requirements should be considered while probing these high voltages and high currents for this isolated DC-DC converter.
- 7. The PSFB\_slope is set to be 30. User can gradually increase or decrease it for testing.

8. Fully halting the MCU when in real-time mode is a two-step process. With the 400 V DC input turned off wait a few seconds. First, halt the processor by using the Halt button on the toolbar, or by using Target > Halt.

Then click the button again to take the MCU out of real-time mode and then reset the MCU.



#### 4.1.2.3.2 Build 2: Closed current and voltage loop (Full PSFB)

#### 4.1.2.3.2.1 Objective

The objective of this build is to verify the operation of the complete PCMC based HVPSFB project from the CCS environment.

#### 4.1.2.3.2.2 Overview

Figure 4-9 shows the software blocks used in this build. A two pole two zero controller is used for the voltage loop. As shown in Figure 4-9, the voltage loop block is executed at 100 KHz. The DCL\_runClamp\_C1 function is used to avoid controller wind-up condition. The DCL\_runDF22\_C2 computes the immediate part of the precomputed DF22 controller. If this value is larger than the max or less than min threshold, a flag will be set with DCL\_runClamp\_C1 function. This stops the further controller saturation. Once the flag is off, DCL\_runDF22\_C3 will compute the partial result of the pre-computed DF22 controller. More information on how the DCL function works could be found inside DCL user's guide in C2000ware.



## Figure 4-9. Build 2 Software Block

#### 4.1.2.3.2.3 Procedure

#### 4.1.2.3.2.3.1 Build and Load Project

To quickly execute this build using the pre-configured work environment, follow the following steps:

- 1. Open the main.syscfg and select *Closed Voltage Loop* in INCR\_BUILD. Click Save.
- 2. Right click the project name *PCMC\_PSFB\_F28004x* and then click *rebuild project*. Open the psfbpcmc\_settings.h. You should see the setting is #define INCR\_BUILD 2. This enables the build 2 solution.
- 3. Turn ON the 12 V DC bench power supply. Click the Debug button. The build 2 code should compile and load.
- 4. Notice the *CCS Debug* icon in the upper right side indicating that we are now in the *Debug Perspective* view. The program should be stopped at the start of *main()*.

#### 4.1.2.3.2.3.2 Debug Environment Windows

 Populate the expressions window entries by clicking on 'View - Scripting console' on the menu bar and then opening the "setupdebugenv\_allbuilds.js" file from the project workspace directory (PCMC\_PSFB\_F28004x\setupdebugenv\_allbuilds.js) using the scripting console 'Open File' ( )command. Please note that some of the variables have not been initialized at this point in the main code and may contain some garbage values.

#### 4.1.2.3.2.3.3 Run the Code

- 1. Follow Steps 1 to 4 of the build 1 procedure to enable real-time mode and continuous refresh for the watch views and also for changing the continuous refresh interval for the watch view if needed.
- 2. Run the code by using the <F8> key, or using the Run button on the toolbar.
- 3. Apply an appropriate resistive load to the PSFB system at the DC output. A load that draws around 3A 6A current at 12 V output is a good starting point.
- 4. Check PSFB\_guivLVBus\_Set\_Volts. PSFB\_guivLVBus\_Set\_Volts should be 2 at the beginning.
- 5. Set PSFB\_enable to be 1. This enables PWM output.
- 6. Power the input at J1, J2 with 400V DC (200V and 300V are optional). The output voltage should rise up to 2V.

#### Note

For user safety, it is recommended to use an isolated DC source to supply 400V DC input to the board.

- Set PSFB\_start\_flag to 1. The output voltage should now start ramping up to 12 V. Here is the watch view that corresponds to the operation of the system with 12 V at the output with an input voltage of around 400 V and a load of around ~5A (constant current load).
- 8. Gradually increase the load (constant current load) to 25A. The output power will be around 300W. The transformer voltage(CH1), PWM signal(CH2, CH3) and primary current (CH4, primary side of CT) should be similar as Figure 4-12.
- 9. By default, the synchronous rectifiers are operated in mode 2. You can change their mode of operation by changing PSFB\_SR\_mode variable to 0, 1 or 2 from the watch view. Observe the change in amount of input current being drawn and change in output voltage with different SR modes. You can also probe the PWM waveforms driving the synchronous rectifier switches. Do not change between different SR modes when operating at very low loads or when the output voltage is very low (less than 6V). In these cases use the default SR mode 2. The SR PWM waveforms(CH2 Ch3) are shown in Figure 4-11
- 10. Now the load transient can be tested. Set the current slew rate to be 0.5A/us (can be tested up to 2.5A). Then set load current to be 12.5A. Now the output power is 150W. More tests can be done between 10% ~ 100% load condition.
- 11. Probe the MOSFETS Vds and Vgs of active to passive leg and passive to active leg. The low voltage switching is achieved for passive to active leg as Figure 4-10.
- 12. SFRA is to verify the designed compensator provides enough gain and phase margin by measuring on hardware. To run the SFRA keep the project running, open sfra\gui\SFRA\_GUI.exe, SFRA GUI will pop out.
- 13. Select the options for the device on the SFRA GUI. For example, for F28004x select floating point. Click on Setup Connection. On the pop-up window uncheck the boot on connect option, and select an appropriate COM port. Click OK. Return to the SFRA GUI, and click Connect.
- 14. The SFRA GUI will connect to the device. A SFRA sweep can now be started by clicking Start Sweep. Activity can be monitored by seeing the progress bar on the SFRA GUI and also checking the flashing of blue LED on the back on the controlcard that indicates UART activity. When complete, a graph with the open loop plot will appear, as in Figure 4-13. This verifies that the designed compensator is indeed stable.
- 15. Fully halting the MCU when in real-time mode is a two-step process. With the 400 V DC input turned off wait a few seconds. First, halt the processor by using the Halt button on the toolbar, or by using Target > Halt. Then, click the button again to take the MCU out of real-time mode and then reset the MCU.
- 16. Close CCS.

#### End of Exercise





Figure 4-10. Low Voltage Switching



Figure 4-11. SR PWM Waveforms





Figure 4-12. Transformer voltage, PWM and primary current (primary side of CT) waveforms



Figure 4-13. Voltage loop SFRA Result



## 4.1.3 Test results

The efficiency is measured under 400 V input and 12 V output condition. The SR\_mode is set to 2 under different load conditions in this test. The peak efficiency is around 91.5%.



Figure 4-14. Efficiency vs. Power

## **5** Design and Documentation Support

## 5.1 Design Files

## 5.1.1 Schematics

To download the schematics, see the design files at TIDM-02000.

#### 5.1.2 BOM

To download the bill of materials (BOM), see the design files at TIDM-02000.

#### 5.2 Software

To download the software files, see the design files at TIDM-02000.

## **5.3 Documentation Support**

Related Documentation:

- Texas Instruments, Bidirectional DC-DC Converter Design Guide.
- Texas Instruments, Phase-Shifted Full Bridge DC/DC Power Converter Reference Design Guide.

## 6 Terminology

| ACRONYM | DEFINITION                             |
|---------|----------------------------------------|
| DAC     | Digital-to-Analog Converter            |
| HVPSFB  | High-Voltage Phase-Shifted Full Bridge |
| LVS     | Low-Voltage Switching                  |
| MCU     | microcontroller                        |
| PCMC    | Peak Current Mode Control              |
| PSFB    | Phase-Shifted Full Bridge              |
| PWM     | pulse width modulation                 |
| SR      | Synchronous Rectification              |
| VMC     | Voltage Mode Control                   |
| ZVS     | Zero-Voltage Switching                 |

## 7 About the Author

**CHEN JIANG** is a Systems Application Engineer with the C2000 Microcontrollers System Solutions Group at Texas Instruments, where he is responsible for developing reference design solutions for digital power



applications. Before joining TI in 2017, Chen received his PhD in Electrical and Computer Engineering from Georgia Institute of Technology, Atlanta in 2017, and his Bachelor of Engineering from Zhejiang University, China in 2012.

## **8 Revision History**

NOTE: Page numbers for previous revisions may differ from page numbers in the current version.

| Changes from Revision A (April 2021) to Revision B (June 2021)    | Page |
|-------------------------------------------------------------------|------|
| Updated PCMC PSFB Implementation image                            | 7    |
| Added step 3                                                      |      |
| Deleted step 3                                                    |      |
| Changes from Revision * (October 2020) to Revision A (March 2021) | Page |

Added step 3.....
22

## IMPORTANT NOTICE AND DISCLAIMER

TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATA SHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, regulatory or other requirements.

These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you will fully indemnify TI and its representatives against, any claims, damages, costs, losses, and liabilities arising out of your use of these resources.

TI's products are provided subject to TI's Terms of Sale or other applicable terms available either on ti.com or provided in conjunction with such TI products. TI's provision of these resources does not expand or otherwise alter TI's applicable warranties or warranty disclaimers for TI products.

TI objects to and rejects any additional or different terms you may have proposed.

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2022, Texas Instruments Incorporated