Mercurial > cortex
changeset 486:6d460ac3f5d0
working on user guide.
author | Robert McIntyre <rlm@mit.edu> |
---|---|
date | Sat, 29 Mar 2014 20:12:52 -0400 (2014-03-30) |
parents | ac953b562eab |
children | 19b55aaf4462 |
files | thesis/cortex.bib thesis/cortex.org thesis/images/finger-2.png thesis/rlm-cortex-meng.tex thesis/user-guide.org |
diffstat | 5 files changed, 339 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
1.1 --- a/thesis/cortex.bib Sat Mar 29 16:22:49 2014 -0400 1.2 +++ b/thesis/cortex.bib Sat Mar 29 20:12:52 2014 -0400 1.3 @@ -23,4 +23,6 @@ 1.4 1.5 @COMMENT sussman's HACKER 1.6 1.7 -@comment motion as a 4D manifold 1.8 \ No newline at end of file 1.9 +@comment motion as a 4D manifold 1.10 + 1.11 +@comment winston multiple modality white paper 1.12 \ No newline at end of file
2.1 --- a/thesis/cortex.org Sat Mar 29 16:22:49 2014 -0400 2.2 +++ b/thesis/cortex.org Sat Mar 29 20:12:52 2014 -0400 2.3 @@ -1627,7 +1627,7 @@ 2.4 #+caption: of a fingertip. It defines regions of high touch sensitivity 2.5 #+caption: (where there are many white pixels) and regions of low 2.6 #+caption: sensitivity (where white pixels are sparse). 2.7 - #+name: fimgertip-UV 2.8 + #+name: fingertip-UV 2.9 #+ATTR_LaTeX: :width 13cm 2.10 [[./images/finger-UV.png]] 2.11
3.1 Binary file thesis/images/finger-2.png has changed
4.1 --- a/thesis/rlm-cortex-meng.tex Sat Mar 29 16:22:49 2014 -0400 4.2 +++ b/thesis/rlm-cortex-meng.tex Sat Mar 29 20:12:52 2014 -0400 4.3 @@ -58,7 +58,7 @@ 4.4 \usepackage{xcolor} 4.5 \definecolor{dark-red}{rgb}{0.4,0.15,0.15} 4.6 \definecolor{dark-blue}{rgb}{0.15,0.4,0.15} 4.7 -\definecolor{medium-blue}{rgb}{0,0,0.5} 4.8 +\definecolor{medium-blue}{rgb}{0.15,0.4,0.4} 4.9 \hypersetup{ 4.10 colorlinks, linkcolor={dark-red}, 4.11 citecolor={dark-blue}, urlcolor={medium-blue}
5.1 --- a/thesis/user-guide.org Sat Mar 29 16:22:49 2014 -0400 5.2 +++ b/thesis/user-guide.org Sat Mar 29 20:12:52 2014 -0400 5.3 @@ -1,6 +1,338 @@ 5.4 * Appendix: =CORTEX= User Guide 5.5 5.6 - For future students who whould like to use =CORTEX= in their own 5.7 - projects. 5.8 + Those who write a thesis should endeavor to make their code not only 5.9 + accessable, but actually useable, as a way to pay back the community 5.10 + that made the thesis possible in the first place. This thesis would 5.11 + not be possible without Free Software such as jMonkeyEngine3, 5.12 + Blender, clojure, emacs, ffmpeg, and many other tools. That is why I 5.13 + have included this user guide, in the hope that someone else might 5.14 + find =CORTEX= useful. 5.15 5.16 +** Obtaining =CORTEX= 5.17 5.18 + You can get cortex from its mercurial repository at 5.19 + http://hg.bortreb.com/cortex. You may also download =CORTEX= 5.20 + releases at http://aurellem.org/cortex/releases/. As a condition of 5.21 + making this thesis, I have also provided Professor Winston the 5.22 + =CORTEX= source, and he knows how to run the demos and get started. 5.23 + You may also email me at =cortex@aurellem.org= and I may help where 5.24 + I can. 5.25 + 5.26 +** Running =CORTEX= 5.27 + 5.28 + =CORTEX= comes with README and INSTALL files that will guide you 5.29 + through installation and running the test suite. In particular you 5.30 + should look at test =cortex.test= which contains test suites that 5.31 + run through all senses and multiple creatures. 5.32 + 5.33 +** Creating creatures 5.34 + 5.35 + Creatures are created using /Blender/, a free 3D modeling program. 5.36 + You will need Blender version 2.6 when using the =CORTEX= included 5.37 + in this thesis. You create a =CORTEX= creature in a similiar manner 5.38 + to modeling anything in Blender, except that you also create 5.39 + several trees of empty nodes which define the creature's senses. 5.40 + 5.41 +*** Mass 5.42 + 5.43 + To give an object mass in =CORTEX=, add a ``mass'' metadata label 5.44 + to the object with the mass in jMonkeyEngine units. Note that 5.45 + setting the mass to 0 causes the object to be immovable. 5.46 + 5.47 +*** Joints 5.48 + 5.49 + Joints are created by creating an empty node named =joints= and 5.50 + then creating any number of empty child nodes to represent your 5.51 + creature's joints. The joint will automatically connect the 5.52 + closest two physical objects. It will help to set the empty node's 5.53 + display mode to ``Arrows'' so that you can clearly see the 5.54 + direction of the axes. 5.55 + 5.56 + Joint nodes should have the following metadata under the ``joint'' 5.57 + label: 5.58 + 5.59 + #+BEGIN_SRC clojure 5.60 +;; ONE OF the following, under the label "joint": 5.61 +{:type :point} 5.62 + 5.63 +;; OR 5.64 + 5.65 +{:type :hinge 5.66 + :limit [<limit-low> <limit-high>] 5.67 + :axis (Vector3f. <x> <y> <z>)} 5.68 +;;(:axis defaults to (Vector3f. 1 0 0) if not provided for hinge joints) 5.69 + 5.70 +;; OR 5.71 + 5.72 +{:type :cone 5.73 + :limit-xz <lim-xz> 5.74 + :limit-xy <lim-xy> 5.75 + :twist <lim-twist>} ;(use XZY rotation mode in blender!) 5.76 + #+END_SRC 5.77 + 5.78 +*** Eyes 5.79 + 5.80 + Eyes are created by creating an empty node named =eyes= and then 5.81 + creating any number of empty child nodes to represent your 5.82 + creature's eyes. 5.83 + 5.84 + Eye nodes should have the following metadata under the ``eye'' 5.85 + label: 5.86 + 5.87 +#+BEGIN_SRC clojure 5.88 +{:red <red-retina-definition> 5.89 + :blue <blue-retina-definition> 5.90 + :green <green-retina-definition> 5.91 + :all <all-retina-definition> 5.92 + (<0xrrggbb> <custom-retina-image>)... 5.93 +} 5.94 +#+END_SRC 5.95 + 5.96 + Any of the color channels may be omitted. You may also include 5.97 + your own color selectors, and in fact :red is equivalent to 5.98 + 0xFF0000 and so forth. The eye will be placed at the same position 5.99 + as the empty node and will bind to the neatest physical object. 5.100 + The eye will point outward from the X-axis of the node, and ``up'' 5.101 + will be in the direction of the X-axis of the node. It will help 5.102 + to set the empty node's display mode to ``Arrows'' so that you can 5.103 + clearly see the direction of the axes. 5.104 + 5.105 + Each retina file should contain white pixels whever you want to be 5.106 + sensitive to your chosen color. If you want the entire field of 5.107 + view, specify :all of 0xFFFFFF and a retinal map that is entirely 5.108 + white. 5.109 + 5.110 + Here is a sample retinal map: 5.111 + 5.112 + #+caption: An example retinal profile image. White pixels are 5.113 + #+caption: photo-sensitive elements. The distribution of white 5.114 + #+caption: pixels is denser in the middle and falls off at the 5.115 + #+caption: edges and is inspired by the human retina. 5.116 + #+name: retina 5.117 + #+ATTR_LaTeX: :width 7cm :placement [H] 5.118 + [[./images/retina-small.png]] 5.119 + 5.120 +*** Hearing 5.121 + 5.122 + Ears are created by creating an empty node named =ears= and then 5.123 + creating any number of empty child nodes to represent your 5.124 + creature's ears. 5.125 + 5.126 + Ear nodes do not require any metadata. 5.127 + 5.128 + The ear will bind to and follow the closest physical node. 5.129 + 5.130 +*** Touch 5.131 + 5.132 + Touch is handled similarly to mass. To make a particular object 5.133 + touch sensitive, add metadata of the following form under the 5.134 + object's ``touch'' metadata field: 5.135 + 5.136 + #+BEGIN_EXAMPLE 5.137 + <touch-UV-map-file-name> 5.138 + #+END_EXAMPLE 5.139 + 5.140 + You may also include an optional ``scale'' metadata number to 5.141 + specifiy the length of the touch feelers. The default is $0.1$, 5.142 + and this is generally sufficient. 5.143 + 5.144 + The touch UV should contain white pixels for each touch sensor. 5.145 + 5.146 + Here is an example touch-uv map that approximates a human finger, 5.147 + and its corresponding model. 5.148 + 5.149 + #+caption: This is the tactile-sensor-profile for the upper segment 5.150 + #+caption: of a fingertip. It defines regions of high touch sensitivity 5.151 + #+caption: (where there are many white pixels) and regions of low 5.152 + #+caption: sensitivity (where white pixels are sparse). 5.153 + #+name: guide-fingertip-UV 5.154 + #+ATTR_LaTeX: :width 9cm :placement [H] 5.155 + [[./images/finger-UV.png]] 5.156 + 5.157 + #+caption: The fingertip UV-image form above applied to a simple 5.158 + #+caption: model of a fingertip. 5.159 + #+name: guide-fingertip 5.160 + #+ATTR_LaTeX: :width 9cm :placement [H] 5.161 + [[./images/finger-2.png]] 5.162 + 5.163 +*** Propriocepotion 5.164 + 5.165 + Proprioception is tied to each joint node -- nothing special must 5.166 + be done in a blender model to enable proprioception other than 5.167 + creating joint nodes. 5.168 + 5.169 +*** Muscles 5.170 + 5.171 + Muscles are created by creating an empty node named =muscles= and 5.172 + then creating any number of empty child nodes to represent your 5.173 + creature's muscles. 5.174 + 5.175 + 5.176 + Muscle nodes should have the following metadata under the 5.177 + ``muscle'' label: 5.178 + 5.179 + #+BEGIN_EXAMPLE 5.180 + <muscle-profile-file-name> 5.181 + #+END_EXAMPLE 5.182 + 5.183 + Muscles should also have a ``strength'' metadata entry describing 5.184 + the muscle's total strength at full activation. 5.185 + 5.186 + Muscle profiles are simple images that contain the relative amount 5.187 + of muscle power in each simulated alpha motor neuron. The width of 5.188 + the image is the total size of the motor pool, and the redness of 5.189 + each neuron is the relative power of that motor pool. 5.190 + 5.191 + While the profile image can have any dimensions, only the first 5.192 + line of pixels is used to define the muscle. Here is a sample 5.193 + muscle profile image that defines a human-like muscle. 5.194 + 5.195 + #+caption: A muscle profile image that describes the strengths 5.196 + #+caption: of each motor neuron in a muscle. White is weakest 5.197 + #+caption: and dark red is strongest. This particular pattern 5.198 + #+caption: has weaker motor neurons at the beginning, just 5.199 + #+caption: like human muscle. 5.200 + #+name: muscle-recruit 5.201 + #+ATTR_LaTeX: :width 7cm :placement [H] 5.202 + [[./images/basic-muscle.png]] 5.203 + 5.204 + Muscles twist the nearest physical object about the muscle node's 5.205 + Z-axis. I recommend using the ``Single Arrow'' display mode for 5.206 + muscles and using the right hand rule to determine which way the 5.207 + muscle will twist. To make a segment that can twist in multiple 5.208 + directions, create multiple, differently aligned muscles. 5.209 + 5.210 +** =CORTEX= API 5.211 + 5.212 + These are the some functions exposed by =CORTEX= for creating 5.213 + worlds and simulating creatures. These are in addition to 5.214 + jMonkeyEngine3's extensive library, which is documented elsewhere. 5.215 + 5.216 +*** Simulation 5.217 + - =(world root-node key-map setup-fn update-fn)= :: create 5.218 + a simulation. 5.219 + - /root-node/ :: a =com.jme3.scene.Node= object which 5.220 + contains all of the objects that should be in the 5.221 + simulation. 5.222 + 5.223 + - /key-map/ :: a map from strings describing keys to 5.224 + functions that should be executed whenever that key is 5.225 + pressed. the functions should take a SimpleApplication 5.226 + object and a boolean value. The SimpleApplication is the 5.227 + current simulation that is running, and the boolean is true 5.228 + if the key is being pressed, and false if it is being 5.229 + released. As an example, 5.230 + #+BEGIN_SRC clojure 5.231 + {"key-j" (fn [game value] (if value (println "key j pressed")))} 5.232 + #+END_SRC 5.233 + is a valid key-map which will cause the simulation to print 5.234 + a message whenever the 'j' key on the keyboard is pressed. 5.235 + 5.236 + - /setup-fn/ :: a function that takes a =SimpleApplication= 5.237 + object. It is called once when initializing the simulation. 5.238 + Use it to create things like lights, change the gravity, 5.239 + initialize debug nodes, etc. 5.240 + 5.241 + - /update-fn/ :: this function takes a =SimpleApplication= 5.242 + object and a float and is called every frame of the 5.243 + simulation. The float tells how many seconds is has been 5.244 + since the last frame was rendered, according to whatever 5.245 + clock jme is currently using. The default is to use IsoTimer 5.246 + which will result in this value always being the same. 5.247 + 5.248 + 5.249 + - =(position-camera world position rotation)= :: set the position 5.250 + of the simulation's main camera. 5.251 + - =(enable-debug world)= :: turn on debug wireframes for each 5.252 + simulated object. 5.253 + - =(set-gravity world gravity)= :: set the gravity of a running 5.254 + simulation. 5.255 + - =(box length width height & {options})= :: create a box in the 5.256 + simulation. Options is a hash map specifying texture, mass, 5.257 + etc. Possible options are =:name=, =:color=, =:mass=, 5.258 + =:friction=, =:texture=, =:material=, =:position=, 5.259 + =:rotation=, =:shape=, and =:physical?=. 5.260 + - =(sphere radius & {options})= :: create a sphere in the simulation. 5.261 + Options are the same as in =box=. 5.262 + - =(load-blender-model file-name)= :: create a node structure 5.263 + representing that described in a blender file. 5.264 + - =(light-up-everything world)= :: distribute a standard compliment 5.265 + of lights throught the simulation. Should be adequate for most 5.266 + purposes. 5.267 + - =(node-seq node)= :: return a recursuve list of the node's 5.268 + children. 5.269 + - =(nodify name children)= :: construct a node given a node-name and 5.270 + desired children. 5.271 + - =(add-element world element)= :: add an object to a running world 5.272 + simulation. 5.273 + - =(set-accuracy world accuracy)= :: change the accuracy of the 5.274 + world's physics simulator. 5.275 + - =(asset-manager)= :: get an /AssetManager/, a jMonkeyEngine 5.276 + construct that is useful for loading textures and is required 5.277 + for smooth interaction with jMonkeyEngine library functions. 5.278 + 5.279 + 5.280 +*** Creature Manipulation / Import 5.281 + 5.282 + - =(body! creature)= :: give the creature a physical body. 5.283 + - =(vision! creature)= :: give the creature a sense of vision. 5.284 + Returns a list of functions which will each, when called 5.285 + during a simulation, return the vision data for the channel of 5.286 + one of the eyes. The functions are ordered depending on the 5.287 + alphabetical order of the names of the eye nodes in the 5.288 + blender file. The data returned by the functions is a vector 5.289 + containing the eye's /topology/, a vector of coordinates, and 5.290 + the eye's /data/, a vector of RGB values filtered by the eye's 5.291 + sensitivity. 5.292 + - =(hearing! creature)= :: give the creature a sense of hearing. 5.293 + Returns a list of functions, one for each ear, that when 5.294 + called will return a frame's worth of hearing data for that 5.295 + ear. The functions are ordered depending on the alphabetical 5.296 + order of the names of the ear nodes in the blender file. The 5.297 + data returned by the functions is an array PCM encoded wav 5.298 + data. 5.299 + - =(touch! creature)= :: give the creature a sense of touch. Returns 5.300 + a single function that must be called with the /root node/ of 5.301 + the world, and which will return a vector of /touch-data/ 5.302 + one entry for each touch sensitive component, each entry of 5.303 + which contains a /topology/ that specifies the distribution of 5.304 + touch sensors, and the /data/, which is a vector of 5.305 + =[activation, length]= pairs for each touch hair. 5.306 + - =(proprioception! creature)= :: give the creature the sense of 5.307 + proprioception. Returns a list of functions, one for each 5.308 + joint, that when called during a running simulation will 5.309 + report the =[headnig, pitch, roll]= of the joint. 5.310 + - =(movement! creature)= :: give the creature the power of movement. 5.311 + Creates a list of functions, one for each muscle, that when 5.312 + called with an integer, will set the recruitment of that 5.313 + muscle to that integer, and will report the current power 5.314 + being exerted by the muscle. Order of muscles is determined by 5.315 + the alphabetical sort order of the names of the muscle nodes. 5.316 + 5.317 +*** Visualization/Debug 5.318 + 5.319 + - =(view-vision)= :: create a function that when called with a list 5.320 + of visual data returned from the functions made by =vision!=, 5.321 + will display that visual data on the screen. 5.322 + - =(view-hearing)= :: same as =view-vision= but for hearing. 5.323 + - =(view-touch)= :: same as =view-vision= but for touch. 5.324 + - =(view-proprioception)= :: same as =view-vision= but for 5.325 + proprioception. 5.326 + - =(view-movement)= :: same as =view-vision= but for 5.327 + proprioception. 5.328 + - =(view anything)= :: =view= is a polymorphic function that allows 5.329 + you to inspect almost anything you could reasonably expect to 5.330 + be able to ``see'' in =CORTEX=. 5.331 + - =(text anything)= :: =text= is a polymorphic function that allows 5.332 + you to convert practically anything into a text string. 5.333 + - =(println-repl anything)= :: print messages to clojure's repl 5.334 + instead of the simulation's terminal window. 5.335 + 5.336 +*** Misc 5.337 + 5.338 + - =(load-bullet)= :: unpack native libraries and initialize 5.339 + blender. This function is required before other world building 5.340 + functions are called. 5.341 + - =(mega-import-jme3)= :: for experimenting at the REPL. This 5.342 + function will import all jMonkeyEngine3 classes for immediate 5.343 + use.