Sample Entropy Calculation

Sample Entropy Calculation preview image

1 collaborator

Cosimo.leuci Cosimo Leuci (Author)

Tags

randomness measure 

Tagged by Cosimo Leuci 5 months ago

sample entropy 

Tagged by Cosimo Leuci 5 months ago

Visible to everyone | Changeable by the author
Model was written in NetLogo 6.4.0 • Viewed 145 times • Downloaded 0 times • Run 0 times
Download the 'Sample Entropy Calculation' modelDownload this modelEmbed this model

Do you have questions or comments about this model? Ask them here! (You'll first need to log in.)


Info tab cannot be displayed because of an encoding error

Comments and Questions

Please start the discussion about this model! (You'll first need to log in.)

Click to Run Model

globals [ m                 ;; length of substrings that can be derived from the input-string
          substrings        ;; list of the substrings derived from the input-string
          substr-copy       ;; a copy of the previous list
          similar           ;; couple of similar substrings in the previous list
          sampen            ;; the sample entropy of the input-string
          index             ;; an index/pointer
         ]


;; --------- CALCULATING SAMPLE ENTROPY FOR THE INPUT-STRING SEQUENCE --------------------------------
;; ---------------------------------------------------------------------------------------------------

to compute-sample-entropy
  ca
  ifelse input-string = "" [output-print "No string to operate on"
    stop] [start-message]
  set input-string word input-string "_"
  ;; Creating patterns with m = 2
  set m 2
  set similar 0
  set substrings []
  built-substrings
  let substrings2 substrings
  output-print word "Set of patterns with m = 2       --> " substrings2
  ;; evaluate each pair of patterns
  ;; to determine if they are similar within a tolerance of 𝑟 = 0.
  set substr-copy substrings2
  calculate-distancies
  let S2 similar
  output-print word "Similar patterns of length = 2   -->  " S2
  output-print ""
    if S2 = 0 [stop-message stop]
  ;; Creating patterns with m = 3
  set m m + 1
  set index 0
  set similar 0
  set substrings []
  built-substrings
  set input-string but-last input-string
  let substrings3 substrings
  output-print word "Set of patterns with m + 1 = 3   --> " substrings3
  set substr-copy substrings3
  calculate-distancies
  let S3 similar
  output-print word "Similar patterns of length = 3   -->  " S3
  output-print ""
  if S3 = 0 [stop-message stop]
  ;; sample entropy computation
  set sampen precision (- ln (S3 / S2)) 5
  output-type word "***     SAMPLE ENTROPY = - ln " S3
  output-type word " / " S2
  output-type word " = " sampen
  output-print "     ***"
end 

to built-substrings
  set substrings lput (substring input-string index (index + m)) substrings
  set index index + 1
  if index < (length input-string - m) [built-substrings]
end 

to calculate-distancies
  set index 0
  let short.copy but-first substr-copy
  repeat length short.copy [
    if item 0 substr-copy = item index short.copy
      [set similar similar + 1]
       set index index + 1
       ]
  if length short.copy > 1 [
    set substr-copy but-first substr-copy
    calculate-distancies
  ]
  set index 0
end 

to start-message
  output-print ""
  output-print "Let's compute the sample entropy for the given sequence (with r=0 and m=2)."
  output-print ""
end 

to stop-message
  output-print "It is not possible to compute the sample entropy for this string"
  output-type "because the similar patterns of length " output-type m output-type " is null."
  if m = 2 [set input-string but-last input-string]
end 


;; Public Domain: to the extent possible under law, the author has waived
;; all copyright and related or neighboring rights to this model.

There are 2 versions of this model.

Uploaded by When Description Download
Cosimo Leuci 2 months ago rev. 0.9 Download this version
Cosimo Leuci 5 months ago Initial upload Download this version

Attached files

File Type Description Last updated
Sample Entropy Calculation.png preview Preview for 'Sample Entropy Calculation' 5 months ago, by Cosimo Leuci Download

This model does not have any ancestors.

This model does not have any descendants.