cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 
Try the Materials Informatics Toolkit, which is designed to easily handle SMILES data. This and other helpful add-ins are available in the JMP® Marketplace
Choose Language Hide Translation Bar
ileshem
Level III

Creating a series column based on other column values.

Hello, I need help with creating a column, using JSL,  that fill a series and increase by one when a triggered by another column value.

Like column 2 below, every time there is a “Yes” in column 1 it increases by 1 the value in column 2.
Hope I am clear enough.

Column 1 Column 2
No 1
No 1
No 1
No 1
Yes 2
No 2
No 2
No 2
No 2
No 2
Yes 3
No 3
No 3
No 3
3 REPLIES 3
jthi
Super User

Re: Creating a series column based on other column values.

Below is one option using Col Cumulative Sum() with comparison

Names Default To Here(1);

dt = New Table("Untitled",
	Add Rows(14),
	Compress File When Saved(1),
	New Column("Column 1",
		Character,
		"Nominal",
		Set Values(
			{"No", "No", "No", "No", "Yes", "No", "No", "No", "No", "No", "Yes",
			"No", "No", "No"}
		)
	),
	New Column("Column 2",
		Numeric,
		"Continuous",
		Format("Best", 12),
		Set Values([1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3])
	)
);

dt << New Column("Series", Numeric, Continuous, Formula(
	Col Cumulative Sum(:Column 1 == "Yes") + 1
));
-Jarmo
ileshem
Level III

Re: Creating a series column based on other column values.

Thanks!!
Now I need some more help,  if I have another column and I want it to "reset" the count, like this:

Column 0Column 1Series
RedNo1
RedNo1
RedNo1
RedNo1
RedYes2
RedNo2
RedNo2
BlueNo1
BlueNo1
BlueNo1
BlueYes2
BlueNo2
BlueNo2
BlueNo2
GreenNo1
GreenNo1
GreenNo1
GreenNo1
GreenNo1
GreenYes2
GreenNo2
GreenNo2

I  Tried this:

dt << New Column("Series", Numeric, Continuous, Formula(If( :column 0 == Lag( :column 0, 1 ),
(Col Cumulative Sum(:column 1 == 1) + 1),
(Col Cumulative Sum(:column 1 == 1) + 0)
)));

 

 

jthi
Super User

Re: Creating a series column based on other column values.

Col Cumulative Sum() does support <byvar> so you can use :Column 0 as byvar and it will perform the calculation separately for each value found from :Column 0

 

-Jarmo