summaryrefslogtreecommitdiff
path: root/Windows/spice/examples/tclspice/tcl-testbench3/tcl-testbench3.sh
blob: e440d8d1e831d3c1ee7ec838f11e42665112c341 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
#!/bin/sh
# -*- mode: tcl -*- \
        exec wish -f "$0" ${1+"$@"}

package require BLT
load ../../../src/.libs/libspice.so
source differentiate.tcl
spice::codemodel ../../../src/xspice/icm/spice2poly/spice2poly.cm 
proc temperatures_calc {temp_inf temp_sup points} {
  set tstep [ expr " ( $temp_sup - $temp_inf ) / $points " ]
  set t $temp_inf
  set temperatures ""
  for { set i 0 } { $i < $points } { incr i } {
    set t [ expr { $t + $tstep } ]
    set temperatures "$temperatures $t"
  }
  return $temperatures
}

proc thermistance_calc { res B points } {
  set tzero 273.15
  set tref 25
  set thermistance ""
  foreach t $points {
    set res_temp [expr " $res * exp ( $B * ( 1 / ($tzero + $t) - 1 / ( $tzero + $tref ) ) ) " ]
    set thermistance "$thermistance $res_temp"
  }
  return $thermistance
}

proc tref_calc { points } {
  set tref ""
  foreach t $points {
    set tref " $tref [ expr " 6 * (2.275-0.005*($t - 20) ) - 9 " ] "
  }
  return $tref
}

proc iteration { t } {
  set tzero 273.15
  spice::alter r11=[ thermistance_calc 10000 3900 $t ]
  #spice::set temp = [ expr " $tzero + $t " ]
  spice::op
  spice::vectoblt vref_temp tref_tmp
  spice::destroy all
  return [ tref_tmp range 0 0 ]
}

proc cost_square { r10 r12 } {
  tref_blt length 0

  spice::alter r10=$r10
  spice::alter r12=$r12
  
  foreach point [ temperatures_blt range 0 [ expr " [temperatures_blt length ] - 1" ] ] {
    tref_blt append [ iteration $point ]
  }
  
  set result [ blt::vector expr " sum(( tref_blt - expected_blt )^2 )" ]
  puts "result square : r10 = $r10 r12 = $r12  gives  $result"

  return $result 
}

proc cost_sup { r10 r12 } {
  tref_blt length 0

  spice::alter r10=$r10
  spice::alter r12=$r12
  
  foreach point [ temperatures_blt range 0 [ expr " [temperatures_blt length ] - 1" ] ] {
    tref_blt append [ iteration $point ]
  }
  
  set result [ blt::vector expr " max(sqrt(( tref_blt - expected_blt )^2 ))" ]
  puts "result sup : $result"
  puts "result sup : r10 = $r10 r12 = $r12  gives  $result"

  return $result 
}

proc disp_curve { r10 r12 } {
.g configure -title "Valeurs optimales: R10 = $r10 R12 = $r12"
}

#
# Optimisation
#

blt::vector create tref_tmp
blt::vector create tref_blt
blt::vector create expected_blt
blt::vector create temperatures_blt
temperatures_blt append [ temperatures_calc -25 75 30 ] 
expected_blt append [ tref_calc [temperatures_blt range 0 [ expr " [ temperatures_blt length ] - 1" ] ] ]
blt::graph .g 
pack .g -side top -fill both -expand true
.g  element create real -pixels 4 -xdata temperatures_blt -ydata tref_blt
.g  element create expected -fill red -pixels 0 -dashes dot -xdata temperatures_blt -ydata expected_blt

spice::source FB14.cir
# point1 max iteration is the last argument
set r10r12 [ ::math::optimize::minimumSteepestDescent cost_square { 10000 10000 } 1.9 20 ]
puts "$r10r12 "
regexp {([0-9.]*) ([0-9.]*)} $r10r12 r10r12 r10 r12
puts "result square with : r10 = $r10 r12 = $r12 "
set r10r12 [ ::math::optimize::minimumSteepestDescent cost_sup " $r10 $r12 " 0.05 20 ]
puts "$r10r12 "
regexp {([0-9.]*) ([0-9.]*)} $r10r12 r10r12 r10 r12
puts "result sup with : r10 = $r10 r12 = $r12 "


#
# Results
#


spice::alter r10=$r10
spice::alter r12=$r12
foreach point [ temperatures_blt range 0 [ expr " [temperatures_blt length ] - 1" ] ] {
  tref_blt append [ iteration $point ]
}
disp_curve $r10 $r12