Actions

CustomNode.java.wp: Difference between revisions

From Santa Fe Institute Events Wiki

No edit summary
No edit summary
Line 1: Line 1:
[[WikiPeerCode]]
[[WikiPeerCode]]
<pre>
<pre>/*
/*
  * CustomNode.java
  * CustomNode.java
  *
  *
  * Created on January 22, 2005, 2:41 PM
  * Created on January 22, 2005, 2:41 PM
  * Modified on June 14, 2006
  * Modified on June 17, 2006, 17:20 by Jack
  *
  *
  * This class contains the parameters and methods
  * This class contains the parameters and methods
Line 41: Line 40:
     public static GUIModel              guiModel = null;
     public static GUIModel              guiModel = null;
     public static RepMod          model;
     public static RepMod          model;
    // voteType, whether to use democratic or meritocratic votes
    // 0 = democratic
    // 1 = meritocratic
    public static int    voteType;
    // the degree by which the historical opinion is weighted
    public static double histWeight;           


     //********************************8**
     //********************************8**
Line 59: Line 67:
     public double reputation;              // current wealth or stored reputation
     public double reputation;              // current wealth or stored reputation
     public double skill;          // skill parameter
     public double skill;          // skill parameter
     public int    numVotes;              // the number of vote rounds  
     //public int    numVotes;              // the number of vote rounds  
   
 
     


     public double success;              // most recent success
     //public double success;              // most recent success


      
      
Line 72: Line 83:
id = nextID++;              // set id and iterate to next
id = nextID++;              // set id and iterate to next
this.skill = skill;
this.skill = skill;
reputation = 50;             // Generalize.  Currently hard-coded
reputation = 0.5;             // Generalize.  Currently hard-coded
if (guiModel != null)
if (guiModel != null)
    setNodeEdgeColorFromSkill();
    setNodeEdgeColorFromSkill();
numVotes = 0;
//numVotes = 0;
success = 0;
//success = 0;
     }
     }
      
      
Line 85: Line 96:
     // Outputs: array of strings holding parameter names
     // Outputs: array of strings holding parameter names
     public String[] getProbedProperties(){
     public String[] getProbedProperties(){
return new String[] {"id", "reputation", "skill", "success"};
return new String[] {"id", "reputation", "skill"};
     }
     }
      
      
Line 128: Line 139:


     ///////////////////////////////////////////////////////
     ///////////////////////////////////////////////////////
     // vote
     // formOpinion
     // Input: double success, the focus' real success
     // Input: double success, the focus' real skill
     // Output: double vote, the voter's estimate of focus' success
     // Output: double vote, the voter's estimate of focus' skill
     public double vote(double fSuccess){
     public double formOpinion(double fSkill, double prevOp){
if (fSuccess > skill)
double op = fSkill + model.getNormalDouble(0, getNoiseFromSkill(this.skill));
    return Math.min(1, 1.1*fSuccess);
op = histWeight*prevOp + (1-histWeight)*op;
else
return op;
    return fSuccess;
     }
     }


     ///////////////////////////////////////////////////////
     ////////////////////////////////////////////////////////
    // updateReputation
     // voteAll
    // Input: double, rep Latest reputation vote
     public void voteAll(){
     // Output: none
ArrayList edgeList = this.getOutEdges();
     public void updateReputation(double rep){
double opinion = 0;
double preRep = reputation * (double) numVotes;
int vote = 0;
numVotes ++;
for (int i = 0; i < edgeList.size(); i++){
reputation = (preRep + rep) / ((double) numVotes);
    CustomEdge edge = (CustomEdge) edgeList.get(i);
    CustomNode node = (CustomNode) edge.getTo();
    opinion = formOpinion(node.getSkill(), edge.getOpinion());
    edge.setOpinion(opinion);
    if (opinion > 0.5)
vote = 1;
    else
vote = 0;
    edge.setVote(vote);
}
     }
     }


     ///////////////////////////////////////////////////////
     ////////////////////////////////////////////////////////
     // challenge
     // calcReputation
     // Input: double difficulty
     // Input: none
     // Output: none
     // Ouput: none
     public void challenge(double difficulty){
     public void calcReputation(){
if (difficulty > skill)
ArrayList edgeList = this.getInEdges();
    success = 0;
double repSum = 0;
else  
double normSum = 0;
    success = skill - difficulty;
for (int i = 0; i < edgeList.size(); i++){
    CustomEdge edge = (CustomEdge) edgeList.get(i);
    CustomNode node = (CustomNode) edge.getFrom();
    if (voteType ==0){
repSum += edge.getVote();
normSum ++;
    }
    else if (voteType ==1){
repSum += edge.getVote() * node.getReputation();
normSum += node.getReputation();
    }
}
reputation = repSum/normSum;
     }
     }




Line 174: Line 204:
     public void    setSkill(double i) {skill = i;}
     public void    setSkill(double i) {skill = i;}


     public double  getSuccess() {return success;}
     //public double  getSuccess() {return success;}
     public void    setSuccess(double i) {success = i;}
     //public void    setSuccess(double i) {success = i;}
      
      
     //***************************************************************
     //***************************************************************
Line 209: Line 239:
nextID = 0;
nextID = 0;
     }
     }
    ///////////////////////////////////////////////////////////
    // getNoiseFromSkill
    // Inputs: double skill
    // Outputs: double, the noise variance
    public static double getNoiseFromSkill(double skill){
return skill/1.0;
    }
    public static int getVoteType() {return voteType;}
    public static void setVoteType(int i) {voteType = i;}
    public static double getHistWeight() {return histWeight;}
    public static void  setHistWeight(double i) {histWeight = i;}
}
}
</pre>
</pre>

Revision as of 23:21, 17 June 2006

WikiPeerCode

/*
 * CustomNode.java
 *
 * Created on January 22, 2005, 2:41 PM
 * Modified on June 17, 2006, 17:20 by Jack
 *
 * This class contains the parameters and methods
 *  for an agent acting on the network
 */

package RepMod;
import uchicago.src.sim.gui.NetworkDrawable;
import uchicago.src.sim.network.DefaultDrawableNode;
import uchicago.src.sim.gui.DrawableNonGridNode;
import uchicago.src.sim.util.Random;
import uchicago.src.sim.gui.OvalNetworkItem;
import java.awt.Color;
import uchicago.src.sim.gui.ColorMap;
import uchicago.src.sim.engine.CustomProbeable;
import java.util.ArrayList;


/**
 *
 * @author Jack Waddell
 *
 */

// DefaultDrawableNode lets us draw it in the GUI
// CustomProbeable lets us define which attributes appear when
//  probed in the GUI
public class CustomNode extends DefaultDrawableNode implements CustomProbeable {
    //***********************************
    // Static Parameters

    // tracks next unique id
    public static int                   nextID = 0;      
    
    public static GUIModel              guiModel = null;
    public static RepMod           model;

    // voteType, whether to use democratic or meritocratic votes
    // 0 = democratic
    // 1 = meritocratic
    public static int    voteType; 

    // the degree by which the historical opinion is weighted
    public static double histWeight;            


    //********************************8**
    // Instance parameters

    // Two colormaps are generated for color-coding the nodes in GUI
    public static ColorMap              centerColorMap;    
    public static ColorMap              edgeColorMap;
    public static final int             colorMapSize = 16;
    public static final int             colorMapMax = colorMapSize - 1;
    
    


    private int   id;                   // uniquely ids node
    public Color  myColor;              // used to draw color in GUI
    public String myPajekColor = "Red"; // color to appear in Pajek output
    public double reputation;              // current wealth or stored reputation
    public double skill;          // skill parameter
    //public int    numVotes;              // the number of vote rounds 
    

       

    //public double success;              // most recent success

    
    ///////////////////////////////////////////////////////////////
    // constructor
    // Inputs: NetworkDrawable drawable, to draw in GUI
    //         double skill, the skill parameter
    public CustomNode (NetworkDrawable drawable, double skill) {
	super(drawable);
	id = nextID++;              // set id and iterate to next
	this.skill = skill;
	reputation = 0.5;	            // Generalize.  Currently hard-coded
	if (guiModel != null)
	    setNodeEdgeColorFromSkill();
	//numVotes = 0;
	//success = 0;
    }
     
    ///////////////////////////////////////////////////////////
    // getProbedProperties
    // Required to implement CustomProbeable
    // Inputs: none
    // Outputs: array of strings holding parameter names
    public String[] getProbedProperties(){
	return new String[] {"id", "reputation", "skill"};
    }
     
    //////////////////////////////////////////////////////////
    // step
    // Input:  none
    // Output: none
    // (Can be) Called by main model to have nodes execute a single step
    public void step(){
    }

    //////////////////////////////////////////////////////////
    // setNodeColorFromReputation
    // Input:  maxReputation, the highest reputation from all agents
    // Output: none
    // Sets the node color to the colormap leval depending on reputation
    public void setNodeColorFromReputation(double maxReputation){
	int i = (int) Math.round(colorMapMax*(reputation)/ (maxReputation));
	this.setColor(centerColorMap.getColor(i));
    }
    
    //////////////////////////////////////////////////////////
    // setNodeEdgeColorFromSkill
    // Input:  none
    // Output: none
    // Sets the node edge color to the colormap level depending on skill
    public void setNodeEdgeColorFromSkill(){
	int i = (int) Math.round(colorMapMax*skill);
	this.setBorderColor(edgeColorMap.getColor(i));
	this.setBorderWidth(3);
    }


    ///////////////////////////////////////////////////////
    // getDegree
    // Input: none
    // Output: int degree
    // Calculates the degree of the node (assuming symmetric)
    public int getDegree(){	
	return (this.getOutNodes()).size();
    }

    ///////////////////////////////////////////////////////
    // formOpinion
    // Input: double success, the focus' real skill
    // Output: double vote, the voter's estimate of focus' skill
    public double formOpinion(double fSkill, double prevOp){
	double op = fSkill + model.getNormalDouble(0, getNoiseFromSkill(this.skill));
	op = histWeight*prevOp + (1-histWeight)*op;
	return op;
    }

    ////////////////////////////////////////////////////////
    // voteAll
    public void voteAll(){
	ArrayList edgeList = this.getOutEdges();
	double opinion = 0;
	int vote = 0;
	for (int i = 0; i < edgeList.size(); i++){
	    CustomEdge edge = (CustomEdge) edgeList.get(i);
	    CustomNode node = (CustomNode) edge.getTo();
	    opinion = formOpinion(node.getSkill(), edge.getOpinion());
	    edge.setOpinion(opinion);
	    if (opinion > 0.5)
		vote = 1;
	    else
		vote = 0;
	    edge.setVote(vote);
	}
    }

    ////////////////////////////////////////////////////////
    // calcReputation
    // Input: none
    // Ouput: none
    public void calcReputation(){
	ArrayList edgeList = this.getInEdges();
	double repSum = 0;
	double normSum = 0;
	for (int i = 0; i < edgeList.size(); i++){
	    CustomEdge edge = (CustomEdge) edgeList.get(i);
	    CustomNode node = (CustomNode) edge.getFrom();
	    if (voteType ==0){
		repSum += edge.getVote();
		normSum ++;
	    }
	    else if (voteType ==1){
		repSum += edge.getVote() * node.getReputation();
		normSum += node.getReputation();
	    }
	}
	reputation = repSum/normSum;
    }


    //***************************************************************
    // Getters and Setters
    public int      getID() {return id;}

    public void     setMyPajekColor(String i) {myPajekColor = i;}
    public String   getMyPajekColor() {return myPajekColor;}
    
    public double   getReputation() {return reputation;}
    public void     setReputation(double i) {reputation = i;}

    public double   getSkill() {return skill;}
    public void     setSkill(double i) {skill = i;}

    //public double   getSuccess() {return success;}
    //public void     setSuccess(double i) {success = i;}
    
    //***************************************************************
    // Static Methods

    public static void setModel(RepMod m) {model = m;}

    //////////////////////////////////////////////////////////
    // setUpNodeDrawing
    // Input: GUIModel m, a pointer to the GUIModel
    // Output: none
    public static void setUpNodeDrawing (GUIModel m) {
	guiModel = m;
	centerColorMap = new ColorMap();
	edgeColorMap   = new ColorMap();
	double minColor = 0.1;
	
	for (int i = 0; i < colorMapSize; i++){
	    double fracColor = minColor + ( (1.0-minColor)*i/colorMapMax );

	    centerColorMap.mapColor(i, 0, 0, fracColor);
	    edgeColorMap.mapColor(i, 0, fracColor, 0);
	}
    }

    ///////////////////////////////////////////////////////////
    // resetNextID
    // Inputs:  none
    // Outputs: none
    // Resets nextID.  Called when the model is reset, and a 
    //  new set of nodes is generated
    public static void resetNextID(){
	nextID = 0;
    }

    ///////////////////////////////////////////////////////////
    // getNoiseFromSkill
    // Inputs: double skill
    // Outputs: double, the noise variance
    public static double getNoiseFromSkill(double skill){
	return skill/1.0;
    }


    public static int getVoteType() {return voteType;}
    public static void setVoteType(int i) {voteType = i;}

    public static double getHistWeight() {return histWeight;}
    public static void   setHistWeight(double i) {histWeight = i;}
}