Comments (18)
Considering the sample request from the timing section.
In the first phase, the bytes necessary for the request are written on the Tx line, according to the specification there should be a 5 millisecond delay between each symbol. The duration of this delay is defined by INTERSYMBOL_WAIT. It is possible that the ECU still discerns the bytes correctly when this delay is lowered.
So wait between each transmitted byte is INTERSYMBOL_WAIT, equal to 5 ms.
For the request, 5 bytes (each 8 bits), with 4 INTERSYMBOL_WAIT
periods: 5 * 8 * (1/10400) + 4 * 0.005 = 0.024s
.
Followed by the response, of 7 bytes (each 8 bits), with 6 INTERSYMBOL_WAIT
periods: 7 * 8 *( 1 / 10400) + 6 * 0.005 = 0.035s
.
Total of request + response: 0.024s + 0.035s = 59ms
, per request.
it uses 17 data with an average sampling rate between 300ms and 400ms
Lets assume that is an average 350ms, 350ms / 17 = 20.6ms
. That's three times faster than the specification allows (assuming equal length requests). ๐ค
Lower values of INTERSYMBOL_WAIT
give different durations for the requests:
INTERSYMBOL_WAIT = 5: 5 * 8 * (1/10400) + 4 * 0.005 + 7 * 8 *( 1 / 10400) + 6 * 0.005 = 0.059 = 59ms
INTERSYMBOL_WAIT = 4: 5 * 8 * (1/10400) + 4 * 0.004 + 7 * 8 *( 1 / 10400) + 6 * 0.004 = 0.049 = 49ms
INTERSYMBOL_WAIT = 3: 5 * 8 * (1/10400) + 4 * 0.003 + 7 * 8 *( 1 / 10400) + 6 * 0.003 = 0.039 = 39ms
INTERSYMBOL_WAIT = 2: 5 * 8 * (1/10400) + 4 * 0.002 + 7 * 8 *( 1 / 10400) + 6 * 0.002 = 0.029 = 29ms
INTERSYMBOL_WAIT = 1: 5 * 8 * (1/10400) + 4 * 0.001 + 7 * 8 *( 1 / 10400) + 6 * 0.001 = 0.019 = 19ms
My hunch, they set INTERSYMBOL_WAIT
to 1ms, change this line to:
#define OBD9141_INTERSYMBOL_WAIT 1
And retry?
from obd9141.
I'm not sure I understand, I think you need software to enable the esp32 or arduino to record?
I said this in this comment;
Perhaps you can make a logic analyzer from an esp32? Use the adapter from amazon, and connect the logic analyzer to the Rx signal.
That https://github.com/EUA/ESP32_LogicAnalyzer looks promising for recording the signal? I've never used it, but it seems to be compatible with sigrok, from the screenshot it uses: Pulseview (Linux, Windows installers), through the standard SUMP protocol.
Then
- Record the K-line with
proprietary adapter
. - Record the K-line with the
ESP32 / OBD9141.h
system.
We compare the differences in timing and see how the proprietary adaptor is so fast.
from obd9141.
๐ฎ
Well, that's all looking super odd. There's no 5 baud init like here. No init at all.
With 10400 baud we have frame errors, so I used 10000, because the sampling rate was 20 kHz only?
With that we obtain...
2950ms: 13 04 00 17
2980ms: 13 04 00 17
5000ms: b8 ff 13 f1 01 a2 f9 ff
6000ms: b8 ff 13 f1 01 02 f9 ff # probably same as 5000ms?
7000ms: b8 4d f7 02 1a 80 c4
7115ms - 7394ms: ... lots of data
7500ms: b8 4d f7 02 1a 80 c4
7545ms - 7820ms: ... lots of data
7900ms: b8 4d f7 02 1a 80 c4
7980ms - 8254ms: ... lots of data
Repeat
Even accounting for some bit errors or framing offsets from the sampling at just 20000Hz. I don't think this is 9141-2? Or it must be some special mode I've never seen before, the lots of data is really really lots of data.
I don't see how we would split that data into PID's. It'll require significant reverse engineering to figure that out I think, this doesn't look like standard 9141-2 OBD pid requests ๐
from obd9141.
I will see to make an analyzer and publish the information it returns
from obd9141.
I had already done this and you could see that it was going a little faster to say it three times I very much doubt it
no offense i think there is a problem of time management because the example i gave you for the esp32 we have about 8 give in one second
unfortunately I can't try to compare because it's proprietary software with a proprietary USB Adapter
however I can make a comparison with the serial monitor by asking several requests and then comparing them once the modification is done
I'll see if I can do that tomorrow
from obd9141.
@iwanders
do you have any software or something that i can analyze with my esp32 or an arduino uno/mega i didn't find anything interesting and i tried but we don't have the recorder
so that I can send you the data that I collected on the proprietary adapter
thanks
from obd9141.
thank you very much for your reply sorry for the inconvenience
here is what I was able to find with INPA software and its k+dcan adapter
inpa-initalisation-read-throttle-position.sr.zip
from obd9141.
Again and as always thank you very much for your answer and for taking the time to answer me
personally with your code I can't reach less than 1.3s for 17 data
https://youtu.be/AYiHjN-IgrU
yes the sampling rate was 20kHz
I can do it again with many more if you want
It's been almost 15 days of relentless trying to find what other protocol can go through K-line I can only find ISO9141
My mini cooper S R53 (2005) is part of the BMW group and I think they have their own protocol because the adapter only works on BMW and Mini
but again when I look on the side of BMW I only turn on ISO9141 there may be KWP2000 but I did not find anything on that side
the only thing I'm actually watching right now is this
https://github.com/uholeschak/ediabaslib
from obd9141.
yes the sampling rate was 20kHz
I can do it again with many more if you want
Nah, I think we got the information we need, it's just... something different :/
personally with your code I can't reach less than 1.3s for 17 data
Yeah, I see that bummer.
My mini cooper S R53 (2005) is part of the BMW group and I think they have their own protocol because the adapter only works on BMW and Mini
I think you're right, that would explain the very long data blocks we got.
from obd9141.
I found the source code of my adapter I also have all the id I am super happy
https://github.com/uholeschak/ediabaslib/blob/master/EdiabasLib/UdsFileReader/UdsReader.cs
Do you mind helping me in this project ?
of course i will reward you for this if you agree can you tell me how much would you like
I know how to code a little and I manage a little but I know that I am clearly not at your level and I mainly use Visual Studio code any other support is unknown to me
I'm not sure I'll be able to do this alone in a reasonable time.
from obd9141.
Do you mind helping me in this project ?
of course i will reward you for this if you agree can you tell me how much would you like
Nope, I've done all I can to help here. I've got a fulltime job and am currently not for hire for additional work.
I know how to code a little and I manage a little but I know that I am clearly not at your level and I mainly use Visual Studio code any other support is unknown to me
I'm not sure I'll be able to do this alone in a reasonable time.
Some general advice; always push your limits to expand your skillset, but don't try to do things too far away from your current level, that makes it difficult and hard to keep motivated. Do work on projects you are passionate about and that push your skills.
Marking this issue as done, the remainder is not related to OBD9141-2.
from obd9141.
@iwanders sorry for not taking the time to answer I was developing the display
https://youtu.be/MYhseVD6s9I
I went back to looking for the protocol they use this high speed in reality it is the KWP2000 protocol
ISO 9141 also has this function on some cars there is a slow function or the 5 baud initialization and ask there is also the fast initialization
http://raviprashanthsn-technical.blogspot.com/2013/10/kwp2000-basic-information.html
for the IDs I don't know yet if it's the same
from obd9141.
@gauix4 , very cool! Love the reaction at the start of the video. I exactly know that feeling ^_^
It could be kwp2000 slow init, initialisation procedure for that was (relatively recently) added under #42. Worth a shot?
from obd9141.
@iwanders yes it's cool but I go through the can bus and unfortunately I don't have the data I want I can get them only by KWP2000
I will make in the next few hours a modification on your code because there is a very big problem of time management I do not understand why did you use delay instead of millis ?
from obd9141.
I will make in the next few hours a modification on your code because there is a very big problem of time management I do not understand why did you use delay instead of millis ?
Classical synchronous vs asynchronous programming decision. This was easy at the time, for me it worked fine, because I wasn't doing anything in parallel to the requests. Writing asynchronous code always involves adding state machines to keep track of where you are in the logic / steps. No need to make a PR for this, I have no desire to change the 'threading model' of this library at this stage.
Only the init should have delays, after that all requests go through readBytes
, which you should be able to change into an available()
call or something, to prevent blocking while the ECU is sending the response.
Good luck :)
from obd9141.
@iwanders
thank you for your answer I will study your code I am not as good as you but I think I understand what you wrote :)
I need kpw2000 rather fast what I'm interested in and to have data as quickly as possible :)
unlike ISO9141 there is more data on the WKP2000 so I hope to progress in the next few days to succeed at least having communication with my ECU
from obd9141.
@iwanders
impossible to have a communication or a link with the KWP protocol
I tested the low and the fast both did not work for me.
// startCommunicationRequest message:
uint8_t message[4] = {0xC1, 0x33, 0xF1, 0x81}; // where do you find this do you have any information please :)
// checksum (0x66) is calculated by request method.
the first image and with my special adapter
the second is kwp fast we can see that there are similarities
from obd9141.
where do you find this do you have any information please
Don't remember, but the 'blame' button allows you to review which commit last touched the line. Looks like it went in in PR 12 which has links to some issues with long discussions, you may be able to find more information there.
In the logic analyzers, try adding a UART analyser at 10400 baud rate, that should decode the symbols for you, making it easier to discern similarities or dissimilarities.
from obd9141.
Related Issues (20)
- readerKWP not working for me HOT 9
- missing Serial1 declaration
- KWP Slow init with v1 != v2 HOT 4
- ESP32 support HOT 7
- problem 'serial_port' was not declared in this scope HOT 14
- For ESP32 HOT 3
- How to make it work.... HOT 20
- How can I know if I'm doing everything right? HOT 5
- esp32 with OBD9141 not work HOT 19
- A special kind of communication with the ECU HOT 6
- ESP32 Serial1 crash... HOT 2
- KWP71 Compatibility HOT 2
- Unable to initialize obd.init() HOT 5
- The example for esp32 does not work. HOT 3
- PIDS HOT 8
- None of the examples is working HOT 3
- mitisuibishi MUT 2 (kline 5 baud init) HOT 1
- Usage with MCP2025 HOT 2
- LiquidCrystal_I2C problem. HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. ๐๐๐
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google โค๏ธ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from obd9141.