public EDFDataBlock(int numRecords, EDFDataRecord[] records) { if (numRecords == records.Length) { this.numRecords = numRecords; this.records = records; } else { throw new ArgumentException("Expected " + numRecords + " records, got " + records.Length + "!"); } }
/// <summary> /// Main function to write all signals data to EDF /// </summary> public void generateEDFData(EDFHeader.EDFHeader iHeader, string path) { EDFHeader.EDFHeader header = iHeader; List<EDFSignal> signals = header.edfSignals; //check if annotations are added Byte[][] annotationSignals; if (signals[signals.Count - 1].samples == null) { //TODO Add annotations functionality above the default requirements int numAnnotationBytes = ConvertEDFHeaderField.toInt32((signals[signals.Count - 1].numSamples)) * 2; // times 2 as we need number of bytes, not number of 2-byte ints. DefaultAnnotationGenerator defGen = new DefaultAnnotationGenerator(ConvertEDFHeaderField.toInt32(header.numRecords), ConvertEDFHeaderField.toInt32(header.durationRecord), numAnnotationBytes); annotationSignals = defGen.getAnnotationSignals(); } else { annotationSignals = null; } EDFDataBlock dataBlock = new EDFDataBlock(); dataBlock.numRecords = ConvertEDFHeaderField.toInt32(header.numRecords); dataBlock.records = new EDFDataRecord[dataBlock.numRecords]; //declare and define the records field for (int i = 0; i < dataBlock.numRecords; i++) //for all the records, proceed { //create the required data record, initialise fields EDFDataRecord record = new EDFDataRecord(); record.numSignals = ConvertEDFHeaderField.toInt32(header.ns); EDFDataRecordSignal[] newSignals = new EDFDataRecordSignal[record.numSignals]; //will contain all the signals for this record for (int j = 0; j < (signals.Count - 1); j++) //for every signal except annotations, which will be handled separately { //make a new signal for the record, initialise it, make a new sample array, and copy the required number of samples over to there EDFDataRecordSignal newSignal = new EDFDataRecordSignal(); newSignal.numSamples = ConvertEDFHeaderField.toInt32(signals[j].numSamples); newSignal.samples = new EDFDataRecordSignalSample[newSignal.numSamples]; int startCopy = i * newSignal.numSamples; //index to start copying from, then copy newSignal.numsample samples. for (int k = 0; k < newSignal.numSamples; k++) //copy 256 items { newSignal.samples[k] = signals[j].samples[startCopy + k]; } // Array.Copy(signals[j].samples, i * newSignal.numSamples, newSamples, 0, newSignal.numSamples); //be careful of overflows here newSignals[j] = newSignal; //copy the new signal into the signals array for this record } //handle annotations -> put into newSignals[signals.count - 1] Byte[] annotationSignal = annotationSignals[i]; //declare a signal sample array that is half the length of the byte array EDFDataRecordSignalSample[] newAnnotationSamples = new EDFDataRecordSignalSample[annotationSignal.Length / 2]; EDFDataRecordSignal newAnnotationSignal = new EDFDataRecordSignal(); for (int k = 0; k < annotationSignal.Length; k += 2) //advanced 2 bytes by 2 bytes while converting them all into int16s { //convert to int16 Int16 convertedInt = BitConverter.ToInt16(annotationSignal, k); //add this to a new signal sample EDFDataRecordSignalSample newAnnotationSample = new EDFDataRecordSignalSample(convertedInt); //assign the signal samples to an index each, but since the length is halved, the highest index is halved too newAnnotationSamples[k / 2] = newAnnotationSample; } newAnnotationSignal.numSamples = ConvertEDFHeaderField.toInt32(signals[signals.Count - 1].numSamples); //get size of annotation field and set newAnnotationSignal.samples = newAnnotationSamples; //set the samples of the signal to the previously converted and assigned 2byte ints //finally, put this as the last signal in the signal array newSignals[signals.Count - 1] = newAnnotationSignal; //finally, add all signals to record and add that record to the dataBlock record.signals = newSignals; dataBlock.records[i] = record; } //get the entire EDF Datablock Int16[] outData = dataBlock.getEDFData(); //write to output EDF using (BinaryWriter b = new BinaryWriter(File.Open(path, FileMode.Append))) //TODO allow file to be specified! { for (int i = 0; i < outData.Length; i++) { //Console.Write(outData[i] + " "); b.Write(outData[i]); } b.Close(); } Console.WriteLine("Done writing to file!"); }