SOC时序分析中的跳变点介绍
e delay value triplet is changed in the IOPATH syntax if ( abs($load_correct_value1_0{$instance_name2}) $correct_value1_IOPATH[0] ) { ###the absolute value to negative delay is larger than the timing of load arc. ###### $correct_value1_IOPATH[0] = $correct_value1_IOPATH[0] + $load_correct_value1_0{$instance_name2}; } else { print IOPATH delay for $load_pin{$instance_name2.$pin_name2} of $instance_name2 is smaller than the INTERCONNECT delay n;} } } if(exists $load_correct_value1_1{$instance_name2}) { if( $load_correct_value1_1{$instance_name2} 0.0) { if ( abs($load_correct_value1_1{$instance_name2}) $correct_value1_IOPATH[1] ) { $correct_value1_IOPATH[1] = $correct_value1_IOPATH[1] + $load_correct_value1_1{$instance_name2};} else { print IOPATH delay for $load_pin{$instance_name2.$pin_name2} of $instance_name2 is smaller than the INTERCONNECT delay n;}}} print file1 ($correct_value1_IOPATH[0]::$correct_value1_IOPATH[1]); } elsif( $value_IOPATH[0] =~ :[^:]) ####CORRECT OR ACCOMODATING THE NEG DELAY VALUES HERE ######### { $value_IOPATH[0] =~ s/[()]//g; @correct_value1_IOPATH = split(/:/,$value_IOPATH[0]); if(exists $load_correct_value1_0{$instance_name2}) { if($load_correct_value1_0{$instance_name2} 0.0) { # So that only negative delay value triplet is changed in the IOPATH syntax if ( abs($load_correct_value1_0{$instance_name2}) $correct_value1_IOPATH[0] ) { $correct_value1_IOPATH[0] = $correct_value1_IOPATH[0] + $load_correct_value1_0{$instance_name2}; } else { print IOPATH delay for $load_pin{$instance_name2.$pin_name2} of $instance_name2 is smaller than the INTERCONNECT delay n;} } } if(exists $load_correct_value1_1{$instance_name2}) { if($load_correct_value1_1{$instance_name2} 0.0) { # So that only negative delay value triplet is changed in the IOPATH syntax if ( abs($load_correct_value1_1{$instance_name2}) $correct_value1_IOPATH[1] ) { $correct_value1_IOPATH[1] = $correct_value1_IOPATH[1] + $load_correct_value1_1{$instance_name2}; } else { print IOPATH delay for $load_pin{$instance_name2.$pin_name2} of $instance_name2 is smaller than the INTERCONNECT delay n;} } } if(exists $load_correct_value1_2{$instance_name2}) { if($load_correct_value1_2{$instance_name2} 0.0) { # So that only negative delay value triplet is changed in the IOPATH syntax if ( abs($load_correct_value1_2{$instance_name2}) $correct_value1_IOPATH[2] ) { $correct_value1_IOPATH[2] = $correct_value1_IOPATH[2] + $load_correct_value1_2{$instance_name2}; } else { print IOPATH delay for $load_pin{$instance_name2.$pin_name2} of $instance_name2 is smaller than the INTERCONNECT delay n;} } } print file1 ($correct_value1_IOPATH[0]:$correct_value1_IOPATH[1]:$correct_value1_IOPATH[2]); } else{print file1 $value_IOPATH[0] ;} # This is to print empty brackets in case rise and fall triplets are empty if( $value_IOPATH[1] =~ ::) { $value_IOPATH[1] =~ s/[()]//g; @correct_value2_IOPATH = split(/::/,$value_IOPATH[1]); if(exists $load_correct_value2_0{$instance_name2}) { if( $load_correct_value2_0{$instance_name2} 0.0) { if ( abs($load_correct_value2_0{$instance_name2}) $correct_value2_IOPATH[0] ) { $correct_value2_IOPATH[0] = $correct_value2_IOPATH[0] + $load_correct_value2_0{$instance_name2};} else { print IOPATH delay for $load_pin{$instance_name2.$pin_name2} of $instance_name2 is smaller than the INTERCONNECT delay n;}}} if(exists $load_correct_value2_1{$instance_name2}) { if( $load_correct_value2_1{$instance_name2} 0.0) { if ( abs($load_correct_value2_1{$instance_name2}) $correct_value2_IOPATH[1] ) { $correct_value2_IOPATH[1] = $correct_value2_IOPATH[1] + $load_correct_value2_1{$instance_name2};} else { print IOPAT
- RS232、RS485和RS422介绍与比较(12-14)
- ARM处理器模式介绍和模式切换(11-28)
- EZ-USB FX2单片机CY7C68013的特性介绍(10-15)
- MCS-51单片机的中央处理器CPU介绍(05-13)
- PIC12F683微控制器实验板介绍(11-10)
- 详细介绍用51单片机解密任何红外遥控器(10-23)