# A COSIDE based (virtual) Radarsensor on the (virtual) Road Florian Starzer (DICE ATV SC CE) 2015-11-10; Munich; Coside UG Meeting

Contributors: Rainer Stuhlberger, Alexander Onic, Lukas Heschl, Andreas Schroeck





#### Purpose and Vision – Product 2 System

- > Infineon's Radar Success Story:
- > First IFX 77GHz Radar Sensor
  - 2003: 77GHz SiGe:C VCO
  - 2005: 77GHz Transmitter 77GHz Receiver
  - 2006: 77GHz 2RX 2TRX + VCO Prototype
  - 2009: series Product Porsche Panamera
  - 2012: SiGe:C + CMOS Companion
  - 2014: BiCMOS Integration







### 3<sup>rd</sup> Gen, Carrying the WORLD

- > 3<sup>rd</sup> Gen. has done a great job!
- > Support of 3<sup>rd</sup> Gen. RADAR
- Derivate solutions have supported 4<sup>th</sup> Gen. RADAR
- CMOS companion has enhanced functionality and flexibility to 3<sup>rd</sup> Gen. derivate solutions
- We think, it's time for 3<sup>rd</sup> Gen and its companion to retire
- The next generation shall contain all the knowledge in one design







#### Historic Attempts?

- Customer demands product with very brief description
  - Brief and hard to fulfill specification
- Block concept with simple ideal simulation (Matlab ®, Simulink)
  - Demands to circuit design
  - Layout back annotation
- Test circuit  $\rightarrow$  functional verification
  - Refinements
- Product



- Lessons learned: some spec. values over demanded!
- Future: Pre-Sim and relax demands!



# Generation 4 System Approach





#### What is the Virtual Prototype?

 The Virtual Prototype is a computer simulation model (software) that is a complete bitand cycle-accurate, functional model of the RADAR chip and includes a simple channel model (target scenario).



- > Same interface as silicon chip on PIN level
- > Same programming as final hardware (via SPI)



### VP – Design Insights (1/3)

- > How is the virtual prototype designed?
- > blocks are known (Core Concept defined)
  - basic functionality is known too
  - models are implemented from simple to sophisticated
  - level 1: basic function examples

$$\sim \rightarrow LO$$
  $s_{LO} = \hat{V} \sin(2\pi f_{LO} + \phi)$ 



G

GAIN

Copyright © Infineon Technologies AG 2015. All rights reserved.

IPPING

# VP – Design Insights (2/3)

- saturation modelled using polynomal fitting methods.
  - model calculated @ VP init
  - model 2 be interchanged with design update
- level 2: non-linearities are partly taken into account  $\sim \rightarrow \text{LO} \qquad \varphi \sim \mathcal{N}(0, \sigma_{\varphi}^2)$  $s_{\rm LO} = \hat{V} \sin\left(2\pi f_{\rm LO} + \phi + \varphi\right)$  $= \hat{V} \sin\left(2\pi f_{\rm LO} + \phi\right) + \omega_{\rm AWGN}$  $\rightarrow$  IF  $s_{\rm IF} = s_{\rm LO,sat} \cdot s_{\rm RF,sat} \cdot G_{\rm lin}$ RF ·  $\rightarrow s_{\text{out,sat}} = \sum a_i \cdot s_{\text{in}}^i \cdot G_{\text{lin}}$ GAIN



G

GAIN

Copyright © Infineon Technologies AG 2015. All rights reserved.



## VP – Design Insights (3/3)

- implementation levels 3 & 4
  - level 3: higher order non-linearities are modelled as add-on to the clipping behavior



- level 4: noise is taken into account (defined via Noise Figure)
- > Computational Effort: e.g. amplifier
  - level 1: 1 mult.
  - level 2: 1 mult. + if then else statement
  - level 3: 3 mult. + 2 adds + if then else statement
    - can be even more complicated, depends on composition of model
  - level 4: 4 mult. + 3 adds + if then else statement



# VP – Design Insights - Conclusion

- Several implementations possible:
  - level 1: simple amplification variable on simulation start
  - level 2: …add clipping shift-able
  - level 3: ... simulation data to be used on start & interchangeable with csv files from designers
    - polynomial fitting algorithms used to fetch P1dB behavior from design files or measurement results
  - level 4: serval random gen. solutions are available to vary possible close to reality behavior



input power (dBm)





# Simulation Insights

- > improving speed @ same quality of data?
- > relax carrier frequency demands



- shift virtual LO to lower value  $\rightarrow$  run simulation
  - same number of samples for "lower" frequency @ more time between two steps
  - digital core computation is calced at virtual real time
- backscale result to value as if has been simulated at actual LO



# **Problem Formulation**

> Our digital design consists of three stages:



- Virtual Prototype (Coside / SystemC)
- Realization (design) in VHDL or others
- We need to make sure, each of them works, according to
  - the draft
  - customer requirements





# Verification with Virtual Prototype (I)

- Module under test is connected to the test bench module, which handles input to and output from the module with data files
- > Available test bench modules:
  - test\_bench\_dig
  - testbench\_dig\_fp test bench for fixed point modules
  - testbench\_dig\_hiprec
    file out with high decimal precision







#### Design Verification

- > Power Up sequence applied to both, CV and circuit simulation
  - Comparison of signals highlights divergence from concept
  - Timing issues can be tracked easily
- Virtual world scenarios mirror behavior of real world scenarios and help to find measurement and test cases
- Digital domain regression be formulated
  - CRC verification
  - CRC test-cases be defined for measurement
- ROM code of FW to be applied to VP
  - Test routines be evaluated before first silicon arrives



#### Concept and Design Verification

> Matlab 
 B based verification framework





#### Firmware functions developed on VP

- > VP used to verify FW functionality
- > Virtual IRP already verified
- Test cases used to cross-verify circuit wiring and consistency of concept with design
- Firmware development starts with completion of basic VP version and is preceded and refined with each enhancement of the VP
- Less updates → gains time & money





Part of your life. Part of tomorrow.

