RoboterCC - Robotic Code Compiler
Forum Roboter.CC Webseite Ankündigungen NiboRoboLib 3.4 - Release Candidate

Welcome

Nachrichten

Sie sind nicht eingeloggt.

Werbung

Letzte Themen

  • •Keine Beiträge vorhanden•

Site-Statistic

  • 7489 private projects
  • 385 public projects
  • 16432958 lines compiled
  • 58478 builds
NIBO @ facebook YouTube Twitter
•Willkommen•, •Gast•
•Benutzername:• •Passwort:• •Angemeldet bleiben:•
Offizielle Ankündigungen von Roboter.CC
Neue Roboter-Plattformen, Programmiersprachen und Bibliotheken
  • •Seite:•
  • 1

•THEMA:• NiboRoboLib 3.4 - Release Candidate

NiboRoboLib 3.4 - Release Candidate •8 •Jahre• 8 •Monate• her• #3657

  • workwind
  • •workwinds Avatar•
  • •OFFLINE•
  • Administrator
  • •Beiträge:• 573

NiboRoboLib 3.4

Unter folgendem Link gibt es die NiboRoboLib 3.3 für NIBObee, NIBO burger und NIBO2:
www.roboter.cc/index.php?view=article&id=28&option=com_content&Itemid=1

Changelog
****************************************************************
* 2016-03-07
* NiboRoboLib 3.4
* Release Candidate
****************************************************************

2016-03-07 (springob)
* arduino: autodetect installed Arduino version (1.6.5/1.6.6/1.6.7)

2016-02-25 (springob)
* burger: new function led_toggle()
* burger: fixed motpwm_get[Left/Right]() sign bug (thanks to BirgerT!)

2016-02-25 (springob)
* nibobee: fixed pwm calculation speed bug (thanks to BirgerT!)
* nibobee: added usart_rxavail() usart_txavail()
* burger: added usart_rxavail() usart_txavail()
* nibo2: added uart[0/1]_rxavail() uart[0/1]_txavail()

2016-02-24 (springob)
* burger: added clock_elapsed_ms() and clock_get_systime_ms(), optimized clock ISR
* nibobee: added clock_elapsed_ms() and clock_get_systime_ms(), optimized clock ISR

2016-02-23 (springob)
* burger: fixed pwm calculation speed bug (thanks to BirgerT!)
* burger: analog.c more independant on clock speed
* nibo2: support for RG128064 gfx displays

2016-02-22 (springob)
* windows: signed drivers for NIBObee, NIBO burger and UCOM-IR2
* arduino: fixed delay() problem with timer0 (delay is now based on pwm/pid timer)

2016-01-11 (springob)
* burger: improved documentation, some items from BirgerT

2016-01-11 (springob)
* burger: improved pid controller: motpid_setTargetRel(dist, dist, speed)
will reach the target position with much higher precision
* burger: EngineClass::setPWM() will call motpid_release() first
* burger: rc5 tx and rx should work now, just plug a SFH 5110-36 in X13!


-workwind-
•Letzte Änderung•: •8 •Jahre• 8 •Monate• her• • von • workwind.
•Der Administrator hat öffentliche Schreibrechte deaktiviert.•

NiboRoboLib 3.4 - Release Candidate •8 •Jahre• 8 •Monate• her• #3659

  • BirgerT
  • •BirgerTs Avatar•
  • •OFFLINE•
  • Gold Boarder
  • •Beiträge:• 325
..und im RoboDude gibt es auch eine neue Funktion: :thumb:

Menuzeile -> Tools -> Reset MCU

Hiermit kann der Mikro Controller resettet werden, solange er mit dem PC verbunden ist.

Mit der Installation der neuen NiboRobolib wird leider noch die Doku der Lib Version 3.3 installiert :S
Deshalb hier ein paar Worte von mir vorab:

Leider ist - womöglich durch den Bug Fix "pwm calculation" - das Regelverhalten von motpid_setTargetRel(100,100,50) bei meinem Burger schlechter geworden:
Erstmal schiesst die PWM bis auf Maximum (1022) hoch, und dicht am Ziel (es fehlen 2 Ticks) geht's erstmal drüber hinaus, dann wieder rückwärts (aber auch zu weit), vorwärts (wieder knapp daneben), wieder rückwärts (und dann erst Punktlandung).

Sehr gut finde ich auch, dass es die Funktionen clock_elapsed_ms() und clock_get_systime_ms() gibt:
clock_get_systime_ms dürfte der *duino Funktion millis() entsprechen.
Wird clock_elapsed_ms() einmal in der Hauptschleife ("while(1==1) {..loop_duration = clock_elapsed_ms()..}") verwendet, wird deren Laufzeit gemessen.
Ohne delay() und xx_wait() sollte die Laufzeit so zwischen 0ms bis 3ms liegen.
Jetzt können unterschiedliche Wartezeiten parallel ablaufend programmiert werden:
Hier noch eine kleine Hilfsfunktion die vor main() einzufügen wäre
/////////////////////////////////////////////////////////////////////////
//
//		Vergleichsfunktion liefert die Zeit (basetime - subtime) oder 0,
//		wenn subtime >= basetime war. Mit dieser Funktion können 
//		"Eieruhren" für zeitgesteuerte Aktionen realisiert werden.
//	
//		#define		LED1_OFF_TIME 400;
//		#define		LED1_ON_TIME 50;
//	
//		uint16_t led1_time = LED1_OFF_TIME;
//		:
//		// Dauer des letzten Schleifendurchlaufs
//		loop_duration = clock_elapsed_ms();
//		:
//		if (led1_time = clock_get_event(led1_time, loop_duration) == 0) {
//		// die Eieruhr ist abgelaufen
//			if (led_get(LED_1)) {
//				// LED leuchtet bereits -> abschalten
//				led_set(LED_1, 0);
//				// Aus-Zeit setzen
//				led1_time = LED1_OFF_TIME;	
//			} 
//			else {
//				// LED ist aus -> einschalten
//				led_set(LED_1, 0);
//				// Ein-Zeit setzen
//				led1_time = LED1_ON_TIME;	
//			} // if led_get
//		} // if clock_get_event
//
//
uint16_t clock_get_event(uint16_t basetime, uint16_t subtime) {
 
		if (basetime > subtime) {
			return (basetime - subtime);
		} 
		else {
			return 0;
		}
	} // clock_get_event
 
.und hier ein Teil der Hauptschleife in main()
	while(1==1) {
		// sei(); // is done within clock_elapsed_ms
		//
		//	Laufzeit der Main_Loop:
		//	Aus der Variablen "clock_ms" ermittelte Zeitdifferenz entspricht
		//	der Laufzeit (Ausführungsdauer) der Hauptschleife.
		//
		loop_duration = clock_elapsed_ms();
		//
		//	Von Autobahnbaustellenfahrzeugen inspiriertes 
		//	Blinken der blauen LEDS 
		//
		#define LED2_ON   50
		#define LED2_OFF 200
		#define LED3_ON   52
		#define LED3_OFF 202
		
		static	uint16_t led2_interval = LED2_ON;
		static	uint16_t led3_interval = LED3_ON;
		led2_interval = clock_get_event(led2_interval,loop_duration);
		led3_interval = clock_get_event(led3_interval,loop_duration);
 
		if (!led2_interval) {
			if (led_get(2)) {
				led_set(1,0);
				led_set(2,0);
				led2_interval = LED2_OFF;
			} // if led_get()
			else {
				led_set(2,1);
				led2_interval = LED2_ON;
			} // else led_get()
		} // if !led_interval
 
		if (!led3_interval) {
			if (led_get(3)) {
				led_set(3,0);
				led_set(4,0);
				led3_interval = LED3_OFF;
			} // if led_get()
			else {
				led_set(3,1);
				led3_interval = LED3_ON;
			} // else led_get()
		} // if !led_interval
 
	} // while(1==1)	
 

Die beiden vorderen LEDs blinken in leicht unterschiedlicher Frequenz - versucht das mal mit delay() zu realisieren..



usart_rxavail() liefert jetzt die Anzahl der über den UART empfangenen Zeichen im Buffer - oK -
usart_txavail() klingt logisch, aber leider heisst die Funktion in Wirklichkeit usart_txfree() :P

Mit dieser Funktion kann man also vorher prüfen, ob die auszugebenden Zeichen überhaupt in den Ausgabebuffer passen; zur Erinnerung - wenn 6 Zeichen in den Buffer geschrieben werden sollen (z.Bsp. aktueller Inhalt einer int16 Variablen), aber nur Platz für zwei Zeichen ist, wartet die usart_sendefunktion bei jedem Zeichen, bis es in den Buffer passt - bei 9600 Baud dauert ein Zeichen ca.1ms (=(9600 Bit/sec) / (10,5 Bit/Zeichen) = 915 Zeichen/sec).
Nun das sieht ja nicht schlimm aus - wenn man nur eine Variable betrachtet - bei 8 Sensorwerten pro Schleifendurchlauf (bzw. alle 10ms) und den zusätzlichen Zeichen für "Neue Zeile" oder "Cursorpositionierung" wird es dann schon etwas länger dauern.
Ich habe mal eine Tabellenausgabe aller Sensorwerte in allen Modi (PASSIVE, ACTIVE, DIFFERENTIAL) programmiert, also 30 Werte (inkl. volt, key u. randomseed) die (fast) ständig aktualisiert werden, und das Blinken (siehe oben) auch noch funktioniert.. Damit die Durchlaufzeit der Hauptschleife möglichst kurz bleibt, wird vor jeder Ausgabe erst geprüft, ob genug Platz im Buffer ist; ansonsten wir die Routine wieder verlassen (break;) und erstmal etwas anderes im Programm ausgeführt.

Auszug aus dem switch(state)-Zweig
	case 9:		// Cursor für Ausgabe setzen
		if (uart_txd_avail() > 8) {
			// Cursorspalte für Tabellenspalte
			curspalte = pgm_read_byte(&anatabs[tspalte] +1);
			ansi_curpos(curzeile, curspalte);
			test_share_state++;
		} // if txd_avail
 
		else break;
 
 
	case 10:	// Analogwert Ausgabe
		if (uart_txd_avail() > 8) {
			anaidx = pgm_read_byte(&zeilen[tzeile]);
 
			if (tspalte == 0) {
				print_u16d(analog_getValue(anaidx));			
			} 
			else if (tspalte == 1) {
				print_u16d(surface_getAbs(anaidx));
			} 
			else if (tspalte == 2) {
				print_u16d(surface_get(anaidx));
			}
 
			test_share_state++;
		} // if txd_avail
 
		else break;
 
•Der Administrator hat öffentliche Schreibrechte deaktiviert.•
  • •Seite:•
  • 1
•Moderatoren•: workwind
•Ladezeit der Seite: 0.205 Sekunden•

Werbung

Protected by R Antispam