Scangauge or Torque App?

Discussion in 'Generation 1 Prius Discussion' started by FinsUp99, Dec 29, 2012.

  1. butchbs1985

    butchbs1985 Taking things apart is fun!

    Joined:
    Feb 24, 2007
    230
    16
    0
    Location:
    ChicagoLand
    Vehicle:
    2013 Prius v wagon
    Model:
    Three
    What do you use for the software with this? Seems like a great deal since the Mini VCI connectors appear to be super cheap. I had the 'standard' TIS subscription but couldn't find it before my two days expired. Thanks.
     
  2. 3prongpaul

    3prongpaul Hybrid Shop Owner, worked on 100's of Prius's

    Joined:
    Jul 18, 2010
    954
    724
    1
    Location:
    Boulder Hybids, Boulder, CO
    Vehicle:
    2006 Prius
    Model:
    N/A
    I use the official Mongoose and Techstream.

    Most Mini VCI sellers include an unofficial "cracked" copy of the official Techstream with the cable. (not legal but they don't care)

    I've played around with Mini VCI from Ebay and it pretty much does the same things a Mongoose/Techstream. (Techstream is the official Toyota dealer diagnostic software)

    If you are home tinkerer and are not concerned about using "stolen" software the Mini VCI package is a very good deal and will pay for itself the first time you use it.
     
    bwilson4web likes this.
  3. LeeD

    LeeD Junior Member

    Joined:
    Mar 28, 2013
    19
    4
    0
    Vehicle:
    2001 Prius
    Model:
    I
    Thank you!
     
  4. That_Prius_Car

    That_Prius_Car Austin Kinser

    Joined:
    Sep 23, 2009
    1,282
    344
    3
    Location:
    Pittsburgh, PA
    Vehicle:
    2016 Prius
    Model:
    Two
    So, is there a final version with all the correct PIDs avaliable now? I'm using the PLX Kiwi Bluetooth adapter with my Android phone. I tried using MG1 and MG2 RPM but MG1's readings were off the wall. Also with HV battery current, and State of Charge. Is there a HP reading for MG2 by the way? Thanks!
     
  5. ChapmanF

    ChapmanF Senior Member

    Joined:
    Mar 30, 2008
    25,233
    16,468
    0
    Location:
    Indiana, USA
    Vehicle:
    2010 Prius
    Model:
    IV


    Did the PIDs you're using come from the NHW11 vehicle database converted with the Torque
    exporter (see the bottom of this page)? I gave some more details on how to do that back here.

    In a nutshell, the way the exporter stands right now, it's just a file you have to download, and you can run it on your computer from the command line. The comments at the top of the exporter file give an example of how to run it. Your computer probably already has Java installed, and you can follow the link in my earlier post to download the free-forever version of Saxon, which it also needs. You don't need to download the NHW11 database itself as a separate step; you can just give the exporter the network URL for the database file, and it will read the current database and make your up-to-date CSV file.

    One problem that can arise when people just mail around their copies of CSV files is you never who's got which one up to date with what. If you work straight from the database on sourceforge and you know of anything missing or erroneous, please let me know, or, we can set you up with an id to make corrections directly.

    The CSV exporter is kind of a stopgap measure. Really the best way to integrate with Torque would be to write a plugin for it that accepts the XML database file directly, and would let you select items to display and in what measurement units right in the app. Just haven't got the time right now.

    I know the database has MG1 and MG2 rpms and torques. If you find the scaling is wrong (do you have another scanner or other way to check it?), we should make sure that gets corrected in the database.

    I don't think the ECUs will give you MG horsepower numbers directly. That's an example of something I think you can do in Torque itself by creating a synthetic PID that multiplies rpm and torque, with the right scale factor.

    -Chap
     
  6. Jeff F

    Jeff F Member

    Joined:
    Oct 10, 2012
    111
    37
    0
    Location:
    London, Ontario
    Vehicle:
    2001 Prius
    Model:
    N/A
    I'm not sure that we ever solved successfully for the signed variables, which include MG rpm and torque, and one of the two HV current measures. See the earlier extended discussion in this thread. This field has worked for me for HV Current:

    HV Battery Current (-99.9A to 999A only)

    There are also two available S0C fields, and this one works for me

    State-of-Charge soC 01C9 (A)*(200)/(51) 0 1000 %{SoC} 8416F1
     
    That_Prius_Car likes this.
  7. amitt

    amitt Junior Member

    Joined:
    Aug 25, 2013
    37
    2
    0
    Vehicle:
    2002 Prius
    Model:
    I
    Hey Guys,

    Great thread, I used the information in your discussion and wrote a small tool for PC that can read all the Prius Gen 1 PID in one screen, I used Labview to do so, and a$1 bluetooth dongle that can connect to a cheap $14 ELM 327 Ebay OBD plug.

    I tested it, and the battery voltages results are in the attached pictures, I see almost 0.2v between max and min voltage, any reason for concern?

    Please let me know if you have more ideas on what to add to this tool, so that maybe us prius gen 1 owners will have some PC diagnostic tool in addition to the android option, and we can save some money, I injured my back very bad lately, so I have some spare time to play with it a little when it doesn't hurt to sit for more than a few minutes.

    Thanks and keep up the good work.
    prius1.png prius2.png prius3.png prius4.png
     
    Alexis Bazin likes this.
  8. ChapmanF

    ChapmanF Senior Member

    Joined:
    Mar 30, 2008
    25,233
    16,468
    0
    Location:
    Indiana, USA
    Vehicle:
    2010 Prius
    Model:
    IV


    That's cool! Will you be sharing the source for your tool?

    I've not used Labview before. If you develop something with Labview, does it end up being something you can distribute and other people can run it without buying Labview themselves? Or is it only usable where people already have Labview installed?

    -Chap
     
  9. Jeff F

    Jeff F Member

    Joined:
    Oct 10, 2012
    111
    37
    0
    Location:
    London, Ontario
    Vehicle:
    2001 Prius
    Model:
    N/A
    Very cool.

    WRT the voltage delta, my experience is that because of the slow communication time and the volatility of the voltage when underway it's hard to get a really good handle on the high-low delta. The voltage of all cells could have changed by more than 0.2v in the time it takes to cycle through the measurement across all the cells. I suppose that sitting at a stop with the ICE off would allow a consistent measure, but I think that is also the circumstance in which a marginal battery probably looks fine.

    When I watch the high and low values (and I've been watching this pretty intently for the past 6 months!) when underway I see a delta of .15-.40v. I was somewhat alarmed with the higher spreads at first, but they occur during high charge/discharge states, so I'm rosily attributing that to the timing differences. And as Bob Wilson and others have pointed out, having one or two blocks that are consistently low against the others is probably of more concern than the actual spread. In my case while the high voltage is almost always block 1 or 19, the low varies across ~5 other blocks, which gives some comfort. In any case I haven't ever had an error code, and the behaviour has been consistent across >25,000 km.

    Hope this helps.
     
  10. Jeff F

    Jeff F Member

    Joined:
    Oct 10, 2012
    111
    37
    0
    Location:
    London, Ontario
    Vehicle:
    2001 Prius
    Model:
    N/A
    ps. looking more closely at your images I see errors returned for some of the codes - this looks like what I was getting before resolving the ECU addressing, when all the ECUs sent a response to the unqualified query. If that's the case you might want to resolve that. You probably have the ability to parse out the response you want, but there is discussion above on how you might address the specific ECU, which is a better approach if you can do it.
     
  11. amitt

    amitt Junior Member

    Joined:
    Aug 25, 2013
    37
    2
    0
    Vehicle:
    2002 Prius
    Model:
    I
    I can create an exe version with the environment that will allow it to run without having Labview on the PC, I believe it will be 100-200MB file, and it will be located in the "program files" folder, with a desktop and start menu links.
    BTW I originally wrote this tool so that I'll have the Prius fuel consumption bars(that shows consumption every 5 min) in my Yaris, or any other car, I used some loops that take the air flow sensor, and speed, and use it in a formula to calculate the momentary fuel consumption, I actually tested it on the prius and the results are amazing, the prius bars and my bars are exactly the same, so does the MPG main result.

    BTW#2 ,I didn't try it, but I believe that it can run with an ELM that is connected via usb cable as well, since it only has to show as COM port on windows, and my tool does the rest.


    Thanks, I also think it's a slow communication issue, I had to give 1000 ms delay between write and read to the COM port, it's only that slow in the 2002 prius, other cars I've tested can return the string in about 100ms.


    Thanks for the response about it, at first I found it very strange to receive so many hexadecimal numbers, because I originally wrote the first screen so that I'll have the Prius fuel consumption bars(that shows consumption every 5 min) in my Yaris, or any other car(it's SUPER COOL to have the Prius bars on other cars), but when I saw multiple responds from the ELM on the prius 2002, I just bypassed the "problem" , for instance:

    This is an example to a string response after sending " 01A6"to the ELM,
    01A6
    41 A6 00 00 32 FF
    41 A6 00 00 00 00 00 <DATA ERROR
    41 A6 06 66 06 71

    >
    I've made some experiments, and found that the last line is what I need, in order to get A,B,C,D for the blocks voltages formula, so I wrote a code that finds the last "41 A6" combination, and read the hexa code right after it, in order to get the A,B,C,D and perform my calculations.
    I did the same for the HV block resistances.
    To be honest, I don't know how to address the 'header" as you've mentioned on this thread, I send the PID to the port and run my search algorithm on the results to get what I want, I think it will be nice to know how to do it, but anyway, since this Gen1 prius is probably the only creature that will have this kind of ECU setup, and since I'm writing everything manually on Labview, I think it's ok to work with it as is for now, unless someone knows how to address the other ECU(?), just by sending string with the PID to ELM?

    I attached pictures of the ELM327 that I have, and the bluetooth dongle.

    Thanks! elm.JPG bt.JPG
     
  12. amitt

    amitt Junior Member

    Joined:
    Aug 25, 2013
    37
    2
    0
    Vehicle:
    2002 Prius
    Model:
    I

    Hey Jeff, one more thought, I believe that the first line that I'm getting is the results for the 16F1 header and that the second result line is the D5F1 header, I know that we have at least 3 PID that are used for both ECU, such as: 01CE, 01CD, 01D1, and I wonder if that's why I get 2 or 3 results, and whether I should look for the second row for the Battery ECU, and the first row for the main ECU, I believe that when <DATA ERROR is received, the PID simply does not exist in the ECU that is receiving it.

    Example:
    The PID 01CE is for Battery blocks 17,18,19 resistance, but it's also the MG1 and MG2 temperature PID, the string that I receive from the ELM is:
    01CE
    41 CE 52 4E
    41 CE 15 15 15


    >
    Means that the 52 4E is for MG1/2 temperatures, and 15 15 15 is for battery blocks resistance?

    If so , I only need to write those 3 PIDs so that the ones that refer to the 16F1 header will look at the first line, to get the correct value, and then I'm pretty much done with all PIDs( that I know that exist from this thread).
    In other cars it's so simple, you only have 1 line :)
    Thanks.
     
  13. vincent1449p

    vincent1449p Active Member

    Joined:
    May 24, 2004
    894
    331
    0
    Location:
    Singapore
    Vehicle:
    2012 Prius c
    If you don't set any header, the ELM will use functional addressing; i.e. any ECUs that has data will response. If an ECU is busy, other ECUs that are not will response first. So, the 1st response is not necessary from 16 and the 2nd may not necessary from D5. You can turn on the header in the response by this command so you can see which ECU responded:

    > AT H1

    If you specify the header in your query, you are using physical addressing; i.e. only the target ECU will response, the rest will not. e.g.

    > AT SH 82 16 F1

    Every query issue after this will only get response from the HV ECU. If you need to get response from other ECU, you need to set the header again. e.g.

    > AT SH 82 D5 F1

    You can refer to the ELM327 data sheet for more information.

    Vincent
     
  14. amitt

    amitt Junior Member

    Joined:
    Aug 25, 2013
    37
    2
    0
    Vehicle:
    2002 Prius
    Model:
    I

    Hi Vincent, that is great information, I remember looking at the ELM data sheet almost 2 years ago when I wrote the tool for the Yaris, I was too lazy to look again , Thanks, I will run this line and will test the results and report if it worked .

    Thanks !
     
  15. Jeff F

    Jeff F Member

    Joined:
    Oct 10, 2012
    111
    37
    0
    Location:
    London, Ontario
    Vehicle:
    2001 Prius
    Model:
    N/A
    My experience is that a header value of 82 doesn't work, but 84 does. I don't have an explanation for this. Getting functional addressing working is a much better solution than trying to isolate the response you're interested in, particularly given the communication bottleneck.
     
  16. bwilson4web

    bwilson4web BMW i3 and Model 3

    Joined:
    Nov 25, 2005
    27,797
    15,723
    0
    Location:
    Huntsville AL
    Vehicle:
    2018 Tesla Model 3
    Model:
    Prime Plus
    This thread needs to be a sticky because it contains the original work known about:
    • Gen I customizations
    • Torque App
    • Android
    These brilliant pioneers figured out the answers but some have moved on to other rides and interests.

    A couple of weeks ago, Good Prius Friend SageBrush loaned me an Android and bluetooth OBD adapter. Within a short period of time, I created a vehicle profile "03_Prius" and connected to the car. The default, engine ECU PIDs are working just fine. The next step is to load the known PIDs and test, hopefully without compromising existing customizations for the NHW20. The question becomes how to add value?

    All I might offer is mapping how Android/Torque fits with:
    • Graham miniscanner - NHW11 day-driver and primary for engineering studies
    • miniVCI - NHW11 and ZVW30 debugger and diagnostic tool (*)
    • Scangauge II - ZVW30 day-driver and limited diagnostic tool, also NHW11
    So I'm interested in what might be needed.

    Bob Wilson

    * - I used to have Autoenginuity but a 'hijacker' killed that virtual PC image. At $500, I've never bothered to refresh it because it did not offer any technical advantage over miniVCI.
     
    kenoarto and usbseawolf2000 like this.
  17. ger-ev

    ger-ev New Member

    Joined:
    Feb 26, 2017
    4
    3
    3
    Location:
    Hungary
    Vehicle:
    2001 Prius
    Model:
    N/A
    I reworked the nhw11.csv for better usage.
    Tested with Torque 1.8
    Can be downloaded from github repository here:
    github com
    search for "nhw11"

    Main modifications:

    Sensor naming prefixed with ECU name (where the data from).
    (HV, EN, Bat)

    Changing equation on negative value capable sensors

    Changing unusual metric like dV cV deciVolt CentiVolt
    (may be because of scangauge's limited display capability)

    Explanation of some special PIDs:

    Fuel Injection time for cyl #1: This value remains not 0 when engine is stopped. Must be combined with "Drive Situation ID" if Drive Situation ID is 0 => fuel injection is 0 This can be used for instant fuel consumption measurement.

    Shift Sensor 2: P : approx. 0.5 V R : approx. 2.8 V N : approx. 3.4 V D : approx. 4.0 V B : approx. 4.5 V

    Shift Sensor 1: P : 1 R : 2 N : 4 D : 8 B : 16

    Fuel system status #1: 1 : Open loop due to insufficient engine temperature 2 : Closed loop, using oxygen sensor feedback to determine fuel mix 4 : Open loop due to engine load OR fuel cut due to deacceleration 8 : Open loop due to system failure 16: Closed loop, using at least one oxygen sensor but there is a fault in the feedback system

    Drive Situation ID: 0 : Engine stopped 1 : Engine about to be stopped 2 : Engine about to be started 3 : Engine operated or operating 4 : Generating power or load driving 6 : Revving up in P position
     
    telmo744 likes this.
  18. anon61

    anon61 Junior Member

    Joined:
    Nov 9, 2011
    30
    2
    0
    Location:
    sweden
    Vehicle:
    2001 Prius
    Model:
    N/A
    This should be made into a sticky post
     
  19. enormiss

    enormiss New Member

    Joined:
    Oct 24, 2017
    10
    3
    0
    Location:
    Jersey
    Vehicle:
    2002 Prius
    Model:
    N/A
    Just wanted to say thanks to everyone who contributed!
     
  20. enormiss

    enormiss New Member

    Joined:
    Oct 24, 2017
    10
    3
    0
    Location:
    Jersey
    Vehicle:
    2002 Prius
    Model:
    N/A
    How do you change the HV battery temp sensors to display Fahrenheit?
    Have it selected in units in settings but guess I need to edit PID...
    Anyone get the state of charge working?