cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 

Discussions

Solve problems, and share tips and tricks with other JMP users.
%3CLINGO-SUB%20id%3D%22lingo-sub-765189%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%EC%97%B4%20%EC%88%98%EC%8B%9D%20%EB%82%B4%EB%B6%80%EC%97%90%20%EB%B3%80%EC%88%98%20%EC%84%A0%EC%96%B8%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-765189%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%EC%95%88%EB%85%95%2C%3C%2FP%3E%3CP%3E%EC%97%B4%20%EC%88%98%EC%8B%9D%20%EB%82%B4%EC%97%90%20%EB%B3%80%EC%88%98%EB%A5%BC%20%EC%84%A0%EC%96%B8%ED%95%98%EB%8A%94%20%EA%B2%83%EC%9D%B4%20%EC%A2%8B%EC%9D%80%20%EC%8A%B5%EA%B4%80%EC%9E%85%EB%8B%88%EA%B9%8C%3F%20%EC%95%84%EB%8B%88%EB%A9%B4%20%EC%98%A4%EB%A5%98%EA%B0%80%20%EB%B0%9C%EC%83%9D%ED%95%A0%20%EC%9C%84%ED%97%98%EC%9D%B4%20%EC%9E%88%EC%8A%B5%EB%8B%88%EA%B9%8C%3F%20%EB%82%B4%20%EA%B3%B5%EC%8B%9D%EC%9D%80%20%EC%9E%98%20%EC%9E%91%EB%8F%99%ED%95%98%EC%A7%80%EB%A7%8C%20%EC%8B%A0%EB%A2%B0%ED%95%A0%20%EC%88%98%20%EC%97%86%EC%9D%84%EA%B9%8C%20%EA%B1%B1%EC%A0%95%EB%90%A9%EB%8B%88%EB%8B%A4.%3C%2FP%3E%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3Erownum%20%3D%20Row()%3B%0AIf(%20%3AMeasurement%20type%20%3D%3D%20%22STUDY_VARIABLE%22%2C%0A%09%3AControl%20means%5BMin(%0A%09%09Current%20Data%20Table()%20%26lt%3B%26lt%3B%20get%20rows%20where(%20%3AMeasurement%20type%20%3D%3D%20%22STUDY_CONTROL%22%20%26amp%3B%20%3AControl%20group%20%3D%3D%20%3AControl%20group%5Brownum%5D%20)%0A%09)%5D%2C%0A%09%3AControl%20means%0A)%3B%3C%2FCODE%3E%3C%2FPRE%3E%3CP%3E%EC%84%A4%EC%A0%95%EC%9D%80%20%EB%8B%A4%EC%9D%8C%EA%B3%BC%20%EA%B0%99%EC%8A%B5%EB%8B%88%EB%8B%A4.%3C%2FP%3E%3CUL%3E%3CLI%3E%3A%EC%B8%A1%EC%A0%95%20%EC%9C%A0%ED%98%95%EC%9D%80%20%EA%B0%81%20%ED%96%89%EC%97%90%20STUDY_CONTROL%20%EB%98%90%EB%8A%94%20STUDY_VARIABLE%EB%A1%9C%20%EB%9D%BC%EB%B2%A8%EC%9D%84%20%EC%A7%80%EC%A0%95%ED%95%98%EB%8A%94%20%EC%97%B4%EC%9E%85%EB%8B%88%EB%8B%A4.%3C%2FLI%3E%3CLI%3E%3A%EC%A0%9C%EC%96%B4%20%EA%B7%B8%EB%A3%B9%EC%9D%80%20STUDY_VARIABLES%EC%9D%B8%20%ED%96%89%EC%9D%84%20%EA%B4%80%EB%A0%A8%20STUDY_CONTROL%20%ED%96%89%EC%9D%98%20%EC%A0%81%EC%A0%88%ED%95%9C%20%ED%8F%89%EA%B7%A0(%3AControl%20%EC%88%98%EB%8B%A8)%EA%B3%BC%20%EC%97%B0%EA%B2%B0%ED%95%98%EA%B8%B0%20%EC%9C%84%ED%95%B4%20%EB%A0%88%EC%9D%B4%EB%B8%94(%EB%8B%A8%EC%A7%80%20%EB%AC%B8%EC%9E%90)%EC%9D%84%20%EC%82%AC%EC%9A%A9%ED%95%98%EB%8A%94%20%EC%97%B4%EC%9E%85%EB%8B%88%EB%8B%A4.%3C%2FLI%3E%3CLI%3E%3AControl%20group%5BRow()%5D%EA%B0%80%20%EC%9E%91%EB%8F%99%ED%95%98%EC%A7%80%20%EC%95%8A%EC%95%84%EC%84%9C%20rownum%20%EB%B3%80%EC%88%98%EB%A5%BC%20%EC%95%9E%EC%97%90%20%EC%A7%80%EC%A0%95%ED%96%88%EC%8A%B5%EB%8B%88%EB%8B%A4.%3C%2FLI%3E%3C%2FUL%3E%3CP%3E%EC%9D%B4%EA%B2%83%EC%9D%80%20%EC%9A%B0%EC%95%84%ED%95%9C%20%ED%95%B4%EA%B2%B0%EC%B1%85%EC%9D%B8%EA%B0%80%20%EC%95%84%EB%8B%88%EB%A9%B4%20%EC%9C%84%ED%97%98%ED%95%9C%20%ED%95%B4%ED%82%B9%EC%9D%B8%EA%B0%80%3F%3C%2FP%3E%3CP%3E%EB%91%90%20%EB%B2%88%EC%A7%B8%20%EC%A7%88%EB%AC%B8%EC%9C%BC%EB%A1%9C%20%ED%8E%B8%EC%A7%91%EC%9E%90%EB%8A%94%20%EC%88%98%EC%8B%9D%EC%97%90%20Current%20Data%20Table()%EC%9D%84%20%EC%82%AC%EC%9A%A9%ED%95%98%EB%8A%94%20%EA%B2%83%EC%9D%B4%20%EC%9C%84%ED%97%98%ED%95%98%EB%8B%A4%EA%B3%A0%20%EA%B2%BD%EA%B3%A0%ED%95%A9%EB%8B%88%EB%8B%A4.%20%EB%8D%94%20%EB%82%98%EC%9D%80%20%EB%8C%80%EC%95%88%EC%9D%B4%20%EC%9E%88%EC%8A%B5%EB%8B%88%EA%B9%8C%3F%3C%2FP%3E%3CP%3E%EB%8F%84%EC%9B%80%EC%9D%84%20%EC%A3%BC%EC%85%94%EC%84%9C%20%EA%B0%90%EC%82%AC%ED%95%A9%EB%8B%88%EB%8B%A4.%20%EC%9D%B4%EA%B2%83%EC%9D%B4%20%EC%B2%AB%20%EB%B2%88%EC%A7%B8%20%EC%A7%88%EB%AC%B8%EC%9E%85%EB%8B%88%EB%8B%A4!%3C%2FP%3E%3CP%3E%EB%8D%B0%EC%9D%B4%EB%B9%84%EB%93%9C%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-802726%22%20slang%3D%22en-US%22%20mode%3D%22UPDATE%22%3ERe%3A%20%EC%97%B4%20%EC%88%98%EC%8B%9D%20%EB%82%B4%EB%B6%80%EC%97%90%EC%84%9C%20%EB%B3%80%EC%88%98%20%EC%84%A0%EC%96%B8%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-802726%22%20slang%3D%22en-US%22%20mode%3D%22UPDATE%22%3E%3CP%3E%ED%81%B4%EB%9F%BD%EC%97%90%20%EC%98%A4%EC%8B%A0%20%EA%B2%83%EC%9D%84%20%ED%99%98%EC%98%81%ED%95%A9%EB%8B%88%EB%8B%A4!%20%3CLI-EMOJI%20id%3D%22lia_slightly-smiling-face%22%20title%3D%22%3Acara_con_una_leve_sonrisa%3A%22%3E%3C%2FLI-EMOJI%3E%3CLI-EMOJI%20id%3D%22lia_slightly-smiling-face%22%20title%3D%22%3Acara_con_una_leve_sonrisa%3A%22%3E%3C%2FLI-EMOJI%3E%3C%2FP%3E%3CP%3E%20%3C%2FP%3E%3CP%3E'Current%20Data%20Table()'%EC%97%90%20%EB%8C%80%ED%95%9C%20%EC%A7%88%EB%AC%B8%EC%97%90%20%EB%8C%80%ED%95%B4%20%3CA%20href%3D%22https%3A%2F%2Fcommunity.jmp.com%2Ft5%2FJMP-Scripters-Club-Discussions%2FScripters-Club-Recording-Building-Robust-and-fail-safe-scripts%2Fm-p%2F788286%23U788286%22%20class%3D%22lia-mention-container-editor-message%20lia-img-icon-forum-thread%20lia-fa-icon%20lia-fa-forum%20lia-fa-thread%20lia-fa%22%20target%3D%22_blank%22%3EScripters%20Club%20Recording%3A%20Building%20Robust%20and%20fail-safe%20scripts%EC%97%90%EC%84%9C%20%EA%B3%B5%EC%9C%A0%EB%90%9C%20%EC%8A%A4%ED%81%AC%EB%A6%BD%ED%8A%B8%EC%9D%98%20%EC%8A%A4%ED%81%AC%EB%A6%B0%EC%83%B7%EC%9D%84%20%EB%B3%B4%EC%97%AC%EB%93%9C%EB%A6%AC%EA%B2%A0%EC%8A%B5%EB%8B%88%EB%8B%A4.%3C%2FA%3E%3C%2FP%3E%3CP%3E%3CSPAN%20class%3D%22lia-inline-image-display-wrapper%20lia-image-align-inline%22%20image-alt%3D%22Ressel_0-1727703983643.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3CSPAN%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22Ressel_0-1727703983643.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3CSPAN%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22Ressel_0-1727703983643.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cspan%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22Ressel_0-1727703983643.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cimg%20src%3D%22https%3A%2F%2Fcommunity.jmp.com%2Ft5%2Fimage%2Fserverpage%2Fimage-id%2F68723iE83E94E25BD08DCE%2Fimage-size%2Fmedium%3Fv%3Dv2%26amp%3Bpx%3D400%22%20role%3D%22button%22%20title%3D%22Ressel_0-1727703983643.png%22%20alt%3D%22Ressel_0-1727703983643.png%22%20%2F%3E%3C%2Fspan%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%20%3C%2FP%3E%3CP%3E%ED%85%8C%EC%9D%B4%EB%B8%94%EC%9D%84%20%EB%B3%80%EC%88%98%EC%97%90%20%EC%A0%80%EC%9E%A5%ED%95%98%EA%B3%A0%20%EC%8A%A4%ED%81%AC%EB%A6%BD%ED%8A%B8%EC%97%90%EC%84%9C%20%ED%95%B4%EB%8B%B9%20%EB%B3%80%EC%88%98%EB%A5%BC%20%EC%82%AC%EC%9A%A9%ED%95%A9%EB%8B%88%EB%8B%A4.%20%EC%8A%A4%ED%81%AC%EB%A6%B0%EC%83%B7%20%EC%98%88%EC%97%90%EC%84%9C%20%EA%B7%B8%EA%B2%83%EC%9D%80%20'dt'%EC%9E%85%EB%8B%88%EB%8B%A4.%3C%2FP%3E%3CP%3E%20%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-802740%22%20slang%3D%22en-US%22%20mode%3D%22UPDATE%22%3ERe%3A%20%EC%97%B4%20%EC%88%98%EC%8B%9D%20%EB%82%B4%EB%B6%80%EC%97%90%EC%84%9C%20%EB%B3%80%EC%88%98%20%EC%84%A0%EC%96%B8%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-802740%22%20slang%3D%22en-US%22%20mode%3D%22UPDATE%22%3E%3CP%3EJSL%20%EC%8A%A4%ED%81%AC%EB%A6%BD%ED%8C%85%EC%97%90%20%EA%B4%80%ED%95%9C%20%EC%A0%95%EB%A7%90%20%ED%9B%8C%EB%A5%AD%ED%95%9C%20%EA%B0%95%EC%9D%98%EB%84%A4%EC%9A%94!%3C%2FP%3E%3CP%3E%EC%9D%B4%201%EC%8B%9C%EA%B0%84%EC%9D%B4%20%EB%AA%87%20%EB%8B%AC%20%EB%8F%99%EC%95%88%EC%9D%98%20%EB%91%90%ED%86%B5%EC%9D%84%20%EB%8D%9C%EC%96%B4%EC%A4%84%20%EA%B1%B0%EC%98%88%EC%9A%94%20%3A%20)%3CBR%20%2F%3E%3CBR%20%2F%3E%20%EA%B7%80%ED%95%98%EC%9D%98%20%EB%AC%B8%EC%A0%9C%EC%97%90%20%EB%8C%80%ED%95%B4%EC%84%9C%EB%8A%94%20%3CFONT%20face%3D%22courier%20new%2Ccourier%22%3ECol%20Min(%20...)%3C%2FFONT%3E%20%EC%9D%84%20%EC%82%B4%ED%8E%B4%EB%B3%B4%EC%8B%9C%EA%B8%B0%20%EB%B0%94%EB%9E%8D%EB%8B%88%EB%8B%A4.%3CBR%20%2F%3E%20%EC%9D%B4%20%ED%94%84%EB%A1%9C%EA%B7%B8%EB%9E%A8%EC%9D%80%20%EA%B7%80%ED%95%98%EB%A5%BC%20%EB%8C%80%EC%8B%A0%ED%95%98%EC%97%AC%20%EB%AA%A8%EB%93%A0%20%EC%9E%91%EC%97%85%EC%9D%84%20%EC%88%98%ED%96%89%ED%95%A9%EB%8B%88%EB%8B%A4.%3CBR%20%2F%3E%20%ED%96%89%20%EB%B2%88%ED%98%B8%EB%A5%BC%20%3CEM%3E%EC%84%A0%EC%96%B8%3C%2FEM%3E%20%ED%95%A0%20%ED%95%84%EC%9A%94%EA%B0%80%20%EC%97%86%EC%8A%B5%EB%8B%88%EB%8B%A4.%20%3CSTRONG%3E%3CEM%3E%ED%98%84%EC%9E%AC%20%EB%8D%B0%EC%9D%B4%ED%84%B0%20%ED%85%8C%EC%9D%B4%EB%B8%94%3C%2FEM%3E%3C%2FSTRONG%3E%20%EC%97%90%20%EC%95%A1%EC%84%B8%EC%8A%A4%ED%95%A0%20%ED%95%84%EC%9A%94%EB%8F%84%20%EC%97%86%EA%B3%A0%2C%20%3CSTRONG%3E%3CEM%3Ewhere()%EC%97%90%EC%84%9C%20%ED%96%89%EC%9D%84%20%EA%B0%80%EC%A0%B8%EC%98%AC%3C%2FEM%3E%3C%2FSTRONG%3E%20%ED%95%84%EC%9A%94%EB%8F%84%20%EC%97%86%EC%8A%B5%EB%8B%88%EB%8B%A4.%3C%2FP%3E%3CP%3E%3A%20)%3CBR%20%2F%3E%3CBR%20%2F%3E%3C%2FP%3E%3CP%3E%3CSPAN%20class%3D%22lia-inline-image-display-wrapper%20lia-image-align-inline%22%20image-alt%3D%22hogi_0-1727707451592.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cspan%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22hogi_0-1727707451592.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cimg%20src%3D%22https%3A%2F%2Fcommunity.jmp.com%2Ft5%2Fimage%2Fserverpage%2Fimage-id%2F68727i2F216F9A5F2E853B%2Fimage-size%2Fmedium%3Fv%3Dv2%26amp%3Bpx%3D400%22%20role%3D%22button%22%20title%3D%22hogi_0-1727707451592.png%22%20alt%3D%22hogi_0-1727707451592.png%22%20%2F%3E%3C%2Fspan%3E%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%20%3C%2FP%3E%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3ENames%20Default%20to%20Here(1)%3B%0Adt%20%3D%20Open(%20%22%24SAMPLE_DATA%2FBig%20Class.jmp%22%20)%3B%0Adt%20%26lt%3B%26lt%3B%20New%20Column(%20%22Measurement%20type%22%2C%0A%09Character%2C%0A%09Formula(%0A%09%09Map%20Value(%0A%09%09%09%3Asex%2C%0A%09%09%09%7B%22F%22%2C%20%22STUDY_VARIABLE%22%2C%20%22M%22%2C%20%22STUDY_CONTROL%22%7D%0A%09%09)%0A%09)%0A)%3B%0A%3Aweight%20%26lt%3B%26lt%3B%20Set%20Name(%20%22Control%20means%22%20)%3B%0A%3Aage%20%26lt%3B%26lt%3B%20Set%20Name(%20%22Control_Group%22%20)%3B%0A%0A%0A%2F%2F%20%5E%5E%5E%5E%5E%5E%5E%5Eprepare%20table%0A%0A%2F%2F%20vvvvvvvv%20how%20to%20use%20Col%20Min()%0A%0ANew%20Column(%20%22myCol%22%2C%0A%09Formula(%0A%09%09If(%20%3AMeasurement%20type%20%3D%3D%20%22STUDY_VARIABLE%22%2C%0A%09%09%09Col%20Minimum(%0A%09%09%09%09If(%20%3AMeasurement%20type%20%3D%3D%20%22STUDY_CONTROL%22%2C%0A%09%09%09%09%09%3AControl%20means%2C%0A%09%09%09%09%09Empty()%0A%09%09%09%09)%2C%0A%09%09%09%09%3AControl_Group%0A%09%09%09)%2C%0A%09%09%09%3AControl%20means%0A%09%09)%0A%09)%0A)%3C%2FCODE%3E%3C%2FPRE%3E%3C%2FLINGO-BODY%3E
Choose Language Hide Translation Bar
Asterix
Level I

Declaring a variable inside a column formula

Hi,

Is it good practice to declare a variable inside a column formula? Or does this create risk of errors? My formula works well, but I'm concerned that it might be unreliable. 

rownum = Row();
If( :Measurement type == "STUDY_VARIABLE",
	:Control means[Min(
		Current Data Table() << get rows where( :Measurement type == "STUDY_CONTROL" & :Control group == :Control group[rownum] )
	)],
	:Control means
);

The setup is as follows:

  • :Measurement type is a column which labels each row as either STUDY_CONTROL or STUDY_VARIABLE
  • :Control group is a column which uses a label (just a letter) to associate rows which are STUDY_VARIABLES with the appropriate mean (:Control means) of the relevant STUDY_CONTROL rows
  • :Control group[Row()] didn't work, so I specified the rownum variable up front

Is this an elegant solution or a dangerous hack?

As a second question, the editor warns me that it's dangerous to use Current Data Table() in a formula - is there a better alternative?

Many thanks for any assistance - this is my first question!

David

2 REPLIES 2
Ressel
Level VII

Re: Declaring a variable inside a column formula

Welcome to the club!

 

Regarding your question on 'Current Data Table()', here a screenshot from the shared script in Scripters Club Recording: Building Robust and fail-safe scripts:

Ressel_0-1727703983643.png

 

Store your table in a variable and use that variable in your script. In the screenshot example, that'd be 'dt'.

 

hogi
Level XIII

Re: Declaring a variable inside a column formula

Indeed a wonderful lecture on JSL scripting!

This 1hr will save you months of headache : )

For you problem, please have a look at Col Min( ...).
It will do all the job for you:
No need to declare any rownum - no need to access the current data table nor to get rows where()

: )

hogi_0-1727707451592.png

 

Names Default to Here(1);
dt = Open( "$SAMPLE_DATA/Big Class.jmp" );
dt << New Column( "Measurement type",
	Character,
	Formula(
		Map Value(
			:sex,
			{"F", "STUDY_VARIABLE", "M", "STUDY_CONTROL"}
		)
	)
);
:weight << Set Name( "Control means" );
:age << Set Name( "Control_Group" );


// ^^^^^^^^prepare table

// vvvvvvvv how to use Col Min()

New Column( "myCol",
	Formula(
		If( :Measurement type == "STUDY_VARIABLE",
			Col Minimum(
				If( :Measurement type == "STUDY_CONTROL",
					:Control means,
					Empty()
				),
				:Control_Group
			),
			:Control means
		)
	)
)

Recommended Articles