cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 
  • JMP will suspend normal business operations for our Winter Holiday beginning on Wednesday, Dec. 24, 2025, at 5:00 p.m. ET (2:00 p.m. ET for JMP Accounts Receivable).
    Regular business hours will resume at 9:00 a.m. EST on Friday, Jan. 2, 2026.
  • We’re retiring the File Exchange at the end of this year. The JMP Marketplace is now your destination for add-ins and extensions.

Discussions

Solve problems, and share tips and tricks with other JMP users.
%3CLINGO-SUB%20id%3D%22lingo-sub-711204%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%E6%9D%A1%E4%BB%B6%E5%85%AC%E5%BC%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-711204%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%3CP%3E%E6%88%91%E6%AD%A3%E5%9C%A8%E5%B0%9D%E8%AF%95%E6%B7%BB%E5%8A%A0%E4%B8%80%E4%B8%AA%E4%BB%A5%E5%85%B6%E4%BB%96%E5%88%97%E4%B8%BA%E6%9D%A1%E4%BB%B6%E7%9A%84%E5%88%97%E5%85%AC%E5%BC%8F%E3%80%82%20%E6%88%91%E6%9C%89%E6%95%B0%E6%8D%AE%EF%BC%8C%E5%85%B6%E4%B8%AD%E2%80%9C%E7%BB%93%E6%9E%9C%E2%80%9D%E5%88%97%E7%94%B1%E2%80%9C%E4%B8%BB%E9%A2%98%E2%80%9D%E5%92%8C%E2%80%9C%E4%BA%A7%E5%93%81%E2%80%9D%E5%A0%86%E5%8F%A0%EF%BC%8C%E5%9C%A8%E2%80%9C%E6%97%B6%E9%97%B4%E2%80%9D%E4%B8%8A%E5%85%B7%E6%9C%89%E5%A4%9A%E4%B8%AA%E5%80%BC%E3%80%82%20%E6%88%91%E6%AD%A3%E5%9C%A8%E5%B0%9D%E8%AF%95%E8%AE%A1%E7%AE%97%E2%80%9C%E7%BB%93%E6%9E%9C%E2%80%9D%E4%B8%AD%E6%AF%8F%E4%B8%AA%E5%80%BC%E7%9A%84%E5%9F%BA%E7%BA%BF%EF%BC%8C%E4%BB%A5%E4%BE%BF%EF%BC%9A%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CP%3E%E6%96%B0%E5%88%97%20%3D%E2%80%9C%E7%BB%93%E6%9E%9C%E2%80%9D%E2%80%93%20%5B%E2%80%9C%E7%BB%93%E6%9E%9C%E2%80%9D%E5%80%BC%EF%BC%8C%E5%85%B6%E4%B8%AD%E9%92%88%E5%AF%B9%E7%89%B9%E5%AE%9A%E4%B8%BB%E9%A2%98%2F%E4%BA%A7%E5%93%81%E7%BB%84%E5%90%88%EF%BC%8C%E6%97%B6%E9%97%B4%3D(1)%5D%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CP%3E%E8%B0%A2%E8%B0%A2%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-LABS%20id%3D%22lingo-labs-711204%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%3CLINGO-LABEL%3E%E8%87%AA%E5%8A%A8%E5%8C%96%E5%92%8C%E8%84%9A%E6%9C%AC%E7%BC%96%E5%86%99%3C%2FLINGO-LABEL%3E%3C%2FLINGO-LABS%3E%3CLINGO-SUB%20id%3D%22lingo-sub-711220%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%9D%A1%E4%BB%B6%E5%85%AC%E5%BC%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-711220%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%3CP%3E%E4%BD%A0%E8%83%BD%E4%B8%BE%E4%B8%AA%E6%95%B0%E6%8D%AE%E4%BE%8B%E5%AD%90%E5%90%97%EF%BC%9F%E8%BF%99%E5%B0%86%E6%9C%89%E5%8A%A9%E4%BA%8E%E6%89%BE%E5%88%B0%E9%80%82%E5%BD%93%E7%9A%84%E8%A7%A3%E5%86%B3%E6%96%B9%E6%A1%88%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-711237%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%9D%A1%E4%BB%B6%E5%85%AC%E5%BC%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-711237%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%3CP%3E%E5%A6%82%E6%9E%9C%E6%82%A8%E7%9A%84%E6%95%B0%E6%8D%AE%E6%8C%89%E4%B8%BB%E9%A2%98%E3%80%81%E4%BA%A7%E5%93%81%E3%80%81%E6%97%B6%E9%97%B4%E6%8E%92%E5%BA%8F%EF%BC%8C%E9%82%A3%E4%B9%88%E6%AD%A4%E7%A4%BA%E4%BE%8B%E5%B0%86%E6%9C%89%E6%95%88%3C%2FP%3E%0A%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3ENames%20Default%20To%20Here(%201%20)%3B%0Adt%20%3D%20Open(%20%22%24SAMPLE_DATA%2Fbig%20class.jmp%22%20)%3B%0Adt%3Aage%20%26lt%3B%26lt%3B%20set%20name(%20%22Subject%22%20)%3B%0Adt%3Asex%20%26lt%3B%26lt%3B%20set%20name(%20%22Product%22%20)%3B%0Adt%3Aweight%20%26lt%3B%26lt%3B%20set%20name(%20%22Results%22%20)%3B%0A%0Adt%20%26lt%3B%26lt%3B%20New%20Column(%20%22baseline%22%2C%0A%20formula(%0A%20%20If(%20Row()%20%3D%3D%201%2C%0A%20%20%20valueTime1%20%3D%20%3AResults%2C%0A%20%20%20If(%20%3ASubject%20!%3D%20Lag(%20%3Asubject%20)%20%7C%20%3AProduct%20!%3D%20Lag(%20%3Aproduct%20)%2C%0A%20%20%20%20valueTime1%20%3D%20%3AResults%0A%20%20%20)%0A%20%20)%3B%0A%20%20baseline%20%3D%20%3AResults%20-%20valueTime1%3B%0A%20)%0A)%3B%3C%2FCODE%3E%3C%2FPRE%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-711335%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%9D%A1%E4%BB%B6%E5%85%AC%E5%BC%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-711335%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%3CP%3E%E6%88%91%E5%B7%B2%E7%BB%8F%E5%8C%85%E5%90%AB%E4%BA%86%E7%A4%BA%E4%BE%8B%E6%95%B0%E6%8D%AE%E3%80%82%20%E6%88%91%E9%9C%80%E8%A6%81%E6%B7%BB%E5%8A%A0%E4%B8%80%E4%B8%AA%E6%96%B0%E5%88%97%EF%BC%8C%E5%85%B6%E4%B8%AD%E5%85%AC%E5%BC%8F%E9%87%87%E7%94%A8%E6%AF%8F%E4%B8%AA%E4%B8%BB%E9%A2%98%2F%E4%BA%A7%E5%93%81%E7%BB%84%E5%90%88%E7%9A%84%E6%97%B6%E9%97%B4%EF%BC%88-5%EF%BC%89%E7%BB%93%E6%9E%9C%E5%80%BC%EF%BC%8C%E5%B9%B6%E4%BB%8E%E4%B8%BB%E9%A2%98%2F%E4%BA%A7%E5%93%81%E7%BB%84%E5%90%88%E4%B8%AD%E7%9A%84%E6%AF%8F%E4%B8%AA%E7%BB%93%E6%9E%9C%E4%B8%AD%E5%87%8F%E5%8E%BB%E8%AF%A5%E5%80%BC%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-711362%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%9D%A1%E4%BB%B6%E5%85%AC%E5%BC%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-711362%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%3CP%3E%E6%9C%89%E6%97%B6%EF%BC%8C%E9%80%9A%E8%BF%87%E5%87%A0%E4%B8%AA%E6%AD%A5%E9%AA%A4%E8%A7%A3%E5%86%B3%E6%AD%A4%E7%B1%BB%E9%97%AE%E9%A2%98%E6%AF%94%E4%B8%BA%E5%88%97%E5%85%AC%E5%BC%8F%E7%BC%96%E5%86%99%E5%A4%8D%E6%9D%82%E7%9A%84%20jsl%20%E6%9B%B4%E5%AE%B9%E6%98%93%E3%80%82%20%E8%BF%99%E6%98%AF%E4%B8%80%E7%A7%8D%E4%BD%BF%E7%94%A8%E2%80%9C%E5%AD%90%E9%9B%86%E2%80%9D%E6%8F%90%E5%8F%96%20Time%3D-5%20%E8%A1%8C%EF%BC%8C%E4%BD%BF%E7%94%A8%E2%80%9C%E6%9B%B4%E6%96%B0%E2%80%9D%E5%B0%86%E5%AE%83%E4%BB%AC%E8%BF%9E%E6%8E%A5%E5%9B%9E%E5%8E%9F%E5%A7%8B%E6%95%B0%E6%8D%AE%E8%A1%A8%E7%9A%84%E6%96%B9%E6%B3%95%EF%BC%8C%E7%84%B6%E5%90%8E%E5%9C%A8%E5%88%97%E5%85%AC%E5%BC%8F%E4%B8%AD%E6%89%A7%E8%A1%8C%E7%AE%80%E5%8D%95%E7%9A%84%E5%87%8F%E6%B3%95%E3%80%82%20%E5%A6%82%E6%9E%9C%E6%82%A8%E6%AD%A3%E5%9C%A8%E8%BF%90%E8%A1%8C%20JMP%2017%EF%BC%8C%E5%B7%A5%E4%BD%9C%E6%B5%81%E7%A8%8B%E6%98%AF%E6%9E%84%E5%BB%BA%E5%92%8C%E5%85%B1%E4%BA%AB%E6%AD%A4%E7%B1%BB%E5%86%85%E5%AE%B9%E7%9A%84%E5%A5%BD%E6%96%B9%E6%B3%95%E3%80%82%3C%2FP%3E%0A%3CP%3E%26nbsp%3B%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-711367%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%9D%A1%E4%BB%B6%E5%85%AC%E5%BC%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-711367%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%3CP%3E%E6%88%91%E6%83%B3%E5%87%BA%E7%9A%84%20JSL%20%E5%B9%B6%E4%B8%8D%E5%A4%AA%E5%A4%8D%E6%9D%82%E3%80%82%E6%88%91%E6%B2%A1%E6%9C%89%E5%86%99%E5%85%AC%E5%BC%8F%EF%BC%8C%E8%80%8C%E6%98%AF%E5%86%99%E4%BA%86%E8%A1%A8%E6%A0%BC%E8%84%9A%E6%9C%AC%E3%80%82%E6%AF%8F%E5%BD%93%E6%B7%BB%E5%8A%A0%E6%9B%B4%E5%A4%9A%E6%95%B0%E6%8D%AE%E6%97%B6%EF%BC%8C%E6%82%A8%E9%83%BD%E5%8F%AF%E4%BB%A5%E8%BF%90%E8%A1%8C%E5%AE%83%E3%80%82%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3Edt%20%3D%20Current%20Data%20Table()%3B%0AOffsetArray%20%3D%20Associative%20Array()%3B%0ATimeRows%20%3D%20dt%20%26lt%3B%26lt%3B%20Get%20Rows%20Where(%20%3ATime%20%3D%3D%20-5%20)%3B%0AFor%20Each(%20%7Bval%2C%20idx%7D%2C%20TimeRows%2C%20OffsetArray%5B%3ASubject%5Bval%5D%20%7C%7C%20%3AProduct%5Bval%5D%5D%20%3D%20%3AResults%5Bval%5D%20)%3B%0AFor%20Each%20Row(%20dt%2C%20%3ANew%20Column%20%3D%20%3AResults%20-%20OffsetArray%5B%3ASubject%20%7C%7C%20%3AProduct%5D%20)%3B%3C%2FCODE%3E%3C%2FPRE%3E%3CP%3E%E7%BC%96%E8%BE%91%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CP%3E%E4%BB%94%E7%BB%86%E6%9F%A5%E7%9C%8B%E8%A1%A8%E6%A0%BC%E5%90%8E%EF%BC%8C%E6%88%91%E6%B3%A8%E6%84%8F%E5%88%B0%E4%B8%80%E4%BA%9B%EF%BC%9A%E7%BB%93%E6%9E%9C%E5%8D%95%E5%85%83%E6%A0%BC%E4%B8%AD%E7%BC%BA%E5%B0%91%E5%80%BC%E3%80%82%E6%82%A8%E5%BA%94%E8%AF%A5%E5%B0%86%E5%AE%83%E4%BB%AC%E9%87%8D%E6%96%B0%E7%BC%96%E7%A0%81%E4%B8%BA%200%20%E6%88%96%E7%A8%8D%E5%BE%AE%E6%9B%B4%E6%94%B9%E8%84%9A%E6%9C%AC%EF%BC%9A%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3Edt%20%3D%20Current%20Data%20Table()%3B%0AOffsetArray%20%3D%20Associative%20Array()%3B%0ATimeRows%20%3D%20dt%20%26lt%3B%26lt%3B%20Get%20Rows%20Where(%20%3ATime%20%3D%3D%20-5%20)%3B%0AFor%20Each(%20%7Bval%2C%20idx%7D%2C%20TimeRows%2C%20OffsetArray%5B%3ASubject%5Bval%5D%20%7C%7C%20%3AProduct%5Bval%5D%5D%20%3D%20If(%20!Is%20Missing(%20%3AResults%5Bval%5D%20)%2C%20%3AResults%5Bval%5D%2C%200%20)%20)%3B%0AFor%20Each%20Row(%20dt%2C%20%3AResults%20with%20Offset%20%3D%20%3AResults%20-%20OffsetArray%5B%3ASubject%20%7C%7C%20%3AProduct%5D%20)%3B%3C%2FCODE%3E%3C%2FPRE%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-711236%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E6%9D%A1%E4%BB%B6%E5%85%AC%E5%BC%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-711236%22%20slang%3D%22en-US%22%20mode%3D%22NONE%22%3E%3CP%3E%E5%8F%AA%E6%98%AF%E7%8C%9C%E6%B5%8B%EF%BC%8C%E5%9B%A0%E4%B8%BA%E6%B2%A1%E6%9C%89%E6%95%B0%E6%8D%AE%E5%8F%AF%E4%BB%A5%E6%B5%8B%E8%AF%95%E8%BF%99%E4%B8%80%E7%82%B9%3C%2FP%3E%0A%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3E%3AResult%20-%20Col%20Min(If(%3ATime%20%3D%3D%201%2C%20%3AResult%2C%20.)%2C%20%3AGroup)%3B%3C%2FCODE%3E%3C%2FPRE%3E%0A%3CP%3E%26nbsp%3B%3C%2FP%3E%0A%3CP%3E%E7%BC%96%E8%BE%91%EF%BC%9A%3C%2FP%3E%0A%3CP%3E%E6%88%91%E4%BB%AC%E6%94%B6%E5%88%B0%E6%A0%B7%E6%9C%AC%E6%95%B0%E6%8D%AE%E5%90%8E%E6%9B%B4%E6%96%B0%E4%BA%86%E5%85%AC%E5%BC%8F%3C%2FP%3E%0A%3CPRE%3E%3CCODE%20class%3D%22%20language-jsl%22%3E%3AResults%20-%20Col%20Min(If(%3ATime%20%3D%3D%20-5%2C%20%3AResults%2C%20.)%2C%20%3ASubject%2C%20%3AProduct)%3C%2FCODE%3E%3C%2FPRE%3E%0A%3CP%3E%26nbsp%3B%3C%2FP%3E%3C%2FLINGO-BODY%3E
Choose Language Hide Translation Bar
JMPUser9
Level II

Conditional Formula

I am trying to add a column formula that is conditional to other columns. I have data where “Results” Column is stacked by “Subject” and “Product” with multiple values over “Time”. I’m trying to calculate the baseline for each value in “Results” so that:

 

New Column = "Results" – ["Results" value where Time=(1) for that particular Subject/Product combination]

 

Thank you

1 ACCEPTED SOLUTION

Accepted Solutions

Re: Conditional Formula

Sometimes it's  easier to attack problems like this in several steps, rather than writing complex jsl for a column formula. Here's an approach that uses "Subset" to extract the Time=-5 rows, joins them back onto the original data table with "Update", and then performs a simple subtraction in a column formula. If you're running JMP 17, workflows are a great way to build and share this kind of thing.

 

View solution in original post

6 REPLIES 6
mmarchandTSI
Level V

Re: Conditional Formula

Can you give an example of the data?  That will help with finding a proper solution.

jthi
Super User

Re: Conditional Formula

Just a guess as there is no data to test this with

:Result - Col Min(If(:Time == 1, :Result, .), :Group);

 

Edit:

Updated formula after we received sample data

:Results - Col Min(If(:Time == -5, :Results, .), :Subject, :Product)

 

-Jarmo
txnelson
Super User

Re: Conditional Formula

If your data are sorted by Subject, Product, Time then this example will work

Names Default To Here( 1 );
dt = Open( "$SAMPLE_DATA/big class.jmp" );
dt:age << set name( "Subject" );
dt:sex << set name( "Product" );
dt:weight << set name( "Results" );

dt << New Column( "baseline",
	formula(
		If( Row() == 1,
			valueTime1 = :Results,
			If( :Subject != Lag( :subject ) | :Product != Lag( :product ),
				valueTime1 = :Results
			)
		);
		baseline = :Results - valueTime1;
	)
);
Jim
JMPUser9
Level II

Re: Conditional Formula

I've included sample data. I need to add a new column where the formula takes the Time(-5) Results value for each Subject/Product combination and subtracts that value from each Result in the Subject/Product Combination. 

Re: Conditional Formula

Sometimes it's  easier to attack problems like this in several steps, rather than writing complex jsl for a column formula. Here's an approach that uses "Subset" to extract the Time=-5 rows, joins them back onto the original data table with "Update", and then performs a simple subtraction in a column formula. If you're running JMP 17, workflows are a great way to build and share this kind of thing.

 

mmarchandTSI
Level V

Re: Conditional Formula

The JSL I came up with isn't too complicated.  I didn't write a formula but a table script.  You could run this whenever you add more data.

 

dt = Current Data Table();
OffsetArray = Associative Array();
TimeRows = dt << Get Rows Where( :Time == -5 );
For Each( {val, idx}, TimeRows, OffsetArray[:Subject[val] || :Product[val]] = :Results[val] );
For Each Row( dt, :New Column = :Results - OffsetArray[:Subject || :Product] );

edit

 

After looking at the table more, I noticed the missing values in some :Results cells.  You should recode those to 0 or alter the script a bit:

 

dt = Current Data Table();
OffsetArray = Associative Array();
TimeRows = dt << Get Rows Where( :Time == -5 );
For Each( {val, idx}, TimeRows, OffsetArray[:Subject[val] || :Product[val]] = If( !Is Missing( :Results[val] ), :Results[val], 0 ) );
For Each Row( dt, :Results with Offset = :Results - OffsetArray[:Subject || :Product] );

 

Recommended Articles