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%A2%9D%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%98%97%E8%A9%A6%E6%B7%BB%E5%8A%A0%E4%B8%80%E5%80%8B%E4%BB%A5%E5%85%B6%E4%BB%96%E5%88%97%E7%82%BA%E6%A2%9D%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%B8%E6%93%9A%EF%BC%8C%E5%85%B6%E4%B8%AD%E2%80%9C%E7%B5%90%E6%9E%9C%E2%80%9D%E5%88%97%E7%94%B1%E2%80%9C%E4%B8%BB%E9%A1%8C%E2%80%9D%E5%92%8C%E2%80%9C%E7%94%A2%E5%93%81%E2%80%9D%E5%A0%86%E7%96%8A%EF%BC%8C%E5%9C%A8%E2%80%9C%E6%99%82%E9%96%93%E2%80%9D%E4%B8%8A%E5%85%B7%E6%9C%89%E5%A4%9A%E5%80%8B%E5%80%BC%E3%80%82%20%E6%88%91%E6%AD%A3%E5%9C%A8%E5%98%97%E8%A9%A6%E8%A8%88%E7%AE%97%E2%80%9C%E7%B5%90%E6%9E%9C%E2%80%9D%E4%B8%AD%E6%AF%8F%E5%80%8B%E5%80%BC%E7%9A%84%E5%9F%BA%E7%B7%9A%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%B5%90%E6%9E%9C%E2%80%9D%E2%80%93%20%5B%E2%80%9C%E7%B5%90%E6%9E%9C%E2%80%9D%E5%80%BC%EF%BC%8C%E5%85%B6%E4%B8%AD%E9%87%9D%E5%B0%8D%E7%89%B9%E5%AE%9A%E4%B8%BB%E9%A1%8C%2F%E7%94%A2%E5%93%81%E7%B5%84%E5%90%88%EF%BC%8C%E6%99%82%E9%96%93%3D(1)%5D%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CP%3E%E8%AC%9D%E8%AC%9D%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%8B%95%E5%8C%96%E5%92%8C%E8%85%B3%E6%9C%AC%E7%B7%A8%E5%AF%AB%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%E8%A6%86%EF%BC%9A%E6%A2%9D%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%E8%88%89%E5%80%8B%E6%95%B8%E6%93%9A%E4%BE%8B%E5%AD%90%E5%97%8E%EF%BC%9F%E9%80%99%E5%B0%87%E6%9C%89%E5%8A%A9%E6%96%BC%E6%89%BE%E5%88%B0%E9%81%A9%E7%95%B6%E7%9A%84%E8%A7%A3%E6%B1%BA%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%E8%A6%86%EF%BC%9A%E6%A2%9D%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%E8%B3%87%E6%96%99%E6%8C%89%E4%B8%BB%E9%A1%8C%E3%80%81%E7%94%A2%E5%93%81%E3%80%81%E6%99%82%E9%96%93%E6%8E%92%E5%BA%8F%EF%BC%8C%E9%82%A3%E9%BA%BC%E6%AD%A4%E7%AF%84%E4%BE%8B%E5%B0%87%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%E8%A6%86%EF%BC%9A%E6%A2%9D%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%B6%93%E5%8C%85%E5%90%AB%E4%BA%86%E7%AF%84%E4%BE%8B%E8%B3%87%E6%96%99%E3%80%82%20%E6%88%91%E9%9C%80%E8%A6%81%E6%B7%BB%E5%8A%A0%E4%B8%80%E5%80%8B%E6%96%B0%E5%88%97%EF%BC%8C%E5%85%B6%E4%B8%AD%E5%85%AC%E5%BC%8F%E6%8E%A1%E7%94%A8%E6%AF%8F%E5%80%8B%E4%B8%BB%E9%A1%8C%2F%E7%94%A2%E5%93%81%E7%B5%84%E5%90%88%E7%9A%84%E6%99%82%E9%96%93%EF%BC%88-5%EF%BC%89%E7%B5%90%E6%9E%9C%E5%80%BC%EF%BC%8C%E4%B8%A6%E5%BE%9E%E4%B8%BB%E9%A1%8C%2F%E7%94%A2%E5%93%81%E7%B5%84%E5%90%88%E4%B8%AD%E7%9A%84%E6%AF%8F%E5%80%8B%E7%B5%90%E6%9E%9C%E4%B8%AD%E6%B8%9B%E5%8E%BB%E8%A9%B2%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%E8%A6%86%EF%BC%9A%E6%A2%9D%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%99%82%EF%BC%8C%E9%80%8F%E9%81%8E%E5%B9%BE%E5%80%8B%E6%AD%A5%E9%A9%9F%E8%A7%A3%E6%B1%BA%E6%AD%A4%E9%A1%9E%E5%95%8F%E9%A1%8C%E6%AF%94%E7%82%BA%E5%88%97%E5%85%AC%E5%BC%8F%E7%B7%A8%E5%AF%AB%E8%A4%87%E9%9B%9C%E7%9A%84%20jsl%20%E6%9B%B4%E5%AE%B9%E6%98%93%E3%80%82%20%E9%80%99%E6%98%AF%E4%B8%80%E7%A8%AE%E4%BD%BF%E7%94%A8%E3%80%8C%E5%AD%90%E9%9B%86%E3%80%8D%E6%8F%90%E5%8F%96%20Time%3D-5%20%E8%A1%8C%EF%BC%8C%E4%BD%BF%E7%94%A8%E3%80%8C%E6%9B%B4%E6%96%B0%E3%80%8D%E5%B0%87%E5%AE%83%E5%80%91%E9%80%A3%E6%8E%A5%E5%9B%9E%E5%8E%9F%E5%A7%8B%E8%B3%87%E6%96%99%E8%A1%A8%E7%9A%84%E6%96%B9%E6%B3%95%EF%BC%8C%E7%84%B6%E5%BE%8C%E5%9C%A8%E5%88%97%E5%85%AC%E5%BC%8F%E4%B8%AD%E5%9F%B7%E8%A1%8C%E7%B0%A1%E5%96%AE%E7%9A%84%E6%B8%9B%E6%B3%95%E3%80%82%20%E5%A6%82%E6%9E%9C%E6%82%A8%E6%AD%A3%E5%9C%A8%E5%9F%B7%E8%A1%8C%20JMP%2017%EF%BC%8C%E5%B7%A5%E4%BD%9C%E6%B5%81%E7%A8%8B%E6%98%AF%E5%BB%BA%E7%AB%8B%E5%92%8C%E5%88%86%E4%BA%AB%E6%AD%A4%E9%A1%9E%E5%85%A7%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%E8%A6%86%EF%BC%9A%E6%A2%9D%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%E4%B8%A6%E4%B8%8D%E5%A4%AA%E8%A4%87%E9%9B%9C%E3%80%82%E6%88%91%E6%B2%92%E6%9C%89%E5%AF%AB%E5%85%AC%E5%BC%8F%EF%BC%8C%E8%80%8C%E6%98%AF%E5%AF%AB%E4%BA%86%E8%A1%A8%E6%A0%BC%E8%85%B3%E6%9C%AC%E3%80%82%E6%AF%8F%E7%95%B6%E6%B7%BB%E5%8A%A0%E6%9B%B4%E5%A4%9A%E6%95%B8%E6%93%9A%E6%99%82%EF%BC%8C%E6%82%A8%E9%83%BD%E5%8F%AF%E4%BB%A5%E9%81%8B%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%B7%A8%E8%BC%AF%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CP%3E%E4%BB%94%E7%B4%B0%E6%9F%A5%E7%9C%8B%E8%A1%A8%E6%A0%BC%E5%BE%8C%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%B5%90%E6%9E%9C%E5%96%AE%E5%85%83%E6%A0%BC%E4%B8%AD%E7%BC%BA%E5%B0%91%E5%80%BC%E3%80%82%E6%82%A8%E6%87%89%E8%A9%B2%E5%B0%87%E5%AE%83%E5%80%91%E9%87%8D%E6%96%B0%E7%B7%A8%E7%A2%BC%E7%82%BA%200%20%E6%88%96%E7%A8%8D%E5%BE%AE%E6%9B%B4%E6%94%B9%E8%85%B3%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%E8%A6%86%EF%BC%9A%E6%A2%9D%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%B8%AC%EF%BC%8C%E5%9B%A0%E7%82%BA%E6%B2%92%E6%9C%89%E6%95%B8%E6%93%9A%E5%8F%AF%E4%BB%A5%E6%B8%AC%E8%A9%A6%E9%80%99%E4%B8%80%E9%BB%9E%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%B7%A8%E8%BC%AF%EF%BC%9A%3C%2FP%3E%0A%3CP%3E%E6%88%91%E5%80%91%E6%94%B6%E5%88%B0%E6%A8%A3%E6%9C%AC%E8%B3%87%E6%96%99%E5%BE%8C%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